From d13ccfd74cdcd0e451eecc45cba29d08e84ce414 Mon Sep 17 00:00:00 2001 From: Anas Nashif Date: Tue, 18 Mar 2025 12:08:03 -0400 Subject: [PATCH] ci: clang: add workflow on push Change workflow to work on push events. Signed-off-by: Anas Nashif --- .github/workflows/clang.yaml | 57 +++++++++++++++++------------------- 1 file changed, 27 insertions(+), 30 deletions(-) diff --git a/.github/workflows/clang.yaml b/.github/workflows/clang.yaml index 11d249cd937..2f3efb49505 100644 --- a/.github/workflows/clang.yaml +++ b/.github/workflows/clang.yaml @@ -1,6 +1,12 @@ name: Build with Clang/LLVM - -on: pull_request_target +on: + push: + branches: + - main + - v*-branch + - collab-* +permissions: + contents: read concurrency: group: ${{ github.workflow }}-${{ github.event_name }}-${{ github.head_ref || github.ref }} @@ -17,16 +23,14 @@ jobs: strategy: fail-fast: false matrix: - platform: ["native_sim"] + subset: [1, 2] env: CCACHE_DIR: /node-cache/ccache-zephyr CCACHE_REMOTE_STORAGE: "redis://cache-*.keydb-cache.svc.cluster.local|shards=1,2,3" CCACHE_REMOTE_ONLY: "true" + CCACHE_IGNOREOPTIONS: '-specs=* --specs=*' LLVM_TOOLCHAIN_PATH: /usr/lib/llvm-16 - COMMIT_RANGE: ${{ github.event.pull_request.base.sha }}..${{ github.event.pull_request.head.sha }} BASE_REF: ${{ github.base_ref }} - outputs: - report_needed: ${{ steps.twister.outputs.report_needed }} steps: - name: Apply container owner mismatch workaround run: | @@ -49,9 +53,8 @@ jobs: git remote set-url origin ${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY} - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 with: - ref: ${{ github.event.pull_request.head.sha }} fetch-depth: 0 persist-credentials: false @@ -62,7 +65,6 @@ jobs: git config --global user.name "Zephyr Bot" rm -fr ".git/rebase-apply" rm -fr ".git/rebase-merge" - git rebase origin/${BASE_REF} git clean -f -d git log --pretty=oneline | head -n 10 west init -l . || true @@ -107,18 +109,8 @@ jobs: export ZEPHYR_BASE=${PWD} export ZEPHYR_TOOLCHAIN_VARIANT=llvm - # check if we need to run a full twister or not based on files changed - python3 ./scripts/ci/test_plan.py --no-detailed-test-id --platform ${{ matrix.platform }} -c origin/${BASE_REF}.. - - # We can limit scope to just what has changed - if [ -s testplan.json ]; then - echo "report_needed=1" >> $GITHUB_OUTPUT - # Full twister but with options based on changes - ./scripts/twister --no-detailed-test-id --force-color --inline-logs -M -N -v --load-tests testplan.json --retry-failed 2 - else - # if nothing is run, skip reporting step - echo "report_needed=0" >> $GITHUB_OUTPUT - fi + ./scripts/twister -p native_sim --no-detailed-test-id --force-color --inline-logs -M -N -v --retry-failed 2 \ + -T tests --subset ${{matrix.subset}}/2 - name: Print ccache stats if: always() @@ -126,20 +118,25 @@ jobs: ccache -s -vv - name: Upload Unit Test Results - if: always() && steps.twister.outputs.report_needed != 0 - uses: actions/upload-artifact@v4 + if: always() + uses: actions/upload-artifact@4cec3d8aa04e39d1a68397de0c4cd6fb9dce8ec1 # v4.6.1 with: - name: Unit Test Results (Subset ${{ matrix.platform }}) - path: twister-out/twister.xml + name: Unit Test Results (Subset ${{ matrix.subset }}) + path: | + twister-out/twister.xml + twister-out/twister.json + if-no-files-found: ignore clang-build-results: name: "Publish Unit Tests Results" needs: clang-build - runs-on: ubuntu-22.04 - if: (success() || failure() ) && needs.clang-build.outputs.report_needed != 0 + runs-on: ubuntu-24.04 + permissions: + checks: write # to create GitHub annotations + if: (success() || failure()) steps: - name: Download Artifacts - uses: actions/download-artifact@v4 + uses: actions/download-artifact@cc203385981b70ca67e1cc392babf9cc229d5806 # v4.1.9 with: path: artifacts - name: Merge Test Results @@ -150,7 +147,7 @@ jobs: - name: Upload Unit Test Results in HTML if: always() - uses: actions/upload-artifact@v4 + uses: actions/upload-artifact@4cec3d8aa04e39d1a68397de0c4cd6fb9dce8ec1 # v4.6.1 with: name: HTML Unit Test Results if-no-files-found: ignore @@ -158,7 +155,7 @@ jobs: junit-clang.html - name: Publish Unit Test Results - uses: EnricoMi/publish-unit-test-result-action@v2 + uses: EnricoMi/publish-unit-test-result-action@170bf24d20d201b842d7a52403b73ed297e6645b # v2.18.0 if: always() with: check_name: Unit Test Results