mirror of
https://code.forgejo.org/forgejo/runner.git
synced 2025-09-05 18:40:59 +00:00
chore: unify cascade-setup-forgejo with cascade-forgejo
- fix bug: close-merge is close - add instructions for debug - identify the origin of the tokens - copy/paste from cascade-forgejo.yml with the following exceptions: - do not trigger on main - use run-end-to-end-test instead of run-forgejo-test
This commit is contained in:
parent
0b3891d166
commit
c76241e6b4
3 changed files with 101 additions and 25 deletions
|
@ -1,16 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -ex
|
|
||||||
|
|
||||||
setup_forgejo=$1
|
|
||||||
setup_forgejo_pr=$2
|
|
||||||
runner=$3
|
|
||||||
runner_pr=$4
|
|
||||||
|
|
||||||
url=$(jq --raw-output .head.repo.html_url < $runner_pr)
|
|
||||||
test "$url" != null
|
|
||||||
branch=$(jq --raw-output .head.ref < $runner_pr)
|
|
||||||
test "$branch" != null
|
|
||||||
cd $setup_forgejo
|
|
||||||
./utils/upgrade-runner.sh $url @$branch
|
|
||||||
date > last-upgrade
|
|
24
.forgejo/cascading-setup-forgejo
Executable file
24
.forgejo/cascading-setup-forgejo
Executable file
|
@ -0,0 +1,24 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -ex
|
||||||
|
|
||||||
|
setup_forgejo=$1
|
||||||
|
setup_forgejo_pr=$2
|
||||||
|
runner=$3
|
||||||
|
runner_pr_or_ref=$4
|
||||||
|
|
||||||
|
if test -f "$runner_pr_or_ref"; then
|
||||||
|
url=$(jq --raw-output .head.repo.html_url <$runner_pr)
|
||||||
|
test "$url" != null
|
||||||
|
branch=$(jq --raw-output .head.ref <$runner_pr)
|
||||||
|
else
|
||||||
|
url=https://code.forgejo.org/forgejo/runner
|
||||||
|
branch=${runner_pr_or_ref#refs/heads/}
|
||||||
|
fi
|
||||||
|
test "$url"
|
||||||
|
test "$branch"
|
||||||
|
test "$branch" != null
|
||||||
|
cd $setup_forgejo
|
||||||
|
./utils/upgrade-runner.sh $url @$branch
|
||||||
|
rm -f .forgejo/workflows/integration*.yml
|
||||||
|
date >last-upgrade
|
|
@ -1,31 +1,99 @@
|
||||||
|
# Copyright 2025 The Forgejo Authors
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
#
|
||||||
|
# CASCADING_PR_ORIGIN is a token from the https://code.forgejo.org/cascading-pr user
|
||||||
|
# with scope write:issue read:repository read:user
|
||||||
|
# CASCADING_PR_DESTINATION is a token from the https://code.forgejo.org/cascading-pr user
|
||||||
|
# with scope write:issue write:repository read:user
|
||||||
|
#
|
||||||
|
# To modify this workflow:
|
||||||
|
#
|
||||||
|
# - push it to the wip-cascade branch on the repository
|
||||||
|
# otherwise it will not have access to the secrets required to push
|
||||||
|
# the cascading PR
|
||||||
|
#
|
||||||
|
# - once it works, open a pull request for the sake of keeping track
|
||||||
|
# of the change even if the PR won't run it because it will use
|
||||||
|
# whatever is in the default branch instead
|
||||||
|
#
|
||||||
|
# - after it is merged, double check it works by setting the
|
||||||
|
# label on a pull request (any pull request will do)
|
||||||
|
#
|
||||||
|
name: cascade
|
||||||
|
|
||||||
on:
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- 'wip-cascade'
|
||||||
pull_request_target:
|
pull_request_target:
|
||||||
types:
|
types:
|
||||||
- opened
|
|
||||||
- synchronize
|
- synchronize
|
||||||
|
- labeled
|
||||||
- closed
|
- closed
|
||||||
|
|
||||||
enable-email-notifications: true
|
enable-email-notifications: true
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
cascade:
|
debug:
|
||||||
|
if: >
|
||||||
|
vars.DEBUG == 'yes'
|
||||||
|
runs-on: docker
|
||||||
|
container:
|
||||||
|
image: data.forgejo.org/oci/node:22-bookworm
|
||||||
|
steps:
|
||||||
|
- name: event
|
||||||
|
run: |
|
||||||
|
cat <<'EOF'
|
||||||
|
${{ toJSON(forge.event.pull_request.labels.*.name) }}
|
||||||
|
EOF
|
||||||
|
cat <<'EOF'
|
||||||
|
push => ${{ forge.event_name == 'push' && ( forge.ref_name == 'wip-cascade') }}
|
||||||
|
pull_request_target synchornized => ${{ ( forge.event.action == 'synchronized' && contains(forge.event.pull_request.labels.*.name, 'run-end-to-end-tests') ) }}
|
||||||
|
pull_request_target label_updated => ${{ ( forge.event.action == 'label_updated' && forge.event.label.name == 'run-end-to-end-tests' ) }}
|
||||||
|
contains => ${{ contains(forge.event.pull_request.labels.*.name, 'run-end-to-end-tests') }}
|
||||||
|
contains boolean => ${{ contains(forge.event.pull_request.labels.*.name, 'run-end-to-end-tests') == true }}
|
||||||
|
EOF
|
||||||
|
cat <<'EOF'
|
||||||
|
${{ toJSON(forge) }}
|
||||||
|
EOF
|
||||||
|
|
||||||
|
end-to-end:
|
||||||
|
#
|
||||||
|
# Always run when a commit is pushed to the wip-cascade branch
|
||||||
|
# If this is a pull request, run
|
||||||
|
# - when the `run-end-to-end-tests` label is set (label_updated) (but not if another label is set or if a label is removed)
|
||||||
|
# - when a new commit is pushed to the pull request (synchronized) if the `run-end-to-end-tests` is already present
|
||||||
|
# - when the pull request is closed, which also happens when it is merged, so that the setup-forgejo & end-to-end pull requests are closed
|
||||||
|
#
|
||||||
|
if: >
|
||||||
|
vars.ROLE == 'forgejo-coding' && (
|
||||||
|
(
|
||||||
|
forge.event_name == 'push' && ( forge.ref_name == 'wip-cascade' )
|
||||||
|
) || (
|
||||||
|
forge.event_name == 'pull_request_target' && (
|
||||||
|
forge.event.action == 'closed' ||
|
||||||
|
( forge.event.action == 'synchronized' && contains(forge.event.pull_request.labels.*.name, 'run-end-to-end-tests') ) ||
|
||||||
|
( forge.event.action == 'label_updated' && forge.event.label.name == 'run-end-to-end-tests' )
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
runs-on: docker
|
runs-on: docker
|
||||||
container:
|
container:
|
||||||
image: 'code.forgejo.org/oci/node:22-bookworm'
|
image: 'code.forgejo.org/oci/node:22-bookworm'
|
||||||
if: >
|
|
||||||
! contains(forge.event.pull_request.title, '[skip cascade]')
|
|
||||||
steps:
|
steps:
|
||||||
- uses: https://code.forgejo.org/actions/cascading-pr@v2.2.1
|
- uses: https://code.forgejo.org/actions/cascading-pr@v2.2.1
|
||||||
with:
|
with:
|
||||||
origin-url: ${{ env.FORGEJO_SERVER_URL }}
|
origin-url: ${{ forge.server_url }}
|
||||||
origin-repo: forgejo/runner
|
origin-repo: ${{ forge.repository }}
|
||||||
origin-token: ${{ secrets.CASCADING_PR_ORIGIN }}
|
origin-token: ${{ secrets.CASCADING_PR_ORIGIN }}
|
||||||
origin-pr: ${{ forge.event.pull_request.number }}
|
origin-pr: ${{ forge.event.pull_request.number }}
|
||||||
destination-url: ${{ env.FORGEJO_SERVER_URL }}
|
origin-ref: ${{ forge.event_name == 'push' && forge.event.ref || '' }}
|
||||||
|
destination-url: ${{ forge.server_url }}
|
||||||
destination-repo: actions/setup-forgejo
|
destination-repo: actions/setup-forgejo
|
||||||
destination-fork-repo: cascading-pr/setup-forgejo
|
destination-fork-repo: cascading-pr/setup-forgejo
|
||||||
destination-branch: main
|
destination-branch: main
|
||||||
destination-token: ${{ secrets.CASCADING_PR_DESTINATION }}
|
destination-token: ${{ secrets.CASCADING_PR_DESTINATION }}
|
||||||
close-merge: true
|
close: true
|
||||||
update: .forgejo/cascading-pr-setup-forgejo
|
verbose: ${{ vars.VERBOSE == 'yes' }}
|
||||||
|
debug: ${{ vars.DEBUG == 'yes' }}
|
||||||
|
update: .forgejo/cascading-setup-forgejo
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue