5.5 KiB
Forgejo Runner
A daemon that connects to a Forgejo instance and runs jobs for continous integration. The high level installation instructions are part of the Forgejo documentation.
Hacking
The Forgejo runner depends on a fork of ACT and is a dependency of the setup-forgejo action. Together they provide a development environment with end to end testing. Each repository also has some unit testing that can be used to quickly detect the simplest mistakes such as a failure to compile or static code checking failures (vulnerability, lint, etc.).
Assuming the modifications to the Forgejo runner are pushed to a fork in a branch named wip-runner-change
, a pull request will verify it compiles and the binary is sane (running forgejo-runner --version
). It will not verify that it is able to properly run jobs when connected to a live Forgejo instance.
For end to end testing, a branch should be pushed to a fork of the setup-forgejo action with a modification to the tests, similar to:
#
# Uncomment the following for a shortcut to debugging the Forgejo runner.
# It will build the runner from a designated repository and branch instead of
# downloading it from a canonical release.
#
./forgejo-test-helper.sh build_runner https://code.forgejo.org/earl-warren/runner wip-runner-change
Where https://code.forgejo.org/earl-warren/runner is the URL of the Forgejo runner fork and wip-runner-change
is the branch where the changes under test were pushed. When they do the wip-runner-change
branch can be discarded.
The runner can be released by merging the wip-runner-change
branch and by pushing a new tag, for instance v10.2.3
. For more information see the documentation that details this release process in the Forgejo infrastructure. Once published, the setup-forgejo action can be updated to default to this latest version knowing it already passed integration tests.
ACT
Assuming the modifications to ACT are pushed to a fork in a branch named wip-act-change
, a pull request will verify it compiles. It will not verify that the Forgejo runner can compile with it.
For verifying it is compatible with the Forgejo runner, a branch should be pushed to a fork of the Forgejo runner (for instance wip-runner-change
) that uses the ACT version under test in the wip-act-change
by modifying go.mod
to contain something like the following and running go mod tidy
:
replace github.com/nektos/act => code.forgejo.org/earl-warren/act wip-act-change
Where https://code.forgejo.org/earl-warren/act is the URL of the ACT fork and wip-act-change
is the branch where the changes under test were pushed. It will not verify that it is able to properly run jobs when connected to a live Forgejo instance. The wip-runner-change
branch must, in turn, be tested as explained above. When the Forgejo runner modified to include the changes in the wip-act-change
branch pass the end to end test of the setup-forgejo
action, it is ready to be released.
ACT can be released by merging the wip-act-change
branch and by pushing a new tag, for instance v48.8.20
. Once published, the Forgejo runner can be updated to default to this latest version knowing it already passed end to end tests with something like:
replace github.com/nektos/act => code.forgejo.org/forgejo/act v48.8.20
Local debug
The repositories are checked out in the same directory:
- runner: Forgejo runner
- act: ACT
- setup-forgejo: setup-forgejo
Install dependencies
The dependencies are installed manually or with:
setup-forgejo/forgejo-dependencies.sh
Build the Forgejo runner with the local ACT
The Forgejo runner is rebuilt with the ACT directory by changing the runner/go.mod
file to:
replace github.com/nektos/act => ../act
Running:
cd runner ; go mod tidy
Building:
cd runner ; rm -f forgejo-runner ; make forgejo-runner
Launch Forgejo and the runner
A Forgejo instance is launched with:
cd setup-forgejo ; ./forgejo.sh setup
firefox http://$(cat forgejo-ip):3000
The user is root
with password admin1234
. The runner is registered with:
cd setup-forgejo
docker exec --user 1000 forgejo forgejo actions generate-runner-token > forgejo-runner-token
../runner/forgejo-runner register --no-interactive --instance "http://$(cat forgejo-ip):3000/" --name runner --token $(cat forgejo-runner-token) --labels ubuntu-latest:docker://node:16-buster,self-hosted
And launched with:
cd setup-forgejo ; ../runner/forgejo-runner daemon
Try a sample workflow
From the Forgejo web interface, create a repository and add the following to .forgejo/workflows/try.yaml
. It will launch the job and the result can be observed from the actions
tab.
on: [push]
jobs:
ls:
runs-on: docker
steps:
- uses: actions/checkout@v3
- run: |
ls ${{ github.workspace }}