# Conflicts: # _images/user/actions/list-of-runners.png # _images/user/actions/secret-add.png # _images/user/actions/secret-list.png
6.4 KiB
layout | title | license |
---|---|---|
~/layouts/Markdown.astro | Forgejo Actions user guide | CC-BY-SA-4.0 |
Forgejo Actions
provides continuous integration driven from the files in the .forgejo/workflows
directory of a repository. The syntax and semantic of the workflow
files will be familiar to people used to GitHub Actions but they are not and will never be identical.
The following guide explains key concepts to help understand how workflows
are interpreted, with a set of examples that can be copy/pasted and modified to fit particular use cases.
Quick start
- Verify that
Enable Repository Actions
is checked in theRepository
tab of the/{owner}/{repository}/settings
page. - Add the following to the
.forgejo/workflows/demo.yaml
file in the repository.on: [push] jobs: test: runs-on: ubuntu-latest steps: - run: echo All Good
- Go to the
Actions
tab of the/{owner}/{repository}/actions
page of the repository to see the result of the run. - Click on the workflow link to see the details and the job execution logs.
Secrets
A repository or an organization can hold secrets, a set of key/value pairs that are stored encrypted in the Forgejo
database and revealed to the workflows
as ${{ secrets.KEY }}
. They can be defined from the web interface:
- in
/org/{org}/settings/actions/secrets
to be available in all the repositories that belong to the organization - in
/{owner}/{repo}/settings/actions/secrets
to be available to theworkflows
of a single repository
Once the secret is added, its value cannot be changed or displayed.
Concepts
Forgejo runner
Forgejo
itself does not run the jobs
, it relies on the Forgejo runner to do so. See the Forgejo Actions administrator guide for more information.
Services
PostgreSQL, redis and other services can conveniently be run from container images with something similar to (see the full example):
services:
pgsql:
image: postgres:15
env:
POSTGRES_DB: test
POSTGRES_PASSWORD: postgres
ports:
- '5432:5432'
A container with the specified image:
is run before the job
starts and is terminated when it completes. The job can address the service using its name, in this case pgsql
.
The machine running the workflow
Each job
in a workflow
must specify the kind of machine it needs to run its steps
with runs-on
. For instance ubuntu-latest
in the following workflow
:
---
jobs:
test:
runs-on: ubuntu-latest
means that the Forgejo runner
that claims to provide a kind of machine labelled ubuntu-latest
will be selected by Forgejo
and sent the job to be run.
The actual machine provided by the runner entirely depends on how the Forgejo runner
was registered (see the Forgejo Actions administrator guide for more information).
By default the ubuntu-latest
label is a Docker container created from a Node.js 16 Debian GNU/Linux buster image and will run each step
as root. The full list of available labels
for a given repository can be seen in the /{owner}/{repo}/settings/actions/runners
page.
Container
When the runs-on
label matches a container image, the jobs will inherit the limitations imposed by the engine (Docker for instance) that runs the container. In particular they will not be able to run or install software that depends on systemd
, such as Docker.
A job can choose the container image with container:
, as shown in this example. For instance the following will ensure the job is run using Alpine 3.18 instead of the container image matching the ubuntu-latest
label.
runs-on: ubuntu-latest
container:
image: alpine:3.18
LXC
The runs-on: self-hosted
label will run the jobs in a LXC container where software that rely on systemd
can be installed. Nested containers can also be created recursively (see the setup-forgejo integration tests for an example).
Services
are not supported for jobs that run on LXC.
Examples
Each example is part of the setup-forgejo action test suite.
- Echo - a single step that prints one sentence.
- PostgreSQL service - a PostgreSQL service and a connection to display the (empty) list of tables of the default database.
- Choosing the image with
container
- replacing theruns-on: ubuntu-latest
image with thealpine:3.18
image usingcontainer:
.
Glossary
- workflow: a file in the
.forgejo/workflows
directory that contains jobs. - job: a sequential set of steps.
- step: a command the runner is required to carry out.
- action: a repository that can be used in a way similar to a function in any programming language to run a single step.
- runner: the Forgejo runner daemon tasked to execute the workflows.
- label the kind of machine that is matched against the value of
runs-on
in a workflow.