From 57f4b555e1dbb5bb11adacd64d02527de79979a0 Mon Sep 17 00:00:00 2001 From: Bernhard Kaindl Date: Thu, 11 Jan 2024 12:00:00 +0100 Subject: [PATCH] CI/utils.py: Better diagnostic output when tests fail Improve the developer experience when files do no show up in the bugball output archive and the associated test fails. Signed-off-by: Bernhard Kaindl --- tests/integration/utils.py | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/tests/integration/utils.py b/tests/integration/utils.py index 88c44fa4..4d3cb8b8 100644 --- a/tests/integration/utils.py +++ b/tests/integration/utils.py @@ -51,19 +51,23 @@ def check_file(path): def assert_content_from_dom0_template(path, control_path=None): - """Compare the contents of output directories or files with the test's Dom0 template directories""" - assert path[0] != "/" + """Check the given path against the files from the test's Dom0 template""" + + assert path[0] != "/" # We expect a relative path in the report archive control = BUGTOOL_DOM0_TEMPL + (control_path or path) print(control) if os.path.isdir(path): + # path is a directory, compare it recursively using dircmp(): result = filecmp.dircmp(path, control) if result.diff_files or result.right_only: # pragma: no cover print(result.report) raise RuntimeError("Missing or Differing files found in " + path) else: + if not os.path.exists(path): + raise AssertionError("/%s is missing in the report archive" % path) if not filecmp.cmp(path, control): - os.system("cat " + path) # pragma: no cover - raise RuntimeError(control) + os.system("diff -u %s %s" % (path, control)) # pragma: no cover + raise AssertionError("/%s from report has different content" % path) # Remove verified output files/directories. Untested files will remain and cause the testcase to FAIL: try: os.unlink(path)