1
0
Fork 0

Add link to ninja log instead of XML #216

XML tooks too long to load and not that helpful

+ link tell how many tests have failed

+ link is added only if something is off
This commit is contained in:
Mikhail Goncharov 2020-07-22 15:45:53 +02:00
parent c384553e0b
commit 605f18bad1
2 changed files with 10 additions and 1 deletions

View file

@ -50,6 +50,8 @@ def ninja_all_report(step: Step, _: Report, filter_output: bool):
'ninja all', cwd=build_dir) 'ninja all', cwd=build_dir)
logging.debug(f'ninja all: returned {rc}') logging.debug(f'ninja all: returned {rc}')
step.set_status_from_exit_code(rc) step.set_status_from_exit_code(rc)
if not step.success:
report.add_artifact(artifacts_dir, 'ninja-all.log', 'build failed')
def ninja_check_all_report(step: Step, _: Report, filter_output: bool): def ninja_check_all_report(step: Step, _: Report, filter_output: bool):
@ -67,6 +69,14 @@ def ninja_check_all_report(step: Step, _: Report, filter_output: bool):
logging.debug(f'ninja check-all: returned {rc}') logging.debug(f'ninja check-all: returned {rc}')
step.set_status_from_exit_code(rc) step.set_status_from_exit_code(rc)
test_results_report.run(build_dir, 'test-results.xml', step, report) test_results_report.run(build_dir, 'test-results.xml', step, report)
if not step.success:
message = 'tests failed'
f = report.test_stats['fail']
if f == 1:
message = '1 test failed'
if f > 1:
message = f'{f} tests failed'
report.add_artifact(artifacts_dir, 'ninja-check-all.log', message)
def run_step(name: str, report: Report, thunk: Callable[[Step, Report], None]) -> Step: def run_step(name: str, report: Report, thunk: Callable[[Step, Report], None]) -> Step:

View file

@ -32,7 +32,6 @@ def run(working_dir: str, test_results: str, step: Optional[Step], report: Optio
step.success = False step.success = False
step.messages.append(f'test report "{path}" is not found') step.messages.append(f'test report "{path}" is not found')
return return
report.add_artifact(working_dir, test_results, 'test results')
try: try:
success = True success = True
root_node = etree.parse(path) root_node = etree.parse(path)