From befb472b1b9650d485f46ae54227caea8bf81cdd Mon Sep 17 00:00:00 2001 From: Klaus Aehlig Date: Wed, 10 Jul 2024 17:25:23 +0200 Subject: Tests: also record `pwd` ... as test meta data. Tests are executed in an unspecified directory, assuming pass or fail is independent of the location where the test is run. While this generally is true, test logs often contain the working directory. So, in order to more easily compare different execution orders of a potential race condition, it can be desirable to compare logs "up to the execution directory". This, however, requires that this directory is recored in the first place. Do so. For consistency of the output format, also have a (fixed) artifact pwd in the summary report. --- CC/test/EXPRESSIONS | 14 ++++++++++++-- CC/test/RULES | 1 + CC/test/runner | 2 ++ 3 files changed, 15 insertions(+), 2 deletions(-) (limited to 'CC/test') diff --git a/CC/test/EXPRESSIONS b/CC/test/EXPRESSIONS index b0a7f2b..1646dd7 100644 --- a/CC/test/EXPRESSIONS +++ b/CC/test/EXPRESSIONS @@ -165,7 +165,13 @@ [ [ "test-results" , { "type": "ACTION" , "outs": - ["result", "stdout", "stderr", "time-start", "time-stop"] + [ "result" + , "stdout" + , "stderr" + , "time-start" + , "time-stop" + , "pwd" + ] , "inputs": {"type": "var", "name": "test input"} , "cmd": ["./runner"] , "env": @@ -291,7 +297,11 @@ , [ "artifacts" , { "type": "map_union" , "$1": - [ {"type": "var", "name": "summary"} + [ { "type": "singleton_map" + , "key": "pwd" + , "value": {"type": "BLOB", "data": "/summary"} + } + , {"type": "var", "name": "summary"} , { "type": "singleton_map" , "key": "work" , "value": diff --git a/CC/test/RULES b/CC/test/RULES index 7444551..e23359e 100644 --- a/CC/test/RULES +++ b/CC/test/RULES @@ -143,6 +143,7 @@ , " the respective file descriptor" , "time-start/time-stop: The time (decimally coded) in seconds since the" , " epoch when the test invocation started and ended." + , "pwd: the directory in which the test was carried out" ] , "runfiles_doc": [ "A tree consisting of the artifacts staged at the name of the test." diff --git a/CC/test/runner b/CC/test/runner index 45a1bee..4984b17 100755 --- a/CC/test/runner +++ b/CC/test/runner @@ -36,6 +36,8 @@ def dump_results() -> None: f.write("%s\n" % (stdout, )) with open("stderr", "w") as f: f.write("%s\n" % (stderr, )) + with open("pwd", "w") as f: + f.write("%s\n" % (os.getcwd(), )) dump_results() -- cgit v1.2.3