# 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')
|