From 26d4fac79e540f4fe23a27aa0514a29193b0c55a Mon Sep 17 00:00:00 2001 From: Arran Schlosberg Date: Tue, 15 Oct 2024 22:30:29 +0100 Subject: [PATCH 1/3] feat: signed commit when renaming upstream module --- .github/workflows/rename-module.yml | 54 +++++++++++++---------------- 1 file changed, 24 insertions(+), 30 deletions(-) diff --git a/.github/workflows/rename-module.yml b/.github/workflows/rename-module.yml index b2ccc20714b..80dcb460199 100644 --- a/.github/workflows/rename-module.yml +++ b/.github/workflows/rename-module.yml @@ -1,13 +1,6 @@ name: Rename Go module on: - # During development, the next two lines MAY be enabled to have the PR - # automatically run this workflow for inspection of the resulting branch. - # However, they MUST be disabled again before merging otherwise *all* PRs will - # run this. - # - # pull_request: - # branches: [ main ] workflow_dispatch: inputs: source_commit: @@ -19,18 +12,23 @@ on: jobs: rename-module: runs-on: ubuntu-latest - env: - source_commit: "${{ inputs.source_commit || '2bd6bd01d2e8561dd7fc21b631f4a34ac16627a1' }}" - # env variables cannot reference others so we have to duplicate the || - output_branch: "${{ github.ref_name }}_auto-rename-module-${{ inputs.source_commit || '2bd6bd01d2e8561dd7fc21b631f4a34ac16627a1' }}" steps: - uses: actions/checkout@v4 with: fetch-depth: 0 # everything - fetch-tags: true + + - name: Set variables + id: vars + # Including hashes of both the source commit and the workflow file makes + # this idempotent. + env: + WORKFLOW_HASH: ${{ hashFiles('.github/workflows/rename-module.yml') }} + run: | + echo "DEST_BRANCH=auto-rename-module_source-${{ inputs.source_commit }}_workflow-${WORKFLOW_HASH}-${{ github.ref_name }}" \ + >> "$GITHUB_OUTPUT"; - name: Check out source commit - run: git checkout ${{ env.source_commit }} + run: git checkout ${{ inputs.source_commit }} - name: Globally update module name run: | @@ -60,22 +58,18 @@ jobs: go build ./...; go test ./accounts/abi/bind ./rlp/rlpgen - - name: Commit to new branch - uses: devops-infra/action-commit-push@8bc2ff9f9de7aa2a7581fc7e5b6401c04cab54c7 - with: - github_token: ${{ secrets.GITHUB_TOKEN }} - target_branch: ${{ env.output_branch }} - force: true - commit_prefix: "[AUTO] rename Go module + update internal import paths" + - name: Create new branch + env: + BRANCH: ${{ steps.vars.outputs.DEST_BRANCH }} + run: | + git checkout -b "${BRANCH}"; + git push origin "${BRANCH}"; - - name: Open PR to "renamed-go-module" iff workflow dispatched on "main" - # If we are changing the way in which we manage module renaming then it - # MUST go through PR review to main; only then can it open PRs. - if: github.event_name == 'workflow_dispatch' && github.ref == 'refs/heads/main' - uses: devops-infra/action-pull-request@v0.5.5 + - name: Commit to new branch + uses: planetscale/ghcommit-action@v0.2.0 + env: + GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} with: - github_token: ${{ secrets.GITHUB_TOKEN }} - source_branch: ${{ env.output_branch }} - target_branch: renamed-go-module - title: "[AUTO] Rename upstream Go module at `${{ env.source_commit }}`" - body: "_PR generated by GitHub Action_" + commit_message: "[AUTO] rename Go module + update internal import paths" + repo: ${{ github.repository }} + branch: ${{ steps.vars.outputs.DEST_BRANCH }} From da2eaf55e2be54bb9d77ca53950252453db588e0 Mon Sep 17 00:00:00 2001 From: Arran Schlosberg Date: Wed, 16 Oct 2024 02:45:12 +0100 Subject: [PATCH 2/3] chore: lock `ghcommit-action` commit hash --- .github/workflows/rename-module.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/rename-module.yml b/.github/workflows/rename-module.yml index 80dcb460199..635a3a42a90 100644 --- a/.github/workflows/rename-module.yml +++ b/.github/workflows/rename-module.yml @@ -66,7 +66,7 @@ jobs: git push origin "${BRANCH}"; - name: Commit to new branch - uses: planetscale/ghcommit-action@v0.2.0 + uses: planetscale/ghcommit-action@d4176bfacef926cc2db351eab20398dfc2f593b5 # v0.2.0 env: GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} with: From 6c4398ccda70d72ca94476399ba4f3fe8d3c923a Mon Sep 17 00:00:00 2001 From: Arran Schlosberg Date: Wed, 16 Oct 2024 02:54:58 +0100 Subject: [PATCH 3/3] chore: include workflow-file hash in commit message --- .github/workflows/rename-module.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/rename-module.yml b/.github/workflows/rename-module.yml index 635a3a42a90..2f483cc0190 100644 --- a/.github/workflows/rename-module.yml +++ b/.github/workflows/rename-module.yml @@ -24,6 +24,7 @@ jobs: env: WORKFLOW_HASH: ${{ hashFiles('.github/workflows/rename-module.yml') }} run: | + echo "WORKFLOW_HASH=${WORKFLOW_HASH}" >> "$GITHUB_OUTPUT"; echo "DEST_BRANCH=auto-rename-module_source-${{ inputs.source_commit }}_workflow-${WORKFLOW_HASH}-${{ github.ref_name }}" \ >> "$GITHUB_OUTPUT"; @@ -70,6 +71,6 @@ jobs: env: GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} with: - commit_message: "[AUTO] rename Go module + update internal import paths" + commit_message: "[AUTO] rename Go module + update internal import paths\n\nWorkflow: ${{ steps.vars.outputs.WORKFLOW_HASH }} on branch ${{ github.ref_name }}" repo: ${{ github.repository }} branch: ${{ steps.vars.outputs.DEST_BRANCH }}