X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=tests%2Fcoverage_dungeon.py;h=365995ce644598d9178f8cd976e8a19b50a052c9;hb=eb49f4d0d2f211117ea4da472ccfabb71b9f8689;hp=0a24865c7abbe7e41a7b66a42d4d863e7169d232;hpb=e8a627f964a8337caf0c71dd87b1d7533f489f57;p=open-adventure.git diff --git a/tests/coverage_dungeon.py b/tests/coverage_dungeon.py index 0a24865..365995c 100755 --- a/tests/coverage_dungeon.py +++ b/tests/coverage_dungeon.py @@ -6,6 +6,10 @@ # # The default HTML output is appropriate for use with Gitlab CI. # You can override it with a command-line argument. +# +# The DANGLING list is for actions that should be considered always found +# even if the checkfile search doesn't find them. Typically this will because +# they emit a templated message that can't be regression-tested by equality. import os import sys @@ -14,8 +18,9 @@ import re TEST_DIR = "." YAML_PATH = "../adventure.yaml" -HTML_TEMPLATE_PATH = "coverage_dungeon.html.tpl" +HTML_TEMPLATE_PATH = "../templates/coverage_dungeon.html.tpl" DEFAULT_HTML_OUTPUT_PATH = "../coverage/adventure.yaml.html" +DANGLING = ["ACT_VERSION"] STDOUT_REPORT_CATEGORY = " {name:.<19}: {percent:5.1f}% covered ({covered} of {total})\n" @@ -158,7 +163,7 @@ def actions_coverage(items, text, report): if name not in report["messages"]: report["messages"][name] = {"covered" : False} report["total"] += 1 - if report["messages"][name]["covered"] != True and search(item["message"], text): + if report["messages"][name]["covered"] != True and (search(item["message"], text) or name in DANGLING): report["messages"][name]["covered"] = True report["covered"] += 1 @@ -175,7 +180,7 @@ def coverage_report(db, check_file_contents): "messages" : {} } - # search for each message in ever test check file + # search for each message in every test check file for chk in check_file_contents: arb_coverage(db["arbitrary_messages"], chk, report["arbitrary_messages"]) hint_coverage(db["hints"], chk, report["hints"])