mirror of
https://github.com/juanfont/headscale.git
synced 2025-01-19 02:10:04 +09:00
edf9e25001
* feat: support client verify for derp * docs: fix doc for integration test * tests: add integration test for DERP verify endpoint * tests: use `tailcfg.DERPMap` instead of `[]byte` * refactor: introduce func `ContainsNodeKey` * tests(dsic): use string builder for cmd args * ci: fix tests order * tests: fix derper failure * chore: cleanup * tests(verify-client): perfer to use `CreateHeadscaleEnv` * refactor(verify-client): simplify error handling * tests: fix `TestDERPVerifyEndpoint` * refactor: make `doVerify` a seperated func --------- Co-authored-by: 117503445 <t117503445@gmail.com>
25 lines
966 B
Markdown
25 lines
966 B
Markdown
# 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](https://github.com/nektos/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.
|