diff options
author | Eric Snow <ericsnowcurrently@gmail.com> | 2016-09-08 02:08:02 (GMT) |
---|---|---|
committer | Eric Snow <ericsnowcurrently@gmail.com> | 2016-09-08 02:08:02 (GMT) |
commit | bf00bc783fd87544c1717b2db163736cea6412aa (patch) | |
tree | 293b139cca275b02148ef35ffa7fe2bd0e2a2489 | |
parent | 280bc223b4b5df841da20faafd1b63cde2694acd (diff) | |
download | cpython-bf00bc783fd87544c1717b2db163736cea6412aa.zip cpython-bf00bc783fd87544c1717b2db163736cea6412aa.tar.gz cpython-bf00bc783fd87544c1717b2db163736cea6412aa.tar.bz2 |
Issue #15578: Correctly incref the parent module while importing.
-rw-r--r-- | Lib/test/test_import.py | 18 | ||||
-rw-r--r-- | Misc/NEWS | 2 | ||||
-rw-r--r-- | Python/import.c | 2 |
3 files changed, 22 insertions, 0 deletions
diff --git a/Lib/test/test_import.py b/Lib/test/test_import.py index c17da10..2abf5b2 100644 --- a/Lib/test/test_import.py +++ b/Lib/test/test_import.py @@ -397,6 +397,24 @@ class ImportTests(unittest.TestCase): finally: sys.path.pop(0) + def test_replace_parent_in_sys_modules(self): + dir_name = os.path.abspath(TESTFN) + os.mkdir(dir_name) + try: + pkg_dir = os.path.join(dir_name, 'sa') + os.mkdir(pkg_dir) + with open(os.path.join(pkg_dir, '__init__.py'), 'w') as init_file: + init_file.write("import v1") + with open(os.path.join(pkg_dir, 'v1.py'), 'w') as v1_file: + v1_file.write("import sys;" + "sys.modules['sa'] = sys.modules[__name__];" + "import sa") + sys.path.insert(0, dir_name) + # a segfault means the test failed! + import sa + finally: + rmtree(dir_name) + class PycRewritingTests(unittest.TestCase): # Test that the `co_filename` attribute on code objects always points @@ -7082,6 +7082,8 @@ Core and Builtins - Add Py3k warnings for parameter names in parentheses. +- Issue #15578: Correctly incref the parent module while importing. + - Issue #7362: Give a proper error message for ``def f((x)=3): pass``. - Issue #7085: Fix crash when importing some extensions in a thread on MacOSX diff --git a/Python/import.c b/Python/import.c index 96f7d47..af47b0b 100644 --- a/Python/import.c +++ b/Python/import.c @@ -2243,8 +2243,10 @@ import_module_level(char *name, PyObject *globals, PyObject *locals, if (parent == NULL) goto error_exit; + Py_INCREF(parent); head = load_next(parent, level < 0 ? Py_None : parent, &name, buf, &buflen); + Py_DECREF(parent); if (head == NULL) goto error_exit; |