Commit c6c05d0e authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

regrtest: repeat summary after re-run (GH-7159)

Using -w, when failing tests are re-run in verbose mode, display
again the tests results at the end.
parent dbf10227
......@@ -88,6 +88,7 @@ class Regrtest:
self.skipped = []
self.resource_denieds = []
self.environment_changed = []
self.rerun = []
self.interrupted = False
# used by --slow
......@@ -283,8 +284,10 @@ class Regrtest:
self.ns.verbose3 = False
self.ns.match_tests = None
print()
print("Re-running failed tests in verbose mode")
for test in self.bad[:]:
self.rerun = self.bad[:]
for test in self.rerun:
print("Re-running test %r in verbose mode" % test, flush=True)
try:
self.ns.verbose = True
......@@ -302,22 +305,32 @@ class Regrtest:
print(count(len(self.bad), 'test'), "failed again:")
printlist(self.bad)
self.display_result()
def display_result(self):
# If running the test suite for PGO then no one cares about results.
if self.ns.pgo:
return
print()
print("== Tests result ==")
if self.interrupted:
# print a newline after ^C
print()
# print a newline after ^C
print("Test suite interrupted by signal SIGINT.")
executed = set(self.good) | set(self.bad) | set(self.skipped)
omitted = set(self.selected) - executed
print(count(len(omitted), "test"), "omitted:")
printlist(omitted)
# If running the test suite for PGO then no one cares about
# results.
if self.ns.pgo:
return
if self.rerun:
print()
print(count(len(self.rerun), "test"), "re-run tests:")
printlist(self.rerun)
if self.good and not self.ns.quiet:
print()
if (not self.bad
and not self.skipped
and not self.interrupted
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment