testrunner: Generate JUnit result files

The JUnit format is easier to feed to tools that don't support
the native Qt Test XML format.

Change-Id: Ie9803cc0fb0577b3b7258b05faa78d8fb1aad1d1
Reviewed-by: Dimitrios Apostolou <jimis@qt.io>
This commit is contained in:
Tor Arne Vestbø 2022-08-23 15:49:59 +02:00
parent adebdd0f9a
commit 210020412c

View File

@ -236,7 +236,7 @@ def run_test(arg_list: List[str], **kwargs):
def unique_filename(test_basename: str) -> str: def unique_filename(test_basename: str) -> str:
timestamp = round(time.time() * 1000) timestamp = round(time.time() * 1000)
return f"{test_basename}-{timestamp}.xml" return f"{test_basename}-{timestamp}"
# Returns tuple: (exit_code, xml_logfile) # Returns tuple: (exit_code, xml_logfile)
def run_full_test(test_basename, testargs: List[str], output_dir: str, def run_full_test(test_basename, testargs: List[str], output_dir: str,
@ -250,9 +250,11 @@ def run_full_test(test_basename, testargs: List[str], output_dir: str,
# Append arguments to write log to qtestlib XML file, # Append arguments to write log to qtestlib XML file,
# and text to stdout. # and text to stdout.
if not no_extra_args: if not no_extra_args:
filename_base = unique_filename(test_basename)
results_files.append( results_files.append(
os.path.join(output_dir, unique_filename(test_basename))) os.path.join(output_dir, f"{filename_base}.xml"))
output_testargs.extend(["-o", results_files[0] + ",xml"]) output_testargs.extend(["-o", results_files[0] + ",xml"])
output_testargs.extend(["-o", f"{filename_base}.junit.xml,junitxml"])
output_testargs.extend(["-o", "-,txt"]) output_testargs.extend(["-o", "-,txt"])
proc = run_test(testargs + specific_extra_args + output_testargs, proc = run_test(testargs + specific_extra_args + output_testargs,
@ -280,8 +282,10 @@ def rerun_failed_testcase(test_basename, testargs: List[str], output_dir: str,
for i in range(max_repeats): for i in range(max_repeats):
# For the individual testcase re-runs, we log to file since Coin needs # For the individual testcase re-runs, we log to file since Coin needs
# to parse it. That is the reason we use unique filename every time. # to parse it. That is the reason we use unique filename every time.
filename_base = unique_filename(test_basename)
output_args = [ output_args = [
"-o", os.path.join(output_dir, unique_filename(test_basename)) + ",xml", "-o", os.path.join(output_dir, f"{filename_base}.xml") + ",xml",
"-o", os.path.join(output_dir, f"{filename_base}.junit.xml") + ",junitxml",
"-o", "-,txt"] "-o", "-,txt"]
L.info("Re-running testcase: %s", failed_arg) L.info("Re-running testcase: %s", failed_arg)
if i < max_repeats - 1: if i < max_repeats - 1: