Skip to content

Commit d1f73c2

Browse files
authored
Merge pull request #827 from Altinity/customizations/24.8.14
24.8.14 Pre-release PR
2 parents 0563cd9 + 2558dfa commit d1f73c2

File tree

69 files changed

+2405
-476
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

69 files changed

+2405
-476
lines changed
Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
name: Create and Upload Combined Report
2+
description: Create and upload a combined CI report
3+
inputs:
4+
final:
5+
description: "Control whether the report is final or a preview"
6+
required: false
7+
default: "false"
8+
runs:
9+
using: "composite"
10+
steps:
11+
- name: Create and upload workflow report
12+
env:
13+
PR_NUMBER: ${{ github.event.pull_request.number || 0 }}
14+
COMMIT_SHA: ${{ github.event_name == 'pull_request' && github.event.pull_request.head.sha || github.sha }}
15+
ACTIONS_RUN_URL: ${{ github.event.repository.html_url }}/actions/runs/${{ github.run_id }}
16+
FINAL: ${{ inputs.final }}
17+
shell: bash
18+
run: |
19+
pip install clickhouse-driver==0.2.8 numpy==1.26.4 pandas==2.0.3 jinja2==3.1.5
20+
21+
CMD="python3 .github/actions/create_workflow_report/create_workflow_report.py"
22+
ARGS="--pr-number $PR_NUMBER --commit-sha $COMMIT_SHA --actions-run-url $ACTIONS_RUN_URL --known-fails tests/broken_tests.json --cves"
23+
24+
set +e
25+
if [[ "$FINAL" == "false" ]]; then
26+
REPORT_LINK=$($CMD $ARGS --mark-preview)
27+
else
28+
REPORT_LINK=$($CMD $ARGS)
29+
fi
30+
31+
echo $REPORT_LINK
32+
33+
if [[ "$FINAL" == "true" ]]; then
34+
IS_VALID_URL=$(echo $REPORT_LINK | grep -E '^https?://')
35+
if [[ -n $IS_VALID_URL ]]; then
36+
echo "Workflow Run Report: [View Report]($REPORT_LINK)" >> $GITHUB_STEP_SUMMARY
37+
else
38+
echo "Error: $REPORT_LINK" >> $GITHUB_STEP_SUMMARY
39+
exit 1
40+
fi
41+
fi
Lines changed: 269 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,269 @@
1+
<!DOCTYPE html>
2+
<html lang="en" data-lt-installed="true">
3+
4+
<head>
5+
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
6+
<meta charset="UTF-8">
7+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
8+
<style>
9+
/* Base colors for Altinity */
10+
:root {
11+
--altinity-background: #000D45;
12+
--altinity-accent: #189DCF;
13+
--altinity-highlight: #FFC600;
14+
--altinity-gray: #6c757d;
15+
--altinity-light-gray: #f8f9fa;
16+
--altinity-white: #ffffff;
17+
}
18+
19+
/* Body and heading fonts */
20+
body {
21+
font-family: Arimo, "Proxima Nova", "Helvetica Neue", Helvetica, Arial, sans-serif;
22+
font-size: 1rem;
23+
background-color: var(--altinity-background);
24+
color: var(--altinity-light-gray);
25+
padding: 2rem;
26+
}
27+
28+
h1,
29+
h2,
30+
h3,
31+
h4,
32+
h5,
33+
h6 {
34+
font-family: Figtree, "Proxima Nova", "Helvetica Neue", Helvetica, Arial, sans-serif;
35+
color: var(--altinity-white);
36+
}
37+
38+
.logo {
39+
width: auto;
40+
height: 5em;
41+
}
42+
43+
/* General table styling */
44+
table {
45+
min-width: min(900px, 98vw);
46+
margin: 1rem 0;
47+
border-collapse: collapse;
48+
background-color: var(--altinity-white);
49+
border: 1px solid var(--altinity-accent);
50+
box-shadow: 0 0 8px rgba(0, 0, 0, 0.05);
51+
color: var(--altinity-background);
52+
}
53+
54+
/* Table header styling */
55+
th {
56+
background-color: var(--altinity-accent);
57+
color: var(--altinity-white);
58+
padding: 10px 16px;
59+
text-align: left;
60+
border: none;
61+
border-bottom: 2px solid var(--altinity-background);
62+
white-space: nowrap;
63+
}
64+
65+
th.hth {
66+
border-bottom: 1px solid var(--altinity-accent);
67+
border-right: 2px solid var(--altinity-background);
68+
}
69+
70+
/* Table header sorting styling */
71+
th {
72+
cursor: pointer;
73+
}
74+
75+
th.no-sort {
76+
pointer-events: none;
77+
}
78+
79+
th::after,
80+
th::before {
81+
transition: color 0.2s ease-in-out;
82+
font-size: 1.2em;
83+
color: transparent;
84+
}
85+
86+
th::after {
87+
margin-left: 3px;
88+
content: '\025B8';
89+
}
90+
91+
th:hover::after {
92+
color: inherit;
93+
}
94+
95+
th.dir-d::after {
96+
color: inherit;
97+
content: '\025BE';
98+
}
99+
100+
th.dir-u::after {
101+
color: inherit;
102+
content: '\025B4';
103+
}
104+
105+
/* Table body row styling */
106+
tr:hover {
107+
background-color: var(--altinity-light-gray);
108+
}
109+
110+
/* Table cell styling */
111+
td {
112+
padding: 8px 8px;
113+
border: 1px solid var(--altinity-accent);
114+
}
115+
116+
/* Link styling */
117+
a {
118+
color: var(--altinity-accent);
119+
text-decoration: none;
120+
}
121+
122+
a:hover {
123+
color: var(--altinity-highlight);
124+
text-decoration: underline;
125+
}
126+
</style>
127+
<title>{{ title }}</title>
128+
<link rel="icon" type="image/svg+xml"
129+
href=''
130+
/>
131+
</head>
132+
133+
<body>
134+
<p><img class="logo"
135+
src=""
136+
alt="logo"></p>
137+
138+
<h1>{{ title }}</h1>
139+
<table>
140+
<tbody>
141+
<tr>
142+
<th class="hth no-sort">Pull Request</th>
143+
<td>{{ pr_info_html }}</td>
144+
</tr>
145+
<tr>
146+
<th class="hth no-sort">Workflow Run</th>
147+
<td><a href="https://github.com/{{ github_repo }}/actions/runs/{{ workflow_id }}">{{ workflow_id }}</a></td>
148+
</tr>
149+
<tr>
150+
<th class="hth no-sort">Commit</th>
151+
<td><a href="https://github.com/{{ github_repo }}/commit/{{ commit_sha }}">{{ commit_sha }}</a></td>
152+
</tr>
153+
<tr>
154+
<th class="hth no-sort">Build Report</th>
155+
<td><a href="https://s3.amazonaws.com/{{ s3_bucket }}/{{ pr_number }}/{{ commit_sha }}/builds/report.html">Build Report</a></td>
156+
</tr>
157+
<tr>
158+
<th class="hth no-sort">Date</th>
159+
<td> {{ date }}</td>
160+
</tr>
161+
</tbody>
162+
</table>
163+
{% if is_preview %}
164+
<p style="font-weight: bold;color: red;">This is a preview. The workflow is not yet finished.</p>
165+
{% endif %}
166+
<h2>Table of Contents</h2>
167+
<ul>
168+
{%- if pr_number != 0 %}<li><a href="#new-fails-pr">New Fails in PR</a> ({{ counts.pr_new_fails }})</li>{% endif %}
169+
<li><a href="#ci-jobs-status">CI Jobs Status</a> ({{ counts.jobs_status }})</li>
170+
<li><a href="#checks-errors">Checks Errors</a> ({{ counts.checks_errors }})</li>
171+
<li><a href="#checks-fails">Checks New Fails</a> ({{ counts.checks_new_fails }})</li>
172+
<li><a href="#regression-fails">Regression New Fails</a> ({{ counts.regression_new_fails }})</li>
173+
<li><a href="#docker-images-cves">Docker Images CVEs</a> ({{ counts.cves }})</li>
174+
<li><a href="#checks-known-fails">Checks Known Fails</a> ({{ counts.checks_known_fails }})</li>
175+
</ul>
176+
177+
{%- if pr_number != 0 -%}
178+
<h2 id="new-fails-pr">New Fails in PR</h2>
179+
<p> Compared with base sha {{ base_sha }} </p>
180+
{{ new_fails_html }}
181+
{%- endif %}
182+
183+
<h2 id="ci-jobs-status">CI Jobs Status</h2>
184+
{{ ci_jobs_status_html }}
185+
186+
<h2 id="checks-errors">Checks Errors</h2>
187+
{{ checks_errors_html }}
188+
189+
<h2 id="checks-fails">Checks New Fails</h2>
190+
{{ checks_fails_html }}
191+
192+
<h2 id="regression-fails">Regression New Fails</h2>
193+
{{ regression_fails_html }}
194+
195+
<h2 id="docker-images-cves">Docker Images CVEs</h2>
196+
{{ docker_images_cves_html }}
197+
198+
<h2 id="checks-known-fails">Checks Known Fails</h2>
199+
<p>
200+
Fail reason conventions:<br/>
201+
KNOWN - Accepted fail and fix is not planned<br/>
202+
INVESTIGATE - We don't know why it fails<br/>
203+
NEEDSFIX - Investigation done and a fix is needed to make it pass<br/>
204+
</p>
205+
{{ checks_known_fails_html }}
206+
207+
<script>
208+
document.addEventListener('click', function (e) {
209+
try {
210+
function findElementRecursive(element, tag) {
211+
return element.nodeName === tag ? element :
212+
findElementRecursive(element.parentNode, tag)
213+
}
214+
var descending_th_class = ' dir-d '
215+
var ascending_th_class = ' dir-u '
216+
var ascending_table_sort_class = 'asc'
217+
var regex_dir = / dir-(u|d) /
218+
var alt_sort = e.shiftKey || e.altKey
219+
var element = findElementRecursive(e.target, 'TH')
220+
var tr = findElementRecursive(element, 'TR')
221+
var table = findElementRecursive(tr, 'TABLE')
222+
function reClassify(element, dir) {
223+
element.className = element.className.replace(regex_dir, '') + dir
224+
}
225+
function getValue(element) {
226+
return (
227+
(alt_sort && element.getAttribute('data-sort-alt')) ||
228+
element.getAttribute('data-sort') || element.innerText
229+
)
230+
}
231+
if (true) {
232+
var column_index
233+
var nodes = tr.cells
234+
for (var i = 0; i < nodes.length; i++) {
235+
if (nodes[i] === element) {
236+
column_index = element.getAttribute('data-sort-col') || i
237+
} else {
238+
reClassify(nodes[i], '')
239+
}
240+
}
241+
var dir = descending_th_class
242+
if (
243+
element.className.indexOf(descending_th_class) !== -1 ||
244+
(table.className.indexOf(ascending_table_sort_class) !== -1 &&
245+
element.className.indexOf(ascending_th_class) == -1)
246+
) {
247+
dir = ascending_th_class
248+
}
249+
reClassify(element, dir)
250+
var org_tbody = table.tBodies[0]
251+
var rows = [].slice.call(org_tbody.rows, 0)
252+
var reverse = dir === ascending_th_class
253+
rows.sort(function (a, b) {
254+
var x = getValue((reverse ? a : b).cells[column_index])
255+
var y = getValue((reverse ? b : a).cells[column_index])
256+
return isNaN(x - y) ? x.localeCompare(y) : x - y
257+
})
258+
var clone_tbody = org_tbody.cloneNode()
259+
while (rows.length) {
260+
clone_tbody.appendChild(rows.splice(0, 1)[0])
261+
}
262+
table.replaceChild(clone_tbody, org_tbody)
263+
}
264+
} catch (error) {
265+
}
266+
});
267+
</script>
268+
</body>
269+
</html>

0 commit comments

Comments
 (0)