Now YAML coverage test generates a nice HTML template
[open-adventure.git] / tests / coverage_dungeon.py
index 036271072b30f3bdb10e0968bb90ac11d4b23984..b65094a5089f8d24a071d0290f05bc061e0c6a76 100644 (file)
@@ -7,6 +7,30 @@ import pprint
 
 test_dir = "."
 yaml_name = "../adventure.yaml"
+html_template_path = "coverage_dungeon.html.tpl"
+html_output_path = "../coverage/adventure.yaml.html"
+
+location_row = """
+    <tr>
+        <td class="coverFile">{}</td>
+        <td class="{}">&nbsp;</td>
+        <td class="{}">&nbsp;</td>
+    </tr>
+"""
+
+arb_msg_row = """
+    <tr>
+        <td class="coverFile">{}</td>
+        <td class="{}">&nbsp;</td>
+    </tr>
+"""
+
+object_row = """
+    <tr>
+        <td class="coverFile">{}</td>
+        <td class="{}">&nbsp;</td>
+    </tr>
+"""
 
 def loc_coverage(locations, text):
     for locname, loc in locations:
@@ -47,6 +71,9 @@ if __name__ == "__main__":
     with open(yaml_name, "r") as f:
         db = yaml.load(f)
 
+    with open(html_template_path, "r") as f:
+        html_template = f.read()
+
     locations = db["locations"]
     arb_msgs = db["arbitrary_messages"]
     objects = db["objects"]
@@ -60,20 +87,63 @@ if __name__ == "__main__":
                 arb_coverage(arb_msgs, text)
                 obj_coverage(objects, text)
 
+    print("\nadventure.yaml coverage rate:")
+
+    location_html = ""
+    location_total = len(locations) * 2
+    location_covered = 0
     for locouter in locations:
         locname = locouter[0]
         loc = locouter[1]
+        long_success = "covered"
+        short_success = "covered"
         if loc["description"]["long"] != True:
-            print("%s long description not covered!" % locname)
+            long_success = "uncovered"
+        else:
+            location_covered += 1
+
         if loc["description"]["short"] != True:
-            print("location: %s short description not covered!" % locname)
+            short_success = "uncovered"
+        else:
+            location_covered += 1
 
+        location_html += location_row.format(locname, long_success, short_success)
+    location_percent = round((location_covered / location_total) * 100, 1)
+    print("  locations..........: {}% covered ({} of {})".format(location_percent, location_covered, location_total))
+
+    arb_msg_html = ""
+    arb_total = len(arb_msgs)
+    arb_covered = 0
     for name, msg in arb_msgs:
+        success = "covered"
         if msg != True:
-            print("arbitrary message: %s not covered!" % name)
+            success = "uncovered"
+        else:
+            arb_covered += 1
+        arb_msg_html += arb_msg_row.format(name, success)
+    arb_percent = round((arb_covered / arb_total) * 100, 1)
+    print("  arbitrary_messages.: {}% covered ({} of {})".format(arb_percent, arb_covered, arb_total))
 
+    object_html = ""
+    objects_total = 0
+    objects_covered = 0
     for (obj_name, obj) in objects:
         if obj["descriptions"]:
             for j, desc in enumerate(obj["descriptions"]):
+                objects_total += 1
+                success = "covered"
                 if desc != True:
-                    print("object: %s desctiption #%d not covered!" % (obj_name, j))
+                    success = "uncovered"
+                else:
+                    objects_covered += 1
+                object_html += object_row.format("%s[%d]" % (obj_name, j), success)
+    objects_percent = round((objects_covered / objects_total) * 100, 1)
+    print("  objects............: {}% covered ({} of {})".format(objects_percent, objects_covered, objects_total))
+
+    with open(html_output_path, "w") as f:
+        f.write(html_template.format(
+                location_total, location_covered, location_percent,
+                arb_total, arb_covered, arb_percent,
+                objects_total, objects_covered, objects_percent,
+                location_html, arb_msg_html, object_html
+        ))