1010permissions :
1111 contents : read
1212
13+ env :
14+ # TESTS_BRANCH: "master" # Branch that will be checked out to run the tests
15+ TESTS_BRANCH : " ci/hw_gitlab"
16+
1317jobs :
1418 get-artifacts :
1519 name : Get required artifacts
2226 ref : ${{ steps.set-ref.outputs.ref }}
2327 base : ${{ steps.set-ref.outputs.base }}
2428 targets : ${{ steps.set-ref.outputs.targets }}
25- types : ${{ steps.set-ref.outputs.types }}
29+ wokwi_types : ${{ steps.set-ref.outputs.wokwi_types }}
30+ hw_types : ${{ steps.set-ref.outputs.hw_types }}
2631 hw_tests_enabled : ${{ steps.set-ref.outputs.hw_tests_enabled }}
2732 push_time : ${{ steps.set-ref.outputs.push_time }}
2833 steps :
6267 name : matrix_info
6368 path : artifacts/matrix_info
6469
65- - name : Try to read PR number
70+ - name : Get info
6671 id : set-ref
6772 run : |
6873 pr_num=$(jq -r '.pull_request.number' artifacts/event_file/event.json | tr -cd "[:digit:]")
@@ -102,12 +107,14 @@ jobs:
102107 push_time=""
103108 fi
104109
105- types=$(cat artifacts/matrix_info/wokwi_types.txt | tr -cd "[:alpha:],[]'")
110+ wokwi_types=$(cat artifacts/matrix_info/wokwi_types.txt | tr -cd "[:alpha:],[]'")
111+ hw_types=$(cat artifacts/matrix_info/hw_types.txt | tr -cd "[:alpha:],[]'")
106112 targets=$(cat artifacts/matrix_info/targets.txt | tr -cd "[:alnum:],[]'")
107113
108114 echo "base = $base"
109115 echo "targets = $targets"
110- echo "types = $types"
116+ echo "wokwi_types = $wokwi_types"
117+ echo "hw_types = $hw_types"
111118 echo "pr_num = $pr_num"
112119 echo "hw_tests_enabled = $hw_tests_enabled"
113120 echo "push_time = $push_time"
@@ -145,7 +152,8 @@ jobs:
145152 echo "pr_num=$pr_num" >> $GITHUB_OUTPUT
146153 echo "base=$base" >> $GITHUB_OUTPUT
147154 echo "targets=$targets" >> $GITHUB_OUTPUT
148- echo "types=$types" >> $GITHUB_OUTPUT
155+ echo "wokwi_types=$wokwi_types" >> $GITHUB_OUTPUT
156+ echo "hw_types=$hw_types" >> $GITHUB_OUTPUT
149157 echo "ref=$ref" >> $GITHUB_OUTPUT
150158 echo "hw_tests_enabled=$hw_tests_enabled" >> $GITHUB_OUTPUT
151159 echo "push_time=$push_time" >> $GITHUB_OUTPUT
@@ -189,7 +197,7 @@ jobs:
189197 core.info(`${name} is ${state}`);
190198
191199 hardware-test :
192- name : Hardware ${{ matrix.chip }} ${{ matrix.type }} tests
200+ name : Internal Hardware Tests
193201 if : |
194202 (github.event.workflow_run.conclusion == 'success' ||
195203 github.event.workflow_run.conclusion == 'failure' ||
@@ -198,15 +206,10 @@ jobs:
198206 runs-on : ubuntu-latest
199207 needs : get-artifacts
200208 env :
201- id : ${{ needs.get-artifacts.outputs.ref }}-${{ github.event.workflow_run.head_sha || github.sha }}-${{ matrix.chip }}-${{ matrix.type }}
209+ id : ${{ needs.get-artifacts.outputs.ref }}-${{ github.event.workflow_run.head_sha || github.sha }}
202210 permissions :
203211 actions : read
204212 statuses : write
205- strategy :
206- fail-fast : false
207- matrix :
208- type : ${{ fromJson(needs.get-artifacts.outputs.types) }}
209- chip : ${{ fromJson(needs.get-artifacts.outputs.targets) }}
210213 steps :
211214 - name : Report pending
212215 uses : actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1
@@ -219,7 +222,7 @@ jobs:
219222 core.debug(`repo: ${repo}`);
220223 core.debug(`sha: ${sha}`);
221224 const { context: name, state } = (await github.rest.repos.createCommitStatus({
222- context: 'Runtime Tests / Hardware (${{ matrix.type }}, ${{ matrix.chip }}) / Hardware ${{ matrix.chip }} ${{ matrix.type }} tests (${{ github.event.workflow_run.event }} -> workflow_run)',
225+ context: 'Runtime Tests / Internal Hardware Tests (${{ github.event.workflow_run.event }} -> workflow_run)',
223226 owner: owner,
224227 repo: repo,
225228 sha: sha,
@@ -258,8 +261,7 @@ jobs:
258261 if : ${{ steps.check-tests.outputs.enabled == 'true' }}
259262 run : |
260263 # A webhook to sync the repository is sent to GitLab when a commit is pushed to GitHub
261- # In the worst case, it can take up to 5 minutes for the sync to complete
262- # We wait for 6 minutes after the push to GitHub to be safe
264+ # We wait for 10 minutes after the push to GitHub to be safe
263265
264266 echo "Ensuring GitLab sync has completed before triggering pipeline..."
265267
@@ -278,8 +280,8 @@ jobs:
278280
279281 echo "Elapsed time since push: ${elapsed_minutes} minutes"
280282
281- if [ $elapsed_minutes -lt 6 ]; then
282- wait_time=$(( (6 - elapsed_minutes) * 60 ))
283+ if [ $elapsed_minutes -lt 10 ]; then
284+ wait_time=$(( (10 - elapsed_minutes) * 60 ))
283285 echo "Waiting ${wait_time} seconds for GitLab sync to complete..."
284286 sleep $wait_time
285287 else
@@ -302,30 +304,20 @@ jobs:
302304 with :
303305 ref : ${{ needs.get-artifacts.outputs.base || github.ref }}
304306
305- - name : Get test binaries
306- if : ${{ steps.check-tests.outputs.enabled == 'true' }}
307- uses : actions/download-artifact@95815c38cf2ff2164869cbab79da8d1f422bc89e # v4.2.1
308- with :
309- github-token : ${{ secrets.GITHUB_TOKEN }}
310- run-id : ${{ github.event.workflow_run.id }}
311- name : test-bin-${{ matrix.chip }}-${{ matrix.type }}
312- path : test-binaries
313-
314307 - name : Trigger GitLab Pipeline and Download Artifacts
315308 if : ${{ steps.check-tests.outputs.enabled == 'true' }}
316309 uses :
digital-blueprint/[email protected] 317310 id : gitlab-trigger
318311 with :
319312 host : ${{ secrets.GITLAB_URL }}
320313 id : ${{ secrets.GITLAB_PROJECT_ID }}
321- ref : ' ci/hw_gitlab'
322- # ref: 'master'
314+ ref : ${{ env.TESTS_BRANCH }}
323315 trigger_token : ${{ secrets.GITLAB_TRIGGER_TOKEN }}
324316 access_token : ${{ secrets.GITLAB_ACCESS_TOKEN }}
325317 download_artifacts : ' true'
326318 download_artifacts_on_failure : ' true'
327319 download_path : ' ./gitlab-artifacts'
328- variables : ' {"TEST_TYPE ":"${{ matrix.type }}","TEST_CHIP ":"${{ matrix.chip }}","PIPELINE_ID":"${{ env.id }}","BINARIES_RUN_ID":"${{ github.event.workflow_run.id }}","GITHUB_REPOSITORY":"${{ github.repository }}"}'
320+ variables : ' {"TEST_TYPES ":"${{ needs.get-artifacts.outputs.hw_types }}","TEST_CHIPS ":"${{ needs.get-artifacts.outputs.targets }}","PIPELINE_ID":"${{ env.id }}","BINARIES_RUN_ID":"${{ github.event.workflow_run.id }}","GITHUB_REPOSITORY":"${{ github.repository }}"}'
329321
330322 - name : Process Downloaded Artifacts
331323 if : ${{ always() && steps.check-tests.outputs.enabled == 'true' }}
@@ -356,7 +348,7 @@ jobs:
356348 echo "No artifacts were downloaded from GitLab"
357349 fi
358350
359- - name : Upload ${{ matrix.chip }} ${{ matrix.type }} hardware results as cache
351+ - name : Upload hardware results as cache
360352 uses : actions/cache/save@5a3ec84eff668545956fd18022155c47e93e2684 # v4.2.3
361353 if : steps.check-tests.outputs.enabled == 'true' && needs.get-artifacts.outputs.pr_num
362354 with :
@@ -365,11 +357,11 @@ jobs:
365357 tests/**/*.xml
366358 tests/**/result_*.json
367359
368- - name : Upload ${{ matrix.chip }} ${{ matrix.type }} hardware results as artifacts
360+ - name : Upload hardware results as artifacts
369361 uses : actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
370362 if : always()
371363 with :
372- name : test-results-hw-${{ matrix.chip }}-${{ matrix.type }}
364+ name : test-results-hw
373365 overwrite : true
374366 path : |
375367 tests/**/*.xml
@@ -387,7 +379,7 @@ jobs:
387379 core.debug(`repo: ${repo}`);
388380 core.debug(`sha: ${sha}`);
389381 const { context: name, state } = (await github.rest.repos.createCommitStatus({
390- context: 'Runtime Tests / Hardware (${{ matrix.type }}, ${{ matrix.chip }}) / Hardware ${{ matrix.chip }} ${{ matrix.type }} tests (${{ github.event.workflow_run.event }} -> workflow_run)',
382+ context: 'Runtime Tests / Internal Hardware Tests (${{ github.event.workflow_run.event }} -> workflow_run)',
391383 owner: owner,
392384 repo: repo,
393385 sha: sha,
@@ -412,7 +404,7 @@ jobs:
412404 strategy :
413405 fail-fast : false
414406 matrix :
415- type : ${{ fromJson(needs.get-artifacts.outputs.types ) }}
407+ type : ${{ fromJson(needs.get-artifacts.outputs.wokwi_types ) }}
416408 chip : ${{ fromJson(needs.get-artifacts.outputs.targets) }}
417409 steps :
418410 - name : Report pending
0 commit comments