Skip to content

Commit b3c0793

Browse files
committed
Test artifact creation
Fix workflow trigger Always run Change name Ignore branches Fix
1 parent 7bb7270 commit b3c0793

File tree

3 files changed

+60
-6
lines changed

3 files changed

+60
-6
lines changed

.github/scripts/on-push.sh

-2
Original file line numberDiff line numberDiff line change
@@ -2,8 +2,6 @@
22

33
set -e
44

5-
export ARDUINO_BUILD_DIR="$HOME/.arduino/build.tmp"
6-
75
function build(){
86
local target=$1
97
local fqbn=$2

.github/workflows/pre-commit.yml

+49-4
Original file line numberDiff line numberDiff line change
@@ -2,15 +2,26 @@ name: Pre-commit check
22

33
on:
44
pull_request:
5-
types: [opened, reopened, synchronize, labeled]
5+
types: [opened, synchronize, reopened, labeled]
6+
7+
concurrency:
8+
group: pre-commit-${{ github.head_ref || github.ref_name }}
9+
cancel-in-progress: true
610

711
jobs:
812
lint:
9-
if: |
10-
contains(github.event.pull_request.labels.*.name, 'Status: Pending Merge')
11-
name: Checking if any fixes are needed
13+
#if: ${{ contains(github.event.pull_request.labels.*.name, 'Status: Pending Merge') }}
14+
name: Run pre-commit hooks
1215
runs-on: ubuntu-latest
1316
steps:
17+
- name: Wait for other jobs to finish
18+
uses: lewagon/[email protected]
19+
with:
20+
ref: ${{ github.sha }}
21+
repo-token: ${{ secrets.GITHUB_TOKEN }}
22+
running-workflow-name: Run pre-commit hooks
23+
check-regexp: Arduino [0-9]+ on ubuntu-latest
24+
1425
- name: Checkout latest commit
1526
uses: actions/checkout@v4
1627
with:
@@ -35,6 +46,40 @@ jobs:
3546
~/.cache/pip
3647
key: pre-commit|${{ env.PY_HASH }}|${{ hashFiles('.pre-commit-config.yaml', '.github/workflows/pre-commit.yml') }}
3748

49+
- name: Get workflow id
50+
run: |
51+
RUNID=$(gh api repos/${{github.event.pull_request.head.repo.full_name}}/commits/${{github.event.pull_request.head.sha}}/check-runs | \
52+
jq -r '.check_runs[] | \
53+
select(.name == "Arduino 0 on ubuntu-latest") | \
54+
.html_url | \
55+
capture("/runs/(?<number>[0-9]+)/jobs") | \
56+
.number' | \
57+
sed 's/"//g' | \
58+
head -n 1)
59+
echo "WORKFLOW_ID = $RUNID"
60+
61+
- name: Download compilation artifacts
62+
uses: actions/download-artifact@v4
63+
if: ${{ env.WORKFLOW_ID != null }}
64+
with:
65+
pattern: build-job-*
66+
merge-multiple: true
67+
path: ~/.arduino/tests/
68+
run-id: ${{ env.WORKFLOW_ID }}
69+
github-token: ${{ secrets.GITHUB_TOKEN }}
70+
71+
- name: Merge compile commands
72+
if: ${{ steps.check-artifact.outputs.exists == 'true' }}
73+
run: |
74+
find ~/.arduino/tests/ -iname "compile_commands.json" | xargs jq -s 'map(.[])' > ~/compile_commands.json
75+
76+
- name: Upload compile commands
77+
if: ${{ steps.check-artifact.outputs.exists == 'true' }}
78+
uses: actions/upload-artifact@v4
79+
with:
80+
name: compile_commands
81+
path: ~/compile_commands.json
82+
3883
- name: Install python dependencies
3984
run: python -m pip install pre-commit docutils
4085

.github/workflows/push.yml

+11
Original file line numberDiff line numberDiff line change
@@ -48,6 +48,17 @@ jobs:
4848
- name: Build Sketches
4949
run: bash ./.github/scripts/on-push.sh ${{ matrix.chunk }} 15
5050

51+
- name: Upload artifact
52+
uses: actions/upload-artifact@v4
53+
with:
54+
name: build-job-${{ matrix.chunk }}
55+
path: |
56+
~/.arduino/tests/**/*.h
57+
~/.arduino/tests/**/*.cpp
58+
~/.arduino/tests/**/*.bin
59+
~/.arduino/tests/**/compile_commands.json
60+
if-no-files-found: error
61+
5162
# Windows and MacOS
5263
build-arduino-win-mac:
5364
name: Arduino on ${{ matrix.os }}

0 commit comments

Comments
 (0)