diff options
author | Michael Foord <fuzzyman@voidspace.org.uk> | 2010-04-03 01:15:21 (GMT) |
---|---|---|
committer | Michael Foord <fuzzyman@voidspace.org.uk> | 2010-04-03 01:15:21 (GMT) |
commit | 931190b4f5b8c2fc9171e0d30697dcb66fd93441 (patch) | |
tree | 65e2aece062a7d99accd8f86489d692a5335ef3f /Lib/unittest/loader.py | |
parent | 2b79fdfc69e40c144e27dadaf824b329acb65dae (diff) | |
download | cpython-931190b4f5b8c2fc9171e0d30697dcb66fd93441.zip cpython-931190b4f5b8c2fc9171e0d30697dcb66fd93441.tar.gz cpython-931190b4f5b8c2fc9171e0d30697dcb66fd93441.tar.bz2 |
Support dotted module names for test discovery paths in unittest. Issue 7780.
Diffstat (limited to 'Lib/unittest/loader.py')
-rw-r--r-- | Lib/unittest/loader.py | 27 |
1 files changed, 23 insertions, 4 deletions
diff --git a/Lib/unittest/loader.py b/Lib/unittest/loader.py index 022ed57..e0b8585 100644 --- a/Lib/unittest/loader.py +++ b/Lib/unittest/loader.py @@ -171,22 +171,41 @@ class TestLoader(object): packages can continue discovery themselves. top_level_dir is stored so load_tests does not need to pass this argument in to loader.discover(). """ + set_implicit_top = False if top_level_dir is None and self._top_level_dir is not None: # make top_level_dir optional if called from load_tests in a package top_level_dir = self._top_level_dir elif top_level_dir is None: + set_implicit_top = True top_level_dir = start_dir - top_level_dir = os.path.abspath(os.path.normpath(top_level_dir)) - start_dir = os.path.abspath(os.path.normpath(start_dir)) + top_level_dir = os.path.abspath(top_level_dir) if not top_level_dir in sys.path: # all test modules must be importable from the top level directory sys.path.append(top_level_dir) self._top_level_dir = top_level_dir - if start_dir != top_level_dir and not os.path.isfile(os.path.join(start_dir, '__init__.py')): - # what about __init__.pyc or pyo (etc) + is_not_importable = False + if os.path.isdir(os.path.abspath(start_dir)): + start_dir = os.path.abspath(start_dir) + if start_dir != top_level_dir: + is_not_importable = not os.path.isfile(os.path.join(start_dir, '__init__.py')) + else: + # support for discovery from dotted module names + try: + __import__(start_dir) + except ImportError: + is_not_importable = True + else: + the_module = sys.modules[start_dir] + top_part = start_dir.split('.')[0] + start_dir = os.path.abspath(os.path.dirname((the_module.__file__))) + if set_implicit_top: + self._top_level_dir = os.path.abspath(os.path.dirname(os.path.dirname(sys.modules[top_part].__file__))) + sys.path.remove(top_level_dir) + + if is_not_importable: raise ImportError('Start directory is not importable: %r' % start_dir) tests = list(self._find_tests(start_dir, pattern)) |