From 672a91113064b88c278d309e06851b8bfc20f682 Mon Sep 17 00:00:00 2001 From: Max Date: Thu, 23 Nov 2023 14:01:19 +0100 Subject: [PATCH] Workflow to update IC (#468) # Motivation We wish to keep the Internet Computer bindings up to date. # Changes * Create a cron job that periodically checks for new IC releases * On discovering a release with a meaningful change, the job creates a PR with updated .did files and typescript bindings. # Tests * Created PRs by pushing this branch * Note: The PRs did not pas CI because some manual changes were needed in addition to reflect the updated bindings. # Todos - [x] Add entry to changelog (if necessary). --- .github/workflows/update-ic.yml | 102 ++++++++++++++++++++++++++++++++ .gitignore | 3 + CHANGELOG.md | 4 ++ 3 files changed, 109 insertions(+) create mode 100644 .github/workflows/update-ic.yml diff --git a/.github/workflows/update-ic.yml b/.github/workflows/update-ic.yml new file mode 100644 index 000000000..386b990c8 --- /dev/null +++ b/.github/workflows/update-ic.yml @@ -0,0 +1,102 @@ +# A GitHub Actions workflow that regularly makes a PR to update +# the IC candid and code bindings. +name: Update IC +on: + schedule: + # Checks for new IC commit weekly + - cron: '30 3 * * MON' + workflow_dispatch: + # Provides an option to run this manually + ic_ref: + description: "The IC commit or tag to update to." + required: false + push: + branches: + # Runs if there is a change to the development branch for this workflow + - "update-ic" +jobs: + update-ic: + runs-on: ubuntu-latest + steps: + - name: Checkout ic-js + uses: actions/checkout@v3 + - name: Choose IC ref + id: choose_ic_ref + run: | + ref="${{ inputs.ic_ref }}" + if [[ "${requested_ref:-}" == "" ]] + then # Use the latest release + ref="$(gh release --repo dfinity/ic view --json tagName -q .tagName)" + fi + echo "ic_ref=$ref" >> "$GITHUB_OUTPUT" + env: + GH_TOKEN: ${{ github.token }} + - name: Checkout ic repo + uses: actions/checkout@v3 + with: + repository: dfinity/ic + ref: ${{ steps.choose_ic_ref.outputs.ic_ref }} + path: ic + - name: Update candid and related JS and TS files + id: update + run: | + set -euxo pipefail + # Gets didc + echo "$PATH" | tr : "\n" + mkdir -p "$HOME/.local/bin" + curl -Lf https://github.com/dfinity/candid/releases/download/2023-09-27/didc-linux64 | install -m 755 /dev/stdin "$HOME/.local/bin/didc" + # Gets prettier in a minute + npm ci + # Gets candid + ./scripts/import-candid ic + # Derives consequences + ./scripts/compile-idl-js + # Checks whether it was all for nothing. + # ... Note: Ignores how we got here. + set +x # Printing the diff to stderr repeatedly can be very noisy. + DIFF_IGNORING_PROVENANCE="$(git diff -I '\/\/ Generated from IC repo.*')" + if [[ "${DIFF_IGNORING_PROVENANCE:-}" == "" ]] + then + commit="$(cd ic && git rev-parse --short HEAD)" + echo "No signficant differences found in IC ref ${{ inputs.ic_ref }} (commit $commit)." + echo "updated=0" >> "$GITHUB_OUTPUT" + else + echo "API changes detected!" + git status + echo "updated=1" >> "$GITHUB_OUTPUT" + fi + - name: Create Pull Request + if: ${{ steps.update.outputs.updated == '1' }} + uses: peter-evans/create-pull-request@v4 + with: + token: ${{ secrets.GIX_CREATE_PR_PAT }} + base: main + add-paths: | + packages/**/*.did + packages/**/*.js + packages/**/*.ts + commit-message: Update IC commit + committer: GitHub + author: gix-bot + branch: bot-ic-update + branch-suffix: timestamp # Creates a new branch & PR with every run. If this gets spammy, please delete this line and instead block the PR from making a PR if there is already an open one. + delete-branch: true + title: 'Update IC Candid Files' + body: | + # Motivation + The Internet Computer APIs have updated. + + # Changes + * Updated the interface description files for the Internet Computer. + * Updated the javascript bindings for the latest IC interface. + + # Tests + - [ ] Please check the API updates for any breaking changes that affect our code. + - name: Notify Slack on failure + # Since the this is a scheduled job, a failure won't be shown on any + # PR status. To notify the team, we send a message to our Slack channel on failure. + uses: dfinity/internet-identity/.github/actions/slack@release-2023-08-28 + if: ${{ failure() }} + with: + WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} + MESSAGE: "IC commit update failed" diff --git a/.gitignore b/.gitignore index f87feadb8..c11ddab7e 100644 --- a/.gitignore +++ b/.gitignore @@ -114,3 +114,6 @@ dist # Built documentation /docs/ + +# IC if checked out, e.g. in CI +/ic/ diff --git a/CHANGELOG.md b/CHANGELOG.md index 5e2a55ef3..d11cb78b1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,10 @@ - Substitute `?` fields with `Option` fields in the converters related to NNS proposals. - Add retrieveBtcStatus to ckbtc minter canister. +## Operations + +- Add a cron job to periodically update IC candid files and typescript bindings. + # Release.2023.11.21-1400Z ## Overview