diff options
author | Guilherme Polo <ggpolo@gmail.com> | 2009-01-28 19:23:28 (GMT) |
---|---|---|
committer | Guilherme Polo <ggpolo@gmail.com> | 2009-01-28 19:23:28 (GMT) |
commit | 6785cf0169a1213f15549374361801185de8a8b0 (patch) | |
tree | bea705d298a33fe1fd2e8db6e8b0990dd419c104 /Lib/lib-tk | |
parent | 4eae07844803880d0b57144708dca8889db511e8 (diff) | |
download | cpython-6785cf0169a1213f15549374361801185de8a8b0.zip cpython-6785cf0169a1213f15549374361801185de8a8b0.tar.gz cpython-6785cf0169a1213f15549374361801185de8a8b0.tar.bz2 |
Added support for collecting tests only from specific packages.
Diffstat (limited to 'Lib/lib-tk')
-rw-r--r-- | Lib/lib-tk/test/runtktests.py | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/Lib/lib-tk/test/runtktests.py b/Lib/lib-tk/test/runtktests.py index b72badf..6c974cf 100644 --- a/Lib/lib-tk/test/runtktests.py +++ b/Lib/lib-tk/test/runtktests.py @@ -19,9 +19,13 @@ def is_package(path): return True return False -def get_tests_modules(basepath=this_dir_path, gui=True): +def get_tests_modules(basepath=this_dir_path, gui=True, packages=None): """This will import and yield modules whose names start with test_ - and are inside packages found in the path starting at basepath.""" + and are inside packages found in the path starting at basepath. + + If packages is specified it should contain package names that want + their tests colleted. + """ py_ext = '.py' for dirpath, dirnames, filenames in os.walk(basepath): @@ -31,6 +35,9 @@ def get_tests_modules(basepath=this_dir_path, gui=True): if is_package(dirpath) and filenames: pkg_name = dirpath[len(basepath) + len(os.sep):].replace('/', '.') + if packages and pkg_name not in packages: + continue + filenames = filter( lambda x: x.startswith('test_') and x.endswith(py_ext), filenames) @@ -45,7 +52,7 @@ def get_tests_modules(basepath=this_dir_path, gui=True): if gui: raise -def get_tests(text=True, gui=True): +def get_tests(text=True, gui=True, packages=None): """Yield all the tests in the modules found by get_tests_modules. If nogui is True, only tests that do not require a GUI will be @@ -55,7 +62,7 @@ def get_tests(text=True, gui=True): attrs.append('tests_nogui') if gui: attrs.append('tests_gui') - for module in get_tests_modules(gui=gui): + for module in get_tests_modules(gui=gui, packages=packages): for attr in attrs: for test in getattr(module, attr, ()): yield test |