From 7b0708e8ced5643d2a54b4d0554529ea87505ec2 Mon Sep 17 00:00:00 2001 From: Bekir Oguz Date: Mon, 7 Oct 2024 07:30:12 +0200 Subject: [PATCH] fix CI pipeline for the pull requests from forks (i.e. scala-steward) excluding publish jobs (#1782) * fix CI pipeline for the pull requests from forks (i.e. scala-steward) excluding publish jobs * Fix CI pipeline to prevent double triggering for push and pull_request events --- .github/workflows/ci.yml | 29 +++++++++++++++++------------ 1 file changed, 17 insertions(+), 12 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index b623b2663..c0eed6c1e 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -3,6 +3,8 @@ on: push: branches: ["**"] tags: ["v*"] + pull_request: + branches: ["master"] permissions: contents: read @@ -14,6 +16,8 @@ jobs: contents: write pull-requests: write runs-on: ubuntu-latest + # This condition ensures the ci job runs only for push events that are not associated with a pull request (prevents duplicate runs) + if: ${{ github.event_name == 'push' && github.event.pull_request == null }} steps: - name: Checkout uses: actions/checkout@v4 @@ -28,22 +32,23 @@ jobs: - name: Run tests and coverage run: |- cp .jvmopts-ci .jvmopts - sbt coverage test coverageReport && bash <(curl -s https://codecov.io/bash) + sbt coverage test coverageReport && bash <(curl -s https://codecov.io/bash) - name: Prepare draft release notes - # Run this step only for pushes to the master branch or for tags starting with 'v' - if: ${{ github.event_name == 'push' && (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/v')) }} + # Run this step only in the original repo and for pushes to the master branch or for tags starting with 'v' + if: ${{ github.event_name == 'push' && (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/v')) && ! github.event.repository.fork }} continue-on-error: true uses: release-drafter/release-drafter@v6 with: config-name: release-drafter.yml env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + publish-sonatype: permissions: contents: write pull-requests: write name: Publish to Sonatype - # Publish to Sonatype only on tags starting with 'v' (stable releases) and not from forked repositories + # Publish to Sonatype only from the original repo and for the tags starting with 'v' if: ${{ github.event_name == 'push' && startsWith(github.ref, 'refs/tags/v') && ! github.event.repository.fork }} needs: [ci] runs-on: ubuntu-latest @@ -65,13 +70,14 @@ jobs: PGP_SECRET: ${{ secrets.PGP_SECRET }} SONATYPE_PASSWORD: ${{ secrets.SONATYPE_PASSWORD }} SONATYPE_USERNAME: ${{ secrets.SONATYPE_USERNAME }} + publish-azure: permissions: contents: write pull-requests: write name: Publish to Azure - # Publish to Azure only for non-tag references (e.g., all the pushes to default and other branches) and not from forked repositories - if: ${{ ! startsWith(github.ref, 'refs/tags/') && ! github.event.repository.fork }} + # Publish to Azure all the commits for all the branches from the original repo except for tags. + if: ${{ github.event_name == 'push' && ! startsWith(github.ref, 'refs/tags/') && ! github.event.repository.fork }} needs: [ci] runs-on: ubuntu-latest steps: @@ -91,13 +97,13 @@ jobs: AZURE_FEEDUSER: ${{ secrets.AZURE_FEEDUSER }} AZURE_FEEDPASSWORD: ${{ secrets.AZURE_FEEDPASSWORD }} AZURE_FEEDURL: ${{ secrets.AZURE_FEEDURL }} + dependency-submission: name: Submit dependency graph continue-on-error: true needs: [ci] - # run on 1) master branch - # do not run on pull requests - if: github.event_name != 'pull_request' && github.ref == 'refs/heads/master' + # Submit dependency graph only for the master branch commits + if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }} runs-on: ubuntu-latest permissions: contents: write @@ -112,6 +118,5 @@ jobs: distribution: temurin java-version: 17 cache: sbt - - name: Submit dependency graph - uses: scalacenter/sbt-dependency-submission@v2 - + - name: Submit dependency graph + uses: scalacenter/sbt-dependency-submission@v2 \ No newline at end of file