headscale/integration
Kristoffer Dalby b3c4d0ec81
Some checks are pending
Build / build-nix (push) Waiting to run
Build / build-cross (GOARCH=amd64 GOOS=darwin) (push) Waiting to run
Build / build-cross (GOARCH=amd64 GOOS=linux) (push) Waiting to run
Build / build-cross (GOARCH=arm64 GOOS=darwin) (push) Waiting to run
Build / build-cross (GOARCH=arm64 GOOS=linux) (push) Waiting to run
Check Generated Files / check-generated (push) Waiting to run
NixOS Module Tests / nix-module-check (push) Waiting to run
Tests / test (push) Waiting to run
integration: add tests for API key expire/delete by ID
Extend TestApiKeyCommand to test the new --id flag for expire and
delete commands, verifying that API keys can be managed by their
database ID in addition to the existing --prefix method.

Updates #2986
2026-01-20 17:13:38 +01:00
..
dockertestutil cmd/hi: improve test cleanup to reduce CI disk usage (#2881) 2025-11-28 16:59:54 +01:00
dsic integration: add run ID isolation for concurrent test execution 2026-01-09 12:34:16 +01:00
hsic integration: add tests for ACL group with deleted/unknown users 2026-01-20 15:41:19 +01:00
integrationutil lint and leftover 2025-09-09 09:40:00 +02:00
tsic integration: add run ID isolation for concurrent test execution 2026-01-09 12:34:16 +01:00
acl_test.go state: add unit test for DeleteUser change signal 2026-01-20 15:41:19 +01:00
api_auth_test.go modernize: run gopls modernize to bring up to 1.25 (#2920) 2025-12-01 19:40:25 +01:00
auth_key_test.go integration: update CLI tests for ID-based preauthkey commands 2026-01-20 12:53:20 +01:00
auth_oidc_test.go golangci-lint: use forbidigo to block time.Sleep (#2946) 2025-12-10 16:45:59 +00:00
auth_web_flow_test.go stability and race conditions in auth and node store (#2781) 2025-10-16 12:17:43 +02:00
cli_test.go integration: add tests for API key expire/delete by ID 2026-01-20 17:13:38 +01:00
control.go integration: add tests for ACL group with deleted/unknown users 2026-01-20 15:41:19 +01:00
derp_verify_endpoint_test.go stability and race conditions in auth and node store (#2781) 2025-10-16 12:17:43 +02:00
dns_test.go integration: make entrypoint override more robust 2025-12-16 10:12:36 +01:00
embedded_derp_test.go golangci-lint: use forbidigo to block time.Sleep (#2946) 2025-12-10 16:45:59 +00:00
general_test.go types: add option to disable taildrop, improve tests (#2955) 2025-12-12 11:35:16 +01:00
helpers.go modernize: run gopls modernize to bring up to 1.25 (#2920) 2025-12-01 19:40:25 +01:00
README.md feat: support client verify for derp (add integration tests) (#2046) 2024-11-22 13:23:05 +01:00
route_test.go integration: prepare AutoApprove test for new tags 2025-12-17 09:32:05 +01:00
run.sh Fix 764 (#2093) 2024-09-03 09:22:17 +02:00
scenario.go integration: support auth keys without user 2026-01-20 12:53:20 +01:00
scenario_test.go stability and race conditions in auth and node store (#2781) 2025-10-16 12:17:43 +02:00
ssh_test.go integration: make entrypoint override more robust 2025-12-16 10:12:36 +01:00
tags_test.go integration: fix tags-only auth key tests 2026-01-20 12:53:20 +01:00
tailscale.go hscontrol/state: allow expired auth keys for node re-registration 2025-11-11 05:12:59 -06:00

Integration testing

Headscale relies on integration testing to ensure we remain compatible with Tailscale.

This is typically performed by starting a Headscale server and running a test "scenario" with an array of Tailscale clients and versions.

Headscale's test framework and the current set of scenarios are defined in this directory.

Tests are located in files ending with _test.go and the framework are located in the rest.

Running integration tests locally

The easiest way to run tests locally is to use act, a local GitHub Actions runner:

act pull_request -W .github/workflows/test-integration.yaml

Alternatively, the docker run command in each GitHub workflow file can be used.

Running integration tests on GitHub Actions

Each test currently runs as a separate workflows in GitHub actions, to add new test, run go generate inside ../cmd/gh-action-integration-generator/ and commit the result.