diff options
author | Ezio Melotti <ezio.melotti@gmail.com> | 2011-05-14 03:02:25 (GMT) |
---|---|---|
committer | Ezio Melotti <ezio.melotti@gmail.com> | 2011-05-14 03:02:25 (GMT) |
commit | fec3ad103613b46c9821f210581efca6fedcb9a9 (patch) | |
tree | bea3331759ca18b0c7baeab3d552cb2d2dab1577 | |
parent | 7c4048918053e457eadaf76f2a1906d2cff879f2 (diff) | |
download | cpython-fec3ad103613b46c9821f210581efca6fedcb9a9.zip cpython-fec3ad103613b46c9821f210581efca6fedcb9a9.tar.gz cpython-fec3ad103613b46c9821f210581efca6fedcb9a9.tar.bz2 |
Change import_fresh_module to work with packages.
-rw-r--r-- | Lib/test/support.py | 16 |
1 files changed, 6 insertions, 10 deletions
diff --git a/Lib/test/support.py b/Lib/test/support.py index b2f0f87..dcfadea 100644 --- a/Lib/test/support.py +++ b/Lib/test/support.py @@ -80,19 +80,15 @@ def import_module(name, deprecated=False): def _save_and_remove_module(name, orig_modules): """Helper function to save and remove a module from sys.modules - Return True if the module was in sys.modules, False otherwise. Raise ImportError if the module can't be imported.""" - saved = True - try: - orig_modules[name] = sys.modules[name] - except KeyError: - # try to import the module and raise an error if it can't be imported + # try to import the module and raise an error if it can't be imported + if name not in sys.modules: __import__(name) - saved = False - else: del sys.modules[name] - return saved - + for modname in list(sys.modules): + if modname == name or modname.startswith(name + '.'): + orig_modules[modname] = sys.modules[modname] + del sys.modules[modname] def _save_and_block_module(name, orig_modules): """Helper function to save and block a module in sys.modules |