AutoMerge - Nightly #543
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# This workflow is triggered by a cron job and merges the upstream 'devel' branch into 'devel+classic'. | |
# If there are merge conflicts, it creates an issue and does not push any changes. | |
# Incidentally, it also pushes 'upstream/devel:devel' to the repo, keeping our diff up-to-date. | |
# | |
# Changelog: | |
# | |
# In January 2023, ledgerwatch extracted a Go library from erigon called 'github.com/ledgerwatch/erigon-lib' as an external dependency. | |
# See github.com/etccooperative/erigon-lib for changes enabling Ethereum Classic support. | |
# | |
# This workflow attempts to manage the upstream merges of both github.com/etccooperative/erigon and github.com/etccooperative/erigon-lib. | |
# It will first fetch and merge github.com/ledgerwatch/erigon-lib into github.com/etccooperative/erigon-lib (branches: 'main' vs. 'main+classic'). | |
# If this merge (and push to remote) is successful, it will then fetch, merge, and push github.com/ledgerwatch/erigon into github.com/etccooperative/erigon (branches: 'devel' vs. 'devel+classic'). | |
name: AutoMerge - Nightly | |
on: | |
workflow_dispatch: | |
schedule: | |
- cron: '0 0 * * *' | |
jobs: | |
erigon-lib: | |
runs-on: ubuntu-latest | |
# https://docs.github.com/en/actions/using-jobs/defining-outputs-for-jobs | |
outputs: | |
ERIGON_LIB_HEAD: ${{ steps.merge.outputs.ERIGON_LIB_HEAD }} | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
repository: etccooperative/erigon-lib | |
ref: main+classic | |
submodules: false | |
fetch-depth: 0 | |
- name: Set up git config | |
run: | | |
git config --global user.email "[email protected]" | |
git config --global user.name "meowsbits" | |
# Keep forked remote default branch ('main') up-to-date with upstream. | |
- name: Push erigon-lib 'upstream/main:main' (with --force) | |
env: | |
MY_PAT: ${{ secrets.MEOWSBITS_REPOWORKFLOW_TOKEN }} | |
run: | | |
git remote add upstream https://github.com/ledgerwatch/erigon-lib.git | |
git fetch upstream | |
git remote set-url origin https://meowsbits:${MY_PAT}@github.com/etccooperative/erigon-lib.git | |
# 'Github Actions workflow push to another repo' @ https://stackoverflow.com/a/69979203 | |
git config --unset-all http.https://github.com/.extraheader | |
git push origin upstream/main:main --force | |
# Keep forked remote ETC branch ('main+classic') merged with upstream's "main" branch. | |
- name: Merge erigon-lib branch 'main' into 'main+classic' | |
id: merge # Necessary for setting an OUTPUT value. | |
run: | | |
merge_status=$(git merge -X theirs upstream/main --no-edit) | |
if [[ $merge_status == 1 ]]; then | |
echo "Merge conflict detected" | |
exit 1 | |
fi | |
# The merge was successful. | |
# Before exiting, save the newly-minted commit hash to an environment variable, | |
# which we'll reference later in an erigon update step upgrading (bumping) this dependency. | |
ERIGON_LIB_HEAD="$(git rev-parse HEAD)" | |
echo "ERIGON_LIB_HEAD=${ERIGON_LIB_HEAD}" # Debug print. | |
echo "ERIGON_LIB_HEAD=${ERIGON_LIB_HEAD}" >> $GITHUB_OUTPUT # Write the result to the special OUTPUT value. | |
exit 0 | |
- name: Push erigon-lib changes if successful | |
if: success() | |
env: | |
MY_PAT: ${{ secrets.MEOWSBITS_REPOWORKFLOW_TOKEN }} | |
run: | | |
git remote set-url origin https://meowsbits:${MY_PAT}@github.com/etccooperative/erigon-lib.git | |
git push origin main+classic | |
- name: Create issue if failed | |
if: failure() | |
uses: JasonEtco/create-an-issue@v2 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
filename: .github/automerge-issue-on-failure.md | |
erigon: | |
needs: erigon-lib | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
ref: devel+classic | |
submodules: false | |
fetch-depth: 0 | |
token: ${{ secrets.MEOWSBITS_REPOWORKFLOW_TOKEN }} | |
- name: Set up git config | |
run: | | |
git config --global user.email "[email protected]" | |
git config --global user.name "meowsbits" | |
# Keep forked remote default branch ('devel') up-to-date with upstream. | |
- name: Push erigon 'upstream/devel:devel' (with --force) | |
env: | |
MY_PAT: ${{ secrets.MEOWSBITS_REPOWORKFLOW_TOKEN }} | |
run: | | |
git remote add upstream https://github.com/ledgerwatch/erigon.git | |
git fetch upstream | |
git remote set-url origin https://meowsbits:${MY_PAT}@github.com/${GITHUB_REPOSITORY}.git | |
git push origin upstream/devel:devel --force | |
# Update the erigon-lib dependency in go.mod. | |
# We use the environment variable ERIGON_LIB_HEAD, which was set in the previous step. | |
- uses: actions/setup-go@v3 | |
with: | |
go-version: '1.20.0' # The Go version to download (if necessary) and use. | |
- name: Update erigon-lib dependency | |
run: | | |
echo "ERIGON_LIB_HEAD=${{ needs.erigon-lib.outputs.ERIGON_LIB_HEAD }}" # Debug print. | |
[[ -z "${{ needs.erigon-lib.outputs.ERIGON_LIB_HEAD }}" ]] && { | |
echo "ERIGON_LIB_HEAD is empty" | |
exit 0 | |
} | |
go mod edit -replace "github.com/ledgerwatch/erigon-lib=github.com/etccooperative/erigon-lib@${{ needs.erigon-lib.outputs.ERIGON_LIB_HEAD }}" | |
go mod tidy | |
git diff --quiet || { | |
echo "Work tree has modified files." | |
git add go.mod go.sum | |
git commit -m "Update erigon-lib dependency" | |
} | |
# Keep forked remote ETC branch ('devel+classic') merged with upstream's "devel" branch. | |
- name: Merge erigon branch 'devel' into 'devel+classic' | |
run: | | |
merge_status=$(git merge -X theirs upstream/devel --no-edit) | |
if [[ $merge_status == 1 ]]; then | |
echo "Merge conflict detected" | |
exit 1 | |
fi | |
exit 0 | |
- name: Push erigon changes if successful | |
if: success() | |
env: | |
MY_PAT: ${{ secrets.MEOWSBITS_REPOWORKFLOW_TOKEN }} | |
run: | | |
git remote set-url origin https://meowsbits:${MY_PAT}@github.com/${GITHUB_REPOSITORY}.git | |
git push origin devel+classic | |
- name: Create issue if failed | |
if: failure() | |
uses: JasonEtco/create-an-issue@v2 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
filename: .github/automerge-issue-on-failure.md | |