1
0
mirror of https://github.com/juanfont/headscale.git synced 2025-12-09 20:04:54 +01:00
juanfont.headscale/integration
Kristoffer Dalby 22ee2bfc9c
tags: process tags on registration, simplify policy (#2931)
This PR investigates, adds tests and aims to correctly implement Tailscale's model for how Tags should be accepted, assigned and used to identify nodes in the Tailscale access and ownership model.

When evaluating in Headscale's policy, Tags are now only checked against a nodes "tags" list, which defines the source of truth for all tags for a given node. This simplifies the code for dealing with tags greatly, and should help us have less access bugs related to nodes belonging to tags or users.

A node can either be owned by a user, or a tag.

Next, to ensure the tags list on the node is correctly implemented, we first add tests for every registration scenario and combination of user, pre auth key and pre auth key with tags with the same registration expectation as observed by trying them all with the Tailscale control server. This should ensure that we implement the correct behaviour and that it does not change or break over time.

Lastly, the missing parts of the auth has been added, or changed in the cases where it was wrong. This has in large parts allowed us to delete and simplify a lot of code.
Now, tags can only be changed when a node authenticates or if set via the CLI/API. Tags can only be fully overwritten/replaced and any use of either auth or CLI will replace the current set if different.

A user owned device can be converted to a tagged device, but it cannot be changed back. A tagged device can never remove the last tag either, it has to have a minimum of one.
2025-12-08 18:51:07 +01:00
..
dockertestutil cmd/hi: improve test cleanup to reduce CI disk usage (#2881) 2025-11-28 16:59:54 +01:00
dsic integration: replace time.Sleep with assert.EventuallyWithT (#2680) 2025-07-10 23:38:55 +02:00
hsic tags: process tags on registration, simplify policy (#2931) 2025-12-08 18:51:07 +01:00
integrationutil lint and leftover 2025-09-09 09:40:00 +02:00
tsic cmd/hi: improve test cleanup to reduce CI disk usage (#2881) 2025-11-28 16:59:54 +01:00
acl_test.go tags: process tags on registration, simplify policy (#2931) 2025-12-08 18:51:07 +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 hscontrol/oidc: fix ACL policy not applied to new OIDC nodes (#2890) 2025-12-02 12:01:02 +01:00
auth_oidc_test.go hscontrol/oidc: fix ACL policy not applied to new OIDC nodes (#2890) 2025-12-02 12:01:02 +01: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 tags: process tags on registration, simplify policy (#2931) 2025-12-08 18:51:07 +01:00
control.go tags: process tags on registration, simplify policy (#2931) 2025-12-08 18:51:07 +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 stability and race conditions in auth and node store (#2781) 2025-10-16 12:17:43 +02:00
embedded_derp_test.go stability and race conditions in auth and node store (#2781) 2025-10-16 12:17:43 +02:00
general_test.go expire nodes with a custom timestamp (#2828) 2025-11-01 08:09:13 +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 tags: process tags on registration, simplify policy (#2931) 2025-12-08 18:51:07 +01:00
run.sh Fix 764 (#2093) 2024-09-03 09:22:17 +02:00
scenario_test.go stability and race conditions in auth and node store (#2781) 2025-10-16 12:17:43 +02:00
scenario.go tags: process tags on registration, simplify policy (#2931) 2025-12-08 18:51:07 +01:00
ssh_test.go add health command (#2659) 2025-10-16 12:00:11 +00:00
tags_test.go tags: process tags on registration, simplify policy (#2931) 2025-12-08 18:51:07 +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.