mirror of
https://github.com/python/cpython.git
synced 2024-12-18 22:34:08 +08:00
Do a better job of preserving the state of sys.modules.
This commit is contained in:
commit
dd61c3ba7e
@ -98,13 +98,18 @@ class FinderTests(unittest.TestCase):
|
||||
new_path_hooks = [zipimport.zipimporter,
|
||||
_bootstrap.FileFinder.path_hook(
|
||||
*_bootstrap._get_supported_file_loaders())]
|
||||
with util.uncache('email'):
|
||||
missing = object()
|
||||
email = sys.modules.pop('email', missing)
|
||||
try:
|
||||
with util.import_state(meta_path=sys.meta_path[:],
|
||||
path=new_path,
|
||||
path_importer_cache=new_path_importer_cache,
|
||||
path_hooks=new_path_hooks):
|
||||
module = import_module('email')
|
||||
self.assertIsInstance(module, ModuleType)
|
||||
finally:
|
||||
if email is not missing:
|
||||
sys.modules['email'] = email
|
||||
|
||||
|
||||
def test_main():
|
||||
|
Loading…
Reference in New Issue
Block a user