A runner for Gitea based on act.
Go to file
ChristopherHX f7a52789d9 fix: report job failure on error return (#14)
act_runner only returns the error to the runner, but doesn't update the job result to failure.

Co-authored-by: Christopher Homberger <christopher.homberger@web.de>
Reviewed-on: https://gitea.com/gitea/act_runner/pulls/14
Reviewed-by: Jason Song <i@wolfogre.com>
Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com>
Co-authored-by: ChristopherHX <christopherhx@noreply.gitea.io>
Co-committed-by: ChristopherHX <christopherhx@noreply.gitea.io>
2023-01-27 20:18:12 +08:00
.gitea/workflows Add websocket 2022-11-24 15:36:19 +08:00
client Rename to actions (#7) 2022-12-06 16:37:38 +08:00
cmd fix(typo): Use uppercase N for default input prompt (#9) 2022-12-19 09:06:24 +08:00
config Disable HTTP/2 (#4) 2022-11-29 10:35:59 +08:00
core feat(register): add labels to local runner file 2022-11-24 15:38:18 +08:00
engine feat: move main task logic to runtime package 2022-11-24 15:37:06 +08:00
poller Rename to actions (#7) 2022-12-06 16:37:38 +08:00
register Rename to actions (#7) 2022-12-06 16:37:38 +08:00
runtime fix: report job failure on error return (#14) 2023-01-27 20:18:12 +08:00
.gitignore chore(runner): remove client secret and add UUID in runner 2022-11-24 15:37:38 +08:00
.golangci.yml chore: add .golangci config 2022-11-24 15:36:28 +08:00
go.mod Update act to 0.234.1 (#12) 2023-01-06 18:32:01 +08:00
go.sum Update act to 0.234.1 (#12) 2023-01-06 18:32:01 +08:00
LICENSE Add license 2022-11-24 15:36:16 +08:00
main.go refactor: Add graceful shutdown signal notify func 2022-11-24 15:36:25 +08:00
Makefile chore: Add makefile 2022-11-24 15:37:09 +08:00
README.md docs: Add Prerequisites (#11) 2023-01-03 11:13:55 +08:00

act runner

Act runner is a runner for Gitea based on act.

Prerequisites

Docker Engine Community version is required. To install Docker CE, follow the official install instructions.

Quickstart

Build

make build

Register

./act_runner register

And you will be asked to input:

  1. Gitea instance URL, like http://192.168.8.8:3000/. You should use your gitea instance ROOT_URL as the instance argument and you should not use localhost or 127.0.0.1 as instance IP;
  2. Runner token, you can get it from http://192.168.8.8:3000/admin/runners;
  3. Runner name, you can just leave it blank;
  4. Runner labels, you can just leave it blank.

The process looks like:

INFO Registering runner, arch=amd64, os=darwin, version=0.1.5.
WARN Runner in user-mode.
INFO Enter the Gitea instance URL (for example, https://gitea.com/):
http://192.168.8.8:3000/
INFO Enter the runner token:
fe884e8027dc292970d4e0303fe82b14xxxxxxxx
INFO Enter the runner name (if set empty, use hostname:Test.local ):

INFO Enter the runner labels, leave blank to use the default labels (comma-separated, for example, ubuntu-20.04:docker://node:16-bullseye,ubuntu-18.04:docker://node:16-buster):

INFO Registering runner, name=Test.local, instance=http://192.168.8.8:3000/, labels=[ubuntu-latest:docker://node:16-bullseye ubuntu-22.04:docker://node:16-bullseye ubuntu-20.04:docker://node:16-bullseye ubuntu-18.04:docker://node:16-buster].
DEBU Successfully pinged the Gitea instance server
INFO Runner registered successfully.

You can also register with command line arguments.

./act_runner register --instance http://192.168.8.8:3000 --token <my_runner_token> --no-interactive

If the registry succeed, it will run immediately. Next time, you could run the runner directly.

Run

./act_runner daemon