ci: Only report failures to CZO on branch pushes.

Targeted fix for regression introduced in #23719 wherein failure reports
were attempted for all CI failures, including those from forked pull
requests, which don't have access to Actions Secrets. Since undefined
Secrets are empty strings at interpolation time [^1], the underlying
`send-message` Action was being called with no API Key, causing a
failure in the failure handler.

This fix is, per discussion in both a comment on #23719 and later on CZO
[^2], prefered to restoring the prior guard against ZULIP_BOT_KEY being
an empty string that had been in the shell script as it is more explicit
in its intent.

[^1]: https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#example-using-secrets

[^2]: https://chat.zulip.org/#narrow/stream/43-automated-testing/topic/all.20branches.20failing/near/1475246

(cherry picked from commit a67ecc0f36)
This commit is contained in:
Josh Klar
2022-12-06 14:10:11 -08:00
committed by Tim Abbott
parent 00829867d7
commit f62b55a5cf
2 changed files with 8 additions and 8 deletions

View File

@@ -106,11 +106,11 @@ jobs:
- name: Generate failure report string - name: Generate failure report string
id: failure_report_string id: failure_report_string
if: ${{ failure() && github.repository == 'zulip/zulip' }} if: ${{ failure() && github.repository == 'zulip/zulip' && github.event_name == 'push' }}
run: tools/ci/generate-failure-message >> $GITHUB_OUTPUT run: tools/ci/generate-failure-message >> $GITHUB_OUTPUT
- name: Report status to CZO - name: Report status to CZO
if: ${{ failure() && github.repository == 'zulip/zulip' }} if: ${{ failure() && github.repository == 'zulip/zulip' && github.event_name == 'push' }}
uses: zulip/github-actions-zulip/send-message@v1 uses: zulip/github-actions-zulip/send-message@v1
with: with:
api-key: ${{ secrets.ZULIP_BOT_KEY }} api-key: ${{ secrets.ZULIP_BOT_KEY }}
@@ -211,11 +211,11 @@ jobs:
- name: Generate failure report string - name: Generate failure report string
id: failure_report_string id: failure_report_string
if: ${{ failure() && github.repository == 'zulip/zulip' }} if: ${{ failure() && github.repository == 'zulip/zulip' && github.event_name == 'push' }}
run: tools/ci/generate-failure-message >> $GITHUB_OUTPUT run: tools/ci/generate-failure-message >> $GITHUB_OUTPUT
- name: Report status to CZO - name: Report status to CZO
if: ${{ failure() && github.repository == 'zulip/zulip' }} if: ${{ failure() && github.repository == 'zulip/zulip' && github.event_name == 'push' }}
uses: zulip/github-actions-zulip/send-message@v1 uses: zulip/github-actions-zulip/send-message@v1
with: with:
api-key: ${{ secrets.ZULIP_BOT_KEY }} api-key: ${{ secrets.ZULIP_BOT_KEY }}
@@ -296,11 +296,11 @@ jobs:
- name: Generate failure report string - name: Generate failure report string
id: failure_report_string id: failure_report_string
if: ${{ failure() && github.repository == 'zulip/zulip' }} if: ${{ failure() && github.repository == 'zulip/zulip' && github.event_name == 'push' }}
run: tools/ci/generate-failure-message >> $GITHUB_OUTPUT run: tools/ci/generate-failure-message >> $GITHUB_OUTPUT
- name: Report status to CZO - name: Report status to CZO
if: ${{ failure() && github.repository == 'zulip/zulip' }} if: ${{ failure() && github.repository == 'zulip/zulip' && github.event_name == 'push' }}
uses: zulip/github-actions-zulip/send-message@v1 uses: zulip/github-actions-zulip/send-message@v1
with: with:
api-key: ${{ secrets.ZULIP_BOT_KEY }} api-key: ${{ secrets.ZULIP_BOT_KEY }}

View File

@@ -235,11 +235,11 @@ jobs:
- name: Generate failure report string - name: Generate failure report string
id: failure_report_string id: failure_report_string
if: ${{ failure() && github.repository == 'zulip/zulip' }} if: ${{ failure() && github.repository == 'zulip/zulip' && github.event_name == 'push' }}
run: tools/ci/generate-failure-message >> $GITHUB_OUTPUT run: tools/ci/generate-failure-message >> $GITHUB_OUTPUT
- name: Report status to CZO - name: Report status to CZO
if: ${{ failure() && github.repository == 'zulip/zulip' }} if: ${{ failure() && github.repository == 'zulip/zulip' && github.event_name == 'push' }}
uses: zulip/github-actions-zulip/send-message@v1 uses: zulip/github-actions-zulip/send-message@v1
with: with:
api-key: ${{ secrets.ZULIP_BOT_KEY }} api-key: ${{ secrets.ZULIP_BOT_KEY }}