aboutsummaryrefslogtreecommitdiff
path: root/tools/patman/test_util.py
diff options
context:
space:
mode:
authorAlper Nebi Yasak <alpernebiyasak@gmail.com>2022-04-02 20:06:05 +0300
committerSimon Glass <sjg@chromium.org>2022-06-28 03:09:51 +0100
commitce12c47b92152e9457d3daa3ddbf53c1cc3de0bb (patch)
tree6e39ad092686a0eebaf8cd804675483f9125592e /tools/patman/test_util.py
parent6474aaa1d1de0fe246707ff05816a32776d48fa8 (diff)
downloadu-boot-ce12c47b92152e9457d3daa3ddbf53c1cc3de0bb.zip
u-boot-ce12c47b92152e9457d3daa3ddbf53c1cc3de0bb.tar.gz
u-boot-ce12c47b92152e9457d3daa3ddbf53c1cc3de0bb.tar.bz2
patman: test_util: Handle nonexistent tests while loading tests
It's possible to request a specific test to run when trying to run a python tool's tests. If we request a nonexistent test, the unittest loaders generate a fake test that reports this as an error. However, we get these fake tests even when the test exists, because test_util can load tests from multiple places one by one and the test we want only exists in one. The test_util helpers currently remove these fake tests when printing test results, but that's more of a workaround than a proper solution. Instead, don't even try to load the missing tests. Signed-off-by: Alper Nebi Yasak <alpernebiyasak@gmail.com> Reviewed-by: Simon Glass <sjg@chromium.org>
Diffstat (limited to 'tools/patman/test_util.py')
-rw-r--r--tools/patman/test_util.py21
1 files changed, 5 insertions, 16 deletions
diff --git a/tools/patman/test_util.py b/tools/patman/test_util.py
index 8b2220d..a4c2a2c 100644
--- a/tools/patman/test_util.py
+++ b/tools/patman/test_util.py
@@ -110,19 +110,6 @@ def report_result(toolname:str, test_name: str, result: unittest.TestResult):
test_name: Name of test that was run, or None for all
result: A unittest.TestResult object containing the results
"""
- # Remove errors which just indicate a missing test. Since Python v3.5 If an
- # ImportError or AttributeError occurs while traversing name then a
- # synthetic test that raises that error when run will be returned. These
- # errors are included in the errors accumulated by result.errors.
- if test_name:
- errors = []
-
- for test, err in result.errors:
- if ("has no attribute '%s'" % test_name) not in err:
- errors.append((test, err))
- result.testsRun -= 1
- result.errors = errors
-
print(result)
for test, err in result.errors:
print(test.id(), err)
@@ -184,10 +171,12 @@ def run_test_suites(result, debug, verbosity, test_preserve_dirs, processes,
preserve_outdirs=test_preserve_dirs and test_name is not None,
toolpath=toolpath, verbosity=verbosity)
if test_name:
- try:
+ # Since Python v3.5 If an ImportError or AttributeError occurs
+ # while traversing a name then a synthetic test that raises that
+ # error when run will be returned. Check that the requested test
+ # exists, otherwise these errors are included in the results.
+ if test_name in loader.getTestCaseNames(module):
suite.addTests(loader.loadTestsFromName(test_name, module))
- except AttributeError:
- continue
else:
suite.addTests(loader.loadTestsFromTestCase(module))
if use_concurrent and processes != 1: