Update runpy.py to 3.14.5 (#7849)

This commit is contained in:
Shahar Naveh
2026-05-12 14:51:46 +03:00
committed by GitHub
parent 72679af4b2
commit f6c382c595
2 changed files with 47 additions and 10 deletions

25
Lib/runpy.py vendored
View File

@@ -103,8 +103,10 @@ def _run_module_code(code, init_globals=None,
# Helper to get the full name, spec and code for a module
def _get_module_details(mod_name, error=ImportError):
# name= is only accepted by ImportError and its subclasses.
kwargs = {"name": mod_name} if issubclass(error, ImportError) else {}
if mod_name.startswith("."):
raise error("Relative module names not supported")
raise error("Relative module names not supported", **kwargs)
pkg_name, _, _ = mod_name.rpartition(".")
if pkg_name:
# Try importing the parent to avoid catching initialization errors
@@ -137,12 +139,13 @@ def _get_module_details(mod_name, error=ImportError):
if mod_name.endswith(".py"):
msg += (f". Try using '{mod_name[:-3]}' instead of "
f"'{mod_name}' as the module name.")
raise error(msg.format(mod_name, type(ex).__name__, ex)) from ex
raise error(msg.format(mod_name, type(ex).__name__, ex),
**kwargs) from ex
if spec is None:
raise error("No module named %s" % mod_name)
raise error("No module named %s" % mod_name, **kwargs)
if spec.submodule_search_locations is not None:
if mod_name == "__main__" or mod_name.endswith(".__main__"):
raise error("Cannot use package as __main__ module")
raise error("Cannot use package as __main__ module", **kwargs)
try:
pkg_main_name = mod_name + ".__main__"
return _get_module_details(pkg_main_name, error)
@@ -150,17 +153,19 @@ def _get_module_details(mod_name, error=ImportError):
if mod_name not in sys.modules:
raise # No module loaded; being a package is irrelevant
raise error(("%s; %r is a package and cannot " +
"be directly executed") %(e, mod_name))
"be directly executed") %(e, mod_name),
**kwargs)
loader = spec.loader
if loader is None:
raise error("%r is a namespace package and cannot be executed"
% mod_name)
% mod_name,
**kwargs)
try:
code = loader.get_code(mod_name)
except ImportError as e:
raise error(format(e)) from e
raise error(format(e), **kwargs) from e
if code is None:
raise error("No code object available for %s" % mod_name)
raise error("No code object available for %s" % mod_name, **kwargs)
return mod_name, spec, code
class _Error(Exception):
@@ -234,6 +239,7 @@ def _get_main_module_details(error=ImportError):
# Also moves the standard __main__ out of the way so that the
# preexisting __loader__ entry doesn't cause issues
main_name = "__main__"
kwargs = {"name": main_name} if issubclass(error, ImportError) else {}
saved_main = sys.modules[main_name]
del sys.modules[main_name]
try:
@@ -241,7 +247,8 @@ def _get_main_module_details(error=ImportError):
except ImportError as exc:
if main_name in str(exc):
raise error("can't find %r module in %r" %
(main_name, sys.path[0])) from exc
(main_name, sys.path[0]),
**kwargs) from exc
raise
finally:
sys.modules[main_name] = saved_main

View File

@@ -216,6 +216,25 @@ class RunModuleTestCase(unittest.TestCase, CodeExecutionMixin):
# Package without __main__.py
self.expect_import_error("multiprocessing")
def test_invalid_names_set_name_attribute(self):
cases = [
# (mod_name, expected_name) -- comment indicates raise site
("nonexistent_runpy_test_module",
"nonexistent_runpy_test_module"), # spec is None
("sys.imp.eric", "sys.imp.eric"), # find_spec error
(".relative_name", ".relative_name"), # relative name rejected
("sys", "sys"), # builtin: no code object
("multiprocessing", "multiprocessing"), # package without __main__
]
for mod_name, expected_name in cases:
with self.subTest(mod_name=mod_name):
try:
run_module(mod_name)
except ImportError as exc:
self.assertEqual(exc.name, expected_name)
else:
self.fail("Expected ImportError for %r" % mod_name)
def test_library_module(self):
self.assertEqual(run_module("runpy")["__name__"], "runpy")
@@ -714,6 +733,17 @@ class RunPathTestCase(unittest.TestCase, CodeExecutionMixin):
msg = "can't find '__main__' module in %r" % script_dir
self._check_import_error(script_dir, msg)
def test_directory_error_sets_name_attribute(self):
with temp_dir() as script_dir:
self._make_test_script(script_dir, 'not_main')
try:
run_path(script_dir)
except ImportError as exc:
self.assertEqual(exc.name, '__main__')
else:
self.fail("Expected ImportError for directory without "
"__main__.py")
def test_zipfile(self):
with temp_dir() as script_dir:
mod_name = '__main__'
@@ -837,7 +867,7 @@ class TestExit(unittest.TestCase):
def test_pymain_run_command(self):
self.assertSigInt(["-c", "import ham"], cwd=self.ham.parent)
@unittest.expectedFailure # TODO: RUSTPYTHON
@unittest.expectedFailure # TODO: RUSTPYTHON
def test_pymain_run_stdin(self):
self.assertSigInt([], input="import ham", cwd=self.ham.parent)