mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-19 21:09:03 +02:00

Adds an option to dump all the ptest logs to individual files in a specified directory. If multiple test runs are present, the '--prepend-run' argument will create separate directories for each test run under the target directory and put the logs there to prevent each test run from clobbering the others. [YOCTO #13331] (From OE-Core rev: f262b9e7482e38f04dfa162f0aaf65b17e86f8b2) Signed-off-by: Joshua Watt <JPEWhacker@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
79 lines
3.2 KiB
Python
79 lines
3.2 KiB
Python
# resulttool - Show logs
|
|
#
|
|
# Copyright (c) 2019 Garmin International
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify it
|
|
# under the terms and conditions of the GNU General Public License,
|
|
# version 2, as published by the Free Software Foundation.
|
|
#
|
|
# This program is distributed in the hope it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
# more details.
|
|
#
|
|
import os
|
|
import resulttool.resultutils as resultutils
|
|
|
|
def show_ptest(result, ptest, logger):
|
|
if 'ptestresult.sections' in result:
|
|
if ptest in result['ptestresult.sections'] and 'log' in result['ptestresult.sections'][ptest]:
|
|
print(result['ptestresult.sections'][ptest]['log'])
|
|
return 0
|
|
|
|
print("ptest '%s' not found" % ptest)
|
|
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:
|
|
if 'ptestresult.sections' in r:
|
|
for name, ptest in r['ptestresult.sections'].items():
|
|
if 'log' in ptest:
|
|
dest_dir = args.dump_ptest
|
|
if args.prepend_run:
|
|
dest_dir = os.path.join(dest_dir, run_name)
|
|
|
|
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(ptest['log'])
|
|
|
|
if args.raw:
|
|
if 'ptestresult.rawlogs' in r:
|
|
print(r['ptestresult.rawlogs']['log'])
|
|
else:
|
|
print('Raw logs not found')
|
|
return 1
|
|
|
|
for ptest in args.ptest:
|
|
if not show_ptest(r, ptest, 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('--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 logs')
|
|
|