resulttool: Add --logfile-archive option to store mode

Storing the log files inside the testresults git repo isn't scaling and isn't
really appropriate use of a git repository. Allow these to be optionally stored
in a separate filesystem location so the git repo can remain managable.

(From OE-Core rev: 1afc0f3d7e93fa8496be241e9622d3b9a6904bd5)

Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
Richard Purdie 2024-11-22 16:11:43 +00:00
parent e948ab9035
commit 589bd28e46

View File

@ -74,12 +74,25 @@ def store(args, logger):
logger.info('Storing test result into git repository %s' % args.git_dir)
gitarchive.gitarchive(tempdir, args.git_dir, False, False,
excludes = []
if args.logfile_archive:
excludes = ['*.log', "*.log.zst"]
tagname = gitarchive.gitarchive(tempdir, args.git_dir, False, False,
"Results of {branch}:{commit}", "branch: {branch}\ncommit: {commit}", "{branch}",
False, "{branch}/{commit_count}-g{commit}/{tag_number}",
'Test run #{tag_number} of {branch}:{commit}', '',
[], [], False, keywords, logger)
excludes, [], False, keywords, logger)
if args.logfile_archive:
logdir = args.logfile_archive + "/" + tagname
shutil.copytree(tempdir, logdir)
for root, dirs, files in os.walk(logdir):
for name in files:
if not name.endswith(".log"):
continue
f = os.path.join(root, name)
subprocess.run(["zstd", f, "--rm"], check=True, capture_output=True)
finally:
subprocess.check_call(["rm", "-rf", tempdir])
@ -107,3 +120,5 @@ def register_commands(subparsers):
help='add extra test environment data to each result file configuration')
parser_build.add_argument('-r', '--revision', default='',
help='only store data for the specified revision')
parser_build.add_argument('-l', '--logfile-archive', default='',
help='directory to separately archive log files along with a copy of the results')