Skip to content

feat: support angular@20 #1014

feat: support angular@20

feat: support angular@20 #1014

# We've configured Renovate to open bump PRs for Angular dependencies within our
# test fixtures. This workflow sends notifications when one of these PRs fails.
name: Notify on Angular bump failures
on:
pull_request:
types: [opened, synchronize, labeled, unlabeled]
jobs:
waitForWorkflows:
name: Wait for workflows
runs-on: ubuntu-latest
if: always()
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
ref: ${{ github.event.pull_request.head.sha }}
- name: Wait for workflows
id: wait
uses: smartcontractkit/chainlink-github-actions/utils/wait-for-workflows@5a7543e418aa2dc57b75e85581eae30820a8c9ae
with:
max-timeout: '900'
polling-interval: '30'
github-token: ${{ secrets.GITHUB_TOKEN }}
notify-on-failure:
name: Notify on failure
needs: [waitForWorkflows]
# Note that this doesn't imply success of the workflows themselves, just the waiting.
if: needs.waitForWorkflows.result == 'success'
runs-on: ubuntu-latest
permissions:
issues: write
steps:
- name: Check out the repository
uses: actions/checkout@v4
- name: Check conditions for failure notification
id: check_label
uses: actions/github-script@v7
with:
script: |
const { owner, repo } = context.repo;
const sha = context.payload.pull_request.head.sha;
const prNumber = context.payload.pull_request.number;
// Get PR status, which is now settled
const { data: {check_suites: checkSuites} } = await github.rest.checks.listSuitesForRef({
owner,
repo,
ref: sha
});
// Get current PR state and labels
const { data: pullRequest } = await github.rest.pulls.get({
owner,
repo,
pull_number: prNumber,
// Don't filter on `state` here so we can gracefuly handle an "expected" race
// condition (PR closed between trigger and query) but still throw on unexpected errors.
});
if (pullRequest == null) {
core.setFailed("Aborting - cannot find PR corresponding to event trigger");
return;
}
const prIsOpen = pullRequest.state === "open";
// NOTE: Technically, we should query both Check Suites and Commit Statuses.
// We're assuming here that this repo exclusively uses the Checks API.
const prDidFail = checkSuites.some(({conclusion}) =>
conclusion === "failure" || conclusion === "timed_out"
);
// See `renovate.json5` at project root.
const REQUIRED_LABEL = "bump-framework-in-fixtures";
const prHasRequiredLabel = pullRequest.labels.some(label => label.name === REQUIRED_LABEL);
const shouldSendNotification = prIsOpen && prDidFail && prHasRequiredLabel;
core.setOutput("should_send_notif", shouldSendNotification ? "true" : "false");
- name: Create issue on failure
if: ${{ steps.check_label.outputs.should_send_notif == 'true' }}
uses: actions/github-script@v7
with:
script: |
const ISSUE_LABEL = "framework-bump-failure";
const { owner, repo } = context.repo;
const {data: issues} = await github.rest.issues.listForRepo({
owner,
repo,
state: "open",
labels: [ISSUE_LABEL]
});
if (issues.length > 0) {
console.log(`Open issue already exists: ${issues[0].html_url}`);
return;
}
const prUrl = context.payload.pull_request.html_url;
const {data: issue} = await github.rest.issues.create({
owner,
repo,
title: "Possible regression with new framework release",
labels: [ISSUE_LABEL],
body: `A framework release bump in test fixtures has failed. Check ${prUrl}.`
});
console.log(`Created issue: ${issue.html_url}`);