diff --git a/.github/workflows/auto-merge.next.yaml b/.github/workflows/auto-merge.next.yaml new file mode 100644 index 00000000000..83cab7248bd --- /dev/null +++ b/.github/workflows/auto-merge.next.yaml @@ -0,0 +1,39 @@ +name: auto-merge-next + +on: + workflow_dispatch: {} + schedule: + - cron: "*/30 * * * *" # At every 30 minutes + +jobs: + auto-approve: + runs-on: ubuntu-latest + if: github.repository_owner == 'openshift-pipelines' # do not run this elsewhere + permissions: + pull-requests: write + steps: + - name: Checkout the current repo + uses: actions/checkout@v4 + - name: auto-merge-update-references + run: | + gh auth status + git config user.name openshift-pipelines-bot + git config user.email pipelines-extcomm@redhat.com + # Approve and merge pull-request with no reviews + for p in $(gh pr list --search "author:app/red-hat-konflux head:konflux/references/next" --json "number" | jq ".[].number"); do + gh pr merge --rebase --delete-branch --auto $p + done + env: + GH_TOKEN: ${{ secrets.OPENSHIFT_PIPELINES_ROBOT }} + - name: auto-merge-upstream-next + run: | + gh auth status + git config user.name openshift-pipelines-bot + git config user.email pipelines-extcomm@redhat.com + # Approve and merge pull-request with no reviews + for p in $(gh pr list --search "head:actions/update/sources-next" --json "number" | jq ".[].number"); do + gh pr merge --rebase --delete-branch --auto $p + done + env: + GH_TOKEN: ${{ secrets.OPENSHIFT_PIPELINES_ROBOT }} + diff --git a/.github/workflows/update-sources.main.yaml b/.github/workflows/update-sources.main.yaml index 3eacd6793d6..1a54ab7c6ed 100644 --- a/.github/workflows/update-sources.main.yaml +++ b/.github/workflows/update-sources.main.yaml @@ -64,9 +64,10 @@ jobs: if [ "$(gh pr list --base main --head actions/update/sources-main --json url --jq 'length')" = "0" ]; then echo "creating PR..." - gh pr create -B main -H actions/update/sources-main --fill + gh pr create -B main -H actions/update/sources-main --label=automated --label=upstream --fill else - echo "a PR already exists, skipping..." + echo "a PR already exists, editing..." + gh pr edit --title "[bot] Update from tektoncd/pipeline to ${NEW_COMMIT}" --body "$(cat /tmp/diff.txt | sed 's/^/ /')" fi env: GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/update-sources.next.yaml b/.github/workflows/update-sources.next.yaml new file mode 100644 index 00000000000..e7a748d340f --- /dev/null +++ b/.github/workflows/update-sources.next.yaml @@ -0,0 +1,73 @@ +# Generated by openshift-pipelines/hack. DO NOT EDIT. +name: update-sources-next + +on: + workflow_dispatch: {} + schedule: + - cron: "30 */12 * * *" # At minute 30 past every 12th hour. + +jobs: + + update-sources: + runs-on: ubuntu-latest + if: github.repository_owner == 'openshift-pipelines' # do not run this elsewhere + permissions: + contents: write + pull-requests: write + steps: + - name: Checkout the current repo + uses: actions/checkout@v4 + with: + ref: next + + - name: Clone tektoncd/pipeline + run: | + rm -fR upstream + git clone https://github.com/tektoncd/pipeline upstream + pushd upstream + git checkout -B release-v0.65.x origin/release-v0.65.x + popd + + - name: Commit new changes + run: | + git config user.name openshift-pipelines-bot + git config user.email pipelines-extcomm@redhat.com + git checkout -b actions/update/sources-next + pushd upstream + OLD_COMMIT=$(cat ../head) + NEW_COMMIT=$(git rev-parse HEAD) + echo Previous commit: ${OLD_COMMIT} + git show --stat ${OLD_COMMIT} + echo New commit: ${NEW_COMMIT} + git show --stat ${NEW_COMMIT} + git diff --stat ${NEW_COMMIT}..${OLD_COMMIT} > /tmp/diff.txt + git rev-parse HEAD > ../head + popd + rm -rf upstream/.git + git add upstream head .konflux + + if [[ -z $(git status --porcelain --untracked-files=no) ]]; then + echo "No change, exiting" + exit 0 + fi + + git commit -F- <