diff --git a/.github/workflows/rust.yml b/.github/workflows/rust.yml index 9aea817a8..99e645d4b 100644 --- a/.github/workflows/rust.yml +++ b/.github/workflows/rust.yml @@ -1,11 +1,8 @@ name: Rust on: - push: - branches-ignore: - - trying.tmp - - staging.tmp pull_request: + merge_group: jobs: miri: @@ -90,28 +87,14 @@ jobs: TARGET: x86_64-unknown-linux-gnu run: sh ci/run.sh - # These jobs doesn't actually test anything, but they're only used to tell - # bors the build completed, as there is no practical way to detect when a - # workflow is successful listening to webhooks only. - # - # ALL THE PREVIOUS JOBS NEED TO BE ADDED TO THE `needs` SECTION OF THIS JOB! - - end-success: - name: bors build finished - if: github.event.pusher.name == 'bors' && success() - runs-on: ubuntu-latest - needs: [miri, rustfmt_clippy, test, msrv] - - steps: - - name: Mark the job as successful - run: exit 0 - - end-failure: - name: bors build finished - if: github.event.pusher.name == 'bors' && (failure() || cancelled()) + conclusion: + needs: [test, msrv] + # !cancelled() executes the job regardless of whether the previous jobs passed or failed + if: ${{ !cancelled() }} runs-on: ubuntu-latest - needs: [miri, rustfmt_clippy, test, msrv] - steps: - - name: Mark the job as a failure - run: exit 1 + - name: Conclusion + run: | + jq -C <<< "${needs}" + # Check if all needs were successful or skipped. + jq --exit-status 'all(.result == "success" or .result == "skipped")' <<< '${{ toJson(needs) }}'