summary refs log tree commit diff
path: root/.buildkite/format_tap.py
diff options
context:
space:
mode:
authorAmber Brown <hawkowl@atleastfornow.net>2019-06-17 21:08:15 +1000
committerGitHub <noreply@github.com>2019-06-17 21:08:15 +1000
commit97d7e4c7b75999b991f53f8a7ee6b25d15442e92 (patch)
treea64eb3f978df3463832fb180408cd8f65bc007da /.buildkite/format_tap.py
parentMerge pull request #5464 from matrix-org/erikj/3pid_remote_invite_state (diff)
downloadsynapse-97d7e4c7b75999b991f53f8a7ee6b25d15442e92.tar.xz
Move SyTest to Buildkite (#5459)
Including workers!
Diffstat (limited to '.buildkite/format_tap.py')
-rw-r--r--.buildkite/format_tap.py33
1 files changed, 33 insertions, 0 deletions
diff --git a/.buildkite/format_tap.py b/.buildkite/format_tap.py
new file mode 100644
index 0000000000..94582f5571
--- /dev/null
+++ b/.buildkite/format_tap.py
@@ -0,0 +1,33 @@
+import sys
+from tap.parser import Parser
+from tap.line import Result, Unknown, Diagnostic
+
+out = ["### TAP Output for " + sys.argv[2]]
+
+p = Parser()
+
+in_error = False
+
+for line in p.parse_file(sys.argv[1]):
+    if isinstance(line, Result):
+        if in_error:
+            out.append("")
+            out.append("</pre></code></details>")
+            out.append("")
+            out.append("----")
+            out.append("")
+        in_error = False
+
+        if not line.ok and not line.todo:
+            in_error = True
+
+            out.append("FAILURE Test #%d: ``%s``" % (line.number, line.description))
+            out.append("")
+            out.append("<details><summary>Show log</summary><code><pre>")
+
+    elif isinstance(line, Diagnostic) and in_error:
+        out.append(line.text)
+
+if out:
+    for line in out[:-3]:
+        print(line)