Forgejo end-to-end tests
Go to file
thefox c6cd39b074
All checks were successful
/ build (push) Successful in 3m14s
/ packages (push) Successful in 8m21s
/ actions (push) Successful in 28m4s
/ actions-docs (map[branch:next forgejo:https://codeberg.org owner:forgejo-experimental version:7.0]) (push) Successful in 12m39s
/ actions-docs (map[forgejo:https://codeberg.org owner:forgejo version:1.21]) (push) Successful in 11m28s
/ upgrade and storage (push) Successful in 10m52s
Merge pull request 'actions: cron: create /srv/example/cron/contexts first' (#182) from earl-warren/end-to-end:wip-cron into main
Reviewed-on: #182
Reviewed-by: thefox <thefox@noreply.code.forgejo.org>
2024-05-21 06:52:08 +00:00
.forgejo tests: the development branch requires go 1.22 to build 2024-03-25 18:26:07 +01:00
actions actions: cron: create /srv/example/cron/contexts first 2024-05-21 08:16:39 +02:00
forgejo the forgejo development branch is now 8.0 2024-03-30 14:44:43 +01:00
lib lib: retry git fetch a few times (take 2) 2024-05-20 01:54:22 +02:00
packages Merge pull request 'merge actions test into end-to-end.sh' (#112) from twenty-panda/end-to-end:wip-actions into main 2024-03-20 13:18:28 +00:00
storage chore(cleanup): v1.20 is EOL, trim it 2024-04-25 14:24:50 +02:00
upgrade fix(pprof): reset_forgejo before running it 2024-04-25 14:24:52 +02:00
.editorconfig add editorconfig to help with Forgejo space display 2024-02-28 18:49:46 +01:00
.gitignore upgrades: remove ad-hoc code and use forgejo-curl.sh instead 2024-03-15 10:21:58 +07:00
end-to-end.sh merge actions test into end-to-end.sh 2024-03-20 13:42:44 +01:00
LICENSE import from forgejo 2023-10-26 21:21:20 +02:00
README.md docs: managing legacy tests and cutting branches 2024-04-25 13:24:51 +02:00

Forgejo end-to-end tests

A series of tests scenarios and assertions covering Forgejo and the Forgejo runner. They partially rely on Forgejo actions developed specifically for testing such as setup-forgejo.

They are designed to run using Forgejo releases and development versions compiled from designated repositories.

Removing legacy tests

End to end tests cover the supported range of releases and when one of them is EOL, it must be removed as well as the tests that target it specifically. Otherwise the test suite would grow indefinitely.

When a release is EOL, a branch is cut with a name following the pattern legacy/vX.Y-vA.B. For instance when v8.0 is published and v1.21 is EOL, the branch legacy/v8.0-v1.21 is cut.

Hacking

docker and sudo must be installed with insecure registries allowed in /etc/docker/daemon.json for the IP that will be used for forgejo such as:

{
  "insecure-registries": [ "10.0.0.0/8" ]
}

Use setup-forgejo from source.

The setup-forgejo repository is a Forgejo Action which is meant to be used in workflows. However, it is implemented as shell scripts that can also be used to create Forgejo instances and runners locally. This is convenient for testing and the reason why it needs to be added to the PATH. For instance, it is a dependency of the end-to-end.sh script.

git clone https://code.forgejo.org/actions/setup-forgejo
export PATH=$(pwd)/setup-forgejo:$PATH
git clone https://code.forgejo.org/forgejo/end-to-end
cd end-to-end

Running from locally built binary

make TAGS='bindata sqlite sqlite_unlock_notify' generate forgejo
cp -a forgejo /srv/forgejo-binaries/forgejo-7.0-dev

It will be used whenever the version 7.0-dev is specified in a test.

Running actions locally

To run and debug workflows from actions/example-*, from the root of the source directory, with docker and forgejo-curl.sh installed, mimic what .forgejo/workflows/actions.yml does. There may be some manual tweaking (such as creating temporary directories) because the tests run as root in the context of Forgejo Actions and assume they have admin permissions. But they do not need to run as root and must work fine when run as a regular user.

./end-to-end.sh actions_setup 1.21
firefox 0.0.0.0:3000 # user root / admin1234
./end-to-end.sh actions_verify_example artifacts
./end-to-end.sh actions_teardown

Running other tests locally

To run and debug tests, from the root of the source directory.

Run one test. When the test fails the instance can be inspected at http://0.0.0.0:3000

./end-to-end.sh test_packages_alpine
./end-to-end.sh test_storage_stable_s3 minio

Cleanup. It will teardown the Forgejo instance.

./end-to-end.sh stop