1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-12 16:30:56 +00:00

core/tests: improve test harness (fixes #1157)

This commit is contained in:
matejcik 2020-08-03 15:47:47 +02:00 committed by matejcik
parent efc5ccdaf0
commit c3afb93837

View File

@ -1,3 +1,5 @@
import sys
from trezor.utils import ensure from trezor.utils import ensure
@ -196,6 +198,9 @@ class TestResult:
return self.errorsNum == 0 and self.failuresNum == 0 return self.errorsNum == 0 and self.failuresNum == 0
generator_type = type((lambda: (yield))())
def run_class(c, test_result): def run_class(c, test_result):
o = c() o = c()
set_up = getattr(o, "setUp", lambda: None) set_up = getattr(o, "setUp", lambda: None)
@ -206,14 +211,28 @@ def run_class(c, test_result):
print(' ', name, end=' ...') print(' ', name, end=' ...')
m = getattr(o, name) m = getattr(o, name)
try: try:
set_up() try:
test_result.testsRun += 1 set_up()
m() test_result.testsRun += 1
tear_down() retval = m()
if isinstance(retval, generator_type):
raise RuntimeError("{} must not be a generator (it is async, uses yield or await).".format(name))
elif retval is not None:
raise RuntimeError("{} should not return a result.".format(name))
finally:
tear_down()
print(" ok") print(" ok")
except SkipTest as e: except SkipTest as e:
print(" skipped:", e.args[0]) print(" skipped:", e.args[0])
test_result.skippedNum += 1 test_result.skippedNum += 1
except AssertionError as e:
print(" failed")
sys.print_exception(e)
test_result.failuresNum += 1
except BaseException as e:
print(" errored:", e)
sys.print_exception(e)
test_result.errorsNum += 1
def main(module="__main__"): def main(module="__main__"):
@ -230,6 +249,16 @@ def main(module="__main__"):
runner = TestRunner() runner = TestRunner()
result = runner.run(suite) result = runner.run(suite)
msg = "Ran %d tests" % result.testsRun msg = "Ran %d tests" % result.testsRun
result_strs = []
if result.skippedNum > 0: if result.skippedNum > 0:
msg += " (%d skipped)" % result.skippedNum result_strs.append("{} skipped".format(result.skippedNum))
if result.failuresNum > 0:
result_strs.append("{} failed".format(result.failuresNum))
if result.errorsNum > 0:
result_strs.append("{} errored".format(result.errorsNum))
if result_strs:
msg += " (" + ", ".join(result_strs) + ")"
print(msg) print(msg)
if not result.wasSuccessful():
raise SystemExit(1)