diff options
author | Nick Coghlan <ncoghlan@gmail.com> | 2011-01-11 10:05:20 (GMT) |
---|---|---|
committer | Nick Coghlan <ncoghlan@gmail.com> | 2011-01-11 10:05:20 (GMT) |
commit | 90be5fb8175705320c8d2cdabb35292a40257cf7 (patch) | |
tree | 5292addc88008e526b05009c99096efdddf71b68 /Lib | |
parent | 6655d113e66b679b5b0c8849f7c58107fdf3e22e (diff) | |
download | cpython-90be5fb8175705320c8d2cdabb35292a40257cf7.zip cpython-90be5fb8175705320c8d2cdabb35292a40257cf7.tar.gz cpython-90be5fb8175705320c8d2cdabb35292a40257cf7.tar.bz2 |
Issue 10556: test_zipimport_support implicitly imports too many modules (including _ssl) to safely clobber sys.modules after each test
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/test/support.py | 6 | ||||
-rw-r--r-- | Lib/test/test_zipimport_support.py | 23 |
2 files changed, 23 insertions, 6 deletions
diff --git a/Lib/test/support.py b/Lib/test/support.py index 152cac9..3d1d0f1 100644 --- a/Lib/test/support.py +++ b/Lib/test/support.py @@ -1199,6 +1199,12 @@ def modules_cleanup(oldmodules): if k.startswith('encodings.')] sys.modules.clear() sys.modules.update(encodings) + # XXX: This kind of problem can affect more than just encodings. In particular + # extension modules (such as _ssl) don't cope with releoding properly. + # Really, test modules should be cleaning out the test specific modules they + # know they added (ala test_runpy) rather than relying on this function (as + # test_importhooks and test_pkg do currently). + # Implicitly imported *real* modules should be left alone (see issue 10556). sys.modules.update(oldmodules) #======================================================================= diff --git a/Lib/test/test_zipimport_support.py b/Lib/test/test_zipimport_support.py index b935b3f..54ab864 100644 --- a/Lib/test/test_zipimport_support.py +++ b/Lib/test/test_zipimport_support.py @@ -13,6 +13,7 @@ import doctest import inspect import linecache import pdb +import unittest from test.script_helper import (spawn_python, kill_python, assert_python_ok, temp_dir, make_script, make_zip_script) @@ -29,7 +30,6 @@ verbose = test.support.verbose # Retrieve some helpers from other test cases from test import test_doctest, sample_doctest -from test.test_importhooks import ImportHooksBaseTestCase def _run_object_doctest(obj, module): @@ -59,17 +59,28 @@ def _run_object_doctest(obj, module): -class ZipSupportTests(ImportHooksBaseTestCase): - # We use the ImportHooksBaseTestCase to restore +class ZipSupportTests(unittest.TestCase): + # This used to use the ImportHooksBaseTestCase to restore # the state of the import related information - # in the sys module after each test + # in the sys module after each test. However, that restores + # *too much* information and breaks for the invocation of + # of test_doctest. So we do our own thing and leave + # sys.modules alone. # We also clear the linecache and zipimport cache # just to avoid any bogus errors due to name reuse in the tests def setUp(self): linecache.clearcache() zipimport._zip_directory_cache.clear() - ImportHooksBaseTestCase.setUp(self) - + self.path = sys.path[:] + self.meta_path = sys.meta_path[:] + self.path_hooks = sys.path_hooks[:] + sys.path_importer_cache.clear() + + def tearDown(self): + sys.path[:] = self.path + sys.meta_path[:] = self.meta_path + sys.path_hooks[:] = self.path_hooks + sys.path_importer_cache.clear() def test_inspect_getsource_issue4223(self): test_src = "def foo(): pass\n" |