summaryrefslogtreecommitdiffstats
path: root/Lib/lib-tk
diff options
context:
space:
mode:
authorGuilherme Polo <ggpolo@gmail.com>2009-01-28 19:23:28 (GMT)
committerGuilherme Polo <ggpolo@gmail.com>2009-01-28 19:23:28 (GMT)
commit6785cf0169a1213f15549374361801185de8a8b0 (patch)
treebea705d298a33fe1fd2e8db6e8b0990dd419c104 /Lib/lib-tk
parent4eae07844803880d0b57144708dca8889db511e8 (diff)
downloadcpython-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.py15
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