diff options
author | Brett Cannon <brett@python.org> | 2012-04-20 19:52:17 (GMT) |
---|---|---|
committer | Brett Cannon <brett@python.org> | 2012-04-20 19:52:17 (GMT) |
commit | 1032af95ffc6ec1c288504dfd5321e941e3607d4 (patch) | |
tree | 0f42f7d938cf85a36ecaaa5f61f6f3d81d6b2904 | |
parent | 3dfc22cc048da44c21cb95996522696d8c679fc9 (diff) | |
download | cpython-1032af95ffc6ec1c288504dfd5321e941e3607d4.zip cpython-1032af95ffc6ec1c288504dfd5321e941e3607d4.tar.gz cpython-1032af95ffc6ec1c288504dfd5321e941e3607d4.tar.bz2 |
Issue #14585: test_import now runs all tests under
importlib.test.import_ using builtins.__import__() instead of just the
relative import tests.
-rw-r--r-- | Lib/importlib/test/__init__.py | 25 | ||||
-rw-r--r-- | Lib/test/test_import.py | 25 |
2 files changed, 35 insertions, 15 deletions
diff --git a/Lib/importlib/test/__init__.py b/Lib/importlib/test/__init__.py index e69de29..815a706 100644 --- a/Lib/importlib/test/__init__.py +++ b/Lib/importlib/test/__init__.py @@ -0,0 +1,25 @@ +import os +import sys +import unittest + +def test_suite(package=__package__, directory=os.path.dirname(__file__)): + suite = unittest.TestSuite() + for name in os.listdir(directory): + if name.startswith(('.', '__')): + continue + path = os.path.join(directory, name) + if (os.path.isfile(path) and name.startswith('test_') and + name.endswith('.py')): + submodule_name = os.path.splitext(name)[0] + module_name = "{0}.{1}".format(package, submodule_name) + __import__(module_name, level=0) + module_tests = unittest.findTestCases(sys.modules[module_name]) + suite.addTest(module_tests) + elif os.path.isdir(path): + package_name = "{0}.{1}".format(package, name) + __import__(package_name, level=0) + package_tests = getattr(sys.modules[package_name], 'test_suite')() + suite.addTest(package_tests) + else: + continue + return suite diff --git a/Lib/test/test_import.py b/Lib/test/test_import.py index 8510eb8..f02681a 100644 --- a/Lib/test/test_import.py +++ b/Lib/test/test_import.py @@ -1,6 +1,6 @@ import builtins import imp -from importlib.test.import_ import test_relative_imports +from importlib.test.import_ import test_suite as importlib_import_test_suite from importlib.test.import_ import util as importlib_util import importlib import marshal @@ -694,21 +694,16 @@ class PycacheTests(unittest.TestCase): self.assertEqual(m.x, 5) -class RelativeImportFromImportlibTests(test_relative_imports.RelativeImports): - - def setUp(self): - self._importlib_util_flag = importlib_util.using___import__ - importlib_util.using___import__ = True - - def tearDown(self): - importlib_util.using___import__ = self._importlib_util_flag - - def test_main(verbose=None): - run_unittest(ImportTests, PycacheTests, - PycRewritingTests, PathsTests, RelativeImportTests, - OverridingImportBuiltinTests, - RelativeImportFromImportlibTests) + flag = importlib_util.using___import__ + try: + importlib_util.using___import__ = True + run_unittest(ImportTests, PycacheTests, + PycRewritingTests, PathsTests, RelativeImportTests, + OverridingImportBuiltinTests, + importlib_import_test_suite()) + finally: + importlib_util.using___import__ = flag if __name__ == '__main__': |