aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKirill Rysin <35688753+naspirato@users.noreply.github.com>2025-02-10 17:55:44 +0100
committerGitHub <noreply@github.com>2025-02-10 19:55:44 +0300
commitad3a69baf9c00f3dc48aa33bf820439c0663e7ff (patch)
treeb4b2e9da407eaf92128fd523c95e35c9c85503f3
parentca50229766bcc6c49b20ddc076939d18b9dbfb07 (diff)
downloadydb-ad3a69baf9c00f3dc48aa33bf820439c0663e7ff.tar.gz
Test report (#14336)
-rwxr-xr-x.github/scripts/tests/generate-summary.py13
-rw-r--r--.github/scripts/tests/templates/summary.html88
2 files changed, 91 insertions, 10 deletions
diff --git a/.github/scripts/tests/generate-summary.py b/.github/scripts/tests/generate-summary.py
index 552c30d54f..5fd6f20588 100755
--- a/.github/scripts/tests/generate-summary.py
+++ b/.github/scripts/tests/generate-summary.py
@@ -37,6 +37,7 @@ class TestResult:
elapsed: float
count_of_passed: int
owners: str
+ status_description: str
@property
def status_display(self):
@@ -67,15 +68,23 @@ class TestResult:
@classmethod
def from_junit(cls, testcase):
classname, name = testcase.get("classname"), testcase.get("name")
-
+ status_description = None
if testcase.find("failure") is not None:
status = TestStatus.FAIL
+ if testcase.find("failure").text is not None:
+ status_description = testcase.find("failure").text
elif testcase.find("error") is not None:
status = TestStatus.ERROR
+ if testcase.find("error").text is not None:
+ status_description = testcase.find("error").text
elif get_property_value(testcase, "mute") is not None:
status = TestStatus.MUTE
+ if testcase.find("skipped").text is not None:
+ status_description = testcase.find("skipped").text
elif testcase.find("skipped") is not None:
status = TestStatus.SKIP
+ if testcase.find("skipped").text is not None:
+ status_description = testcase.find("skipped").text
else:
status = TestStatus.PASS
@@ -96,7 +105,7 @@ class TestResult:
elapsed = 0
print(f"Unable to cast elapsed time for {classname}::{name} value={elapsed!r}")
- return cls(classname, name, status, log_urls, elapsed, 0,'')
+ return cls(classname, name, status, log_urls, elapsed, 0, '', status_description)
class TestSummaryLine:
diff --git a/.github/scripts/tests/templates/summary.html b/.github/scripts/tests/templates/summary.html
index 16b7721287..a595d1b7e2 100644
--- a/.github/scripts/tests/templates/summary.html
+++ b/.github/scripts/tests/templates/summary.html
@@ -1,5 +1,10 @@
<html>
<head>
+ <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism-themes/1.9.0/prism-vs.min.css">
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js"></script>
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/components/prism-python.min.js"></script>
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/components/prism-c.min.js"></script>
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/components/prism-cpp.min.js"></script>
<style>
body {
font-family: -apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";
@@ -92,7 +97,7 @@
.button svg {
fill: #4b535c;
fill-rule: evenodd;
- }
+ }
.button svg:hover {
fill: #0366d6;
@@ -119,12 +124,13 @@
.button-group > button svg {
fill: #4b535c;
fill-rule: evenodd;
- }
+ }
.button-group > button svg:hover {
fill: #0366d6;
fill-rule: evenodd;
}
+
.button-group .icon-container .show_history_svg {
fill: #ffffff;
stroke: #000;
@@ -232,7 +238,6 @@
visibility: visible;
opacity: 1;
}
-
table > tbody > tr > td:nth-child(2),
table > tbody > tr > td:nth-child(3),
@@ -255,7 +260,7 @@
left: 5;
height: auto;
}
-
+
.collapsible-header {
cursor: pointer;
background-color: #f2f2f2;
@@ -263,14 +268,60 @@
border: 1px solid #ddd;
margin-bottom: 5px;
}
-
-
+
.toggle-visibility-buttons {
margin-bottom: 10px;
overflow:hidden;
float: right;
}
- </style>
+
+ .error-button {
+ border: none;
+ cursor: pointer;
+ background: url("") no-repeat 50% 50% / 1em 1em;
+ width: 1em;
+ height: 1em;
+ content: "";
+ transition: transform .5s;
+ }
+
+ pre>code[class*=language-] {
+ font-size: x-small;
+ }
+
+ .console-frame {
+ font-size: x-small;
+ display: grid;
+ border-radius: 4px;
+ overscroll-behavior: none;
+ background: #ddd;
+ padding: 5px;
+ color: #f1f2f3;
+ overflow-y: auto;
+ font-family: monospace;
+ word-break: keep-all;
+ font-size: x-small;
+ }
+
+ .console-frame::-webkit-scrollbar {
+ width: 10px;
+ }
+
+ .console-frame::-webkit-scrollbar-track {
+ background: #c5c6c8;
+ }
+
+ .console-frame::-webkit-scrollbar-thumb {
+ background: #838485;
+ border-radius: 4px;
+ }
+ pre[class*=language-] {
+ padding: 1em;
+ margin: 0;
+ overflow: auto;
+ }
+
+</style>
<script>
function findParentBySelector(elm, selector) {
var all = document.querySelectorAll(selector);
@@ -538,6 +589,19 @@
toggleAllTables('collapse');
});
});
+ function toggleError(button) {
+ const errorContent = button.nextElementSibling;
+ const consoleFrame = errorContent.querySelector('.console-frame');
+ if (errorContent.style.display === 'none') {
+ errorContent.style.display = 'block';
+ consoleFrame.style.display = 'block';
+ button.style.transform = "rotate(90deg)"
+ } else {
+ errorContent.style.display = 'none';
+ consoleFrame.style.display = 'none';
+ button.style.transform = "rotate(0deg)"
+ }
+ }
</script>
</head>
<body>
@@ -576,7 +640,7 @@
<td class="test_name">
{% endif %}
<span>{{ t.full_name }}</span>
- {% if status.is_error %}
+ {% if status.is_error %}
<div class="button-group">
<button class="button" title="Show options">
<svg class="more" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="14" height="14" stroke="none" aria-hidden="true" viewBox="0 0 448 512">
@@ -645,6 +709,14 @@
<span class="button-text">Open test history</span>
</button>
+ </div>
+ </div>
+ {% endif %}
+ {% if t.status_description %}
+ <button class="error-button" onclick="toggleError(this)"></button>
+ <div style="display: none;" class="error-content">
+ <div class="console-frame" style="display: none;">
+ <pre><code class="language-{{ 'python' if '.py' in t.full_name else 'cpp'}}">{{ t.status_description | default("Status description missed") }}</code></pre>
</div>
</div>
{% endif %}