# resulttool - Show logs # # Copyright (c) 2019 Garmin International # # SPDX-License-Identifier: GPL-2.0-only # import os import resulttool.resultutils as resultutils def show_ptest(result, ptest, logger): logdata = resultutils.ptestresult_get_log(result, ptest) if logdata is not None: print(logdata) return 0 print("ptest '%s' log not found" % ptest) return 1 def show_reproducible(result, reproducible, logger): try: print(result['reproducible'][reproducible]['diffoscope.text']) return 0 except KeyError: print("reproducible '%s' not found" % reproducible) return 1 def log(args, logger): results = resultutils.load_resultsdata(args.source) ptest_count = sum(1 for _, _, _, r in resultutils.test_run_results(results) if 'ptestresult.sections' in r) if ptest_count > 1 and not args.prepend_run: print("%i ptest sections found. '--prepend-run' is required" % ptest_count) return 1 for _, run_name, _, r in resultutils.test_run_results(results): if args.dump_ptest: for sectname in ['ptestresult.sections', 'ltpposixresult.sections', 'ltpresult.sections']: if sectname in r: for name, ptest in r[sectname].items(): logdata = resultutils.generic_get_log(sectname, r, name) if logdata is not None: dest_dir = args.dump_ptest if args.prepend_run: dest_dir = os.path.join(dest_dir, run_name) if not sectname.startswith("ptest"): dest_dir = os.path.join(dest_dir, sectname.split(".")[0]) os.makedirs(dest_dir, exist_ok=True) dest = os.path.join(dest_dir, '%s.log' % name) print(dest) with open(dest, 'w') as f: f.write(logdata) if args.raw_ptest: found = False for sectname in ['ptestresult.rawlogs', 'ltpposixresult.rawlogs', 'ltpresult.rawlogs']: rawlog = resultutils.generic_get_rawlogs(sectname, r) if rawlog is not None: print(rawlog) found = True if not found: print('Raw ptest logs not found') return 1 if args.raw_reproducible: if 'reproducible.rawlogs' in r: print(r['reproducible.rawlogs']['log']) else: print('Raw reproducible logs not found') return 1 for ptest in args.ptest: if not show_ptest(r, ptest, logger): return 1 for reproducible in args.reproducible: if not show_reproducible(r, reproducible, logger): return 1 def register_commands(subparsers): """Register subcommands from this plugin""" parser = subparsers.add_parser('log', help='show logs', description='show the logs from test results', group='analysis') parser.set_defaults(func=log) parser.add_argument('source', help='the results file/directory/URL to import') parser.add_argument('--ptest', action='append', default=[], help='show logs for a ptest') parser.add_argument('--dump-ptest', metavar='DIR', help='Dump all ptest log files to the specified directory.') parser.add_argument('--reproducible', action='append', default=[], help='show logs for a reproducible test') parser.add_argument('--prepend-run', action='store_true', help='''Dump ptest results to a subdirectory named after the test run when using --dump-ptest. Required if more than one test run is present in the result file''') parser.add_argument('--raw', action='store_true', help='show raw (ptest) logs. Deprecated. Alias for "--raw-ptest"', dest='raw_ptest') parser.add_argument('--raw-ptest', action='store_true', help='show raw ptest log') parser.add_argument('--raw-reproducible', action='store_true', help='show raw reproducible build logs')