package integration import ( "testing" "github.com/juanfont/headscale/integration/dockertestutil" ) // This file is intended to "test the test framework", by proxy it will also test // some Headcsale/Tailscale stuff, but mostly in very simple ways. func IntegrationSkip(t *testing.T) { t.Helper() if !dockertestutil.IsRunningInContainer() { t.Skip("not running in docker, skipping") } if testing.Short() { t.Skip("skipping integration tests due to short flag") } } // If subtests are parallel, then they will start before setup is run. // This might mean we approach setup slightly wrong, but for now, ignore // the linter // nolint:tparallel func TestHeadscale(t *testing.T) { IntegrationSkip(t) t.Parallel() var err error user := "test-space" scenario, err := NewScenario() assertNoErr(t, err) defer scenario.Shutdown() t.Run("start-headscale", func(t *testing.T) { headscale, err := scenario.Headscale() if err != nil { t.Fatalf("failed to create start headcale: %s", err) } err = headscale.WaitForRunning() if err != nil { t.Fatalf("headscale failed to become ready: %s", err) } }) t.Run("create-user", func(t *testing.T) { err := scenario.CreateUser(user) if err != nil { t.Fatalf("failed to create user: %s", err) } if _, ok := scenario.users[user]; !ok { t.Fatalf("user is not in scenario") } }) t.Run("create-auth-key", func(t *testing.T) { _, err := scenario.CreatePreAuthKey(user, true, false) if err != nil { t.Fatalf("failed to create preauthkey: %s", err) } }) } // If subtests are parallel, then they will start before setup is run. // This might mean we approach setup slightly wrong, but for now, ignore // the linter // nolint:tparallel func TestCreateTailscale(t *testing.T) { IntegrationSkip(t) t.Parallel() user := "only-create-containers" scenario, err := NewScenario() assertNoErr(t, err) defer scenario.Shutdown() scenario.users[user] = &User{ Clients: make(map[string]TailscaleClient), } t.Run("create-tailscale", func(t *testing.T) { err := scenario.CreateTailscaleNodesInUser(user, "all", 3) if err != nil { t.Fatalf("failed to add tailscale nodes: %s", err) } if clients := len(scenario.users[user].Clients); clients != 3 { t.Fatalf("wrong number of tailscale clients: %d != %d", clients, 3) } // TODO(kradalby): Test "all" version logic }) } // If subtests are parallel, then they will start before setup is run. // This might mean we approach setup slightly wrong, but for now, ignore // the linter // nolint:tparallel func TestTailscaleNodesJoiningHeadcale(t *testing.T) { IntegrationSkip(t) t.Parallel() var err error user := "join-node-test" count := 1 scenario, err := NewScenario() assertNoErr(t, err) defer scenario.Shutdown() t.Run("start-headscale", func(t *testing.T) { headscale, err := scenario.Headscale() if err != nil { t.Fatalf("failed to create start headcale: %s", err) } err = headscale.WaitForRunning() if err != nil { t.Fatalf("headscale failed to become ready: %s", err) } }) t.Run("create-user", func(t *testing.T) { err := scenario.CreateUser(user) if err != nil { t.Fatalf("failed to create user: %s", err) } if _, ok := scenario.users[user]; !ok { t.Fatalf("user is not in scenario") } }) t.Run("create-tailscale", func(t *testing.T) { err := scenario.CreateTailscaleNodesInUser(user, "unstable", count) if err != nil { t.Fatalf("failed to add tailscale nodes: %s", err) } if clients := len(scenario.users[user].Clients); clients != count { t.Fatalf("wrong number of tailscale clients: %d != %d", clients, count) } }) t.Run("join-headscale", func(t *testing.T) { key, err := scenario.CreatePreAuthKey(user, true, false) if err != nil { t.Fatalf("failed to create preauthkey: %s", err) } headscale, err := scenario.Headscale() if err != nil { t.Fatalf("failed to create start headcale: %s", err) } err = scenario.RunTailscaleUp( user, headscale.GetEndpoint(), key.GetKey(), ) if err != nil { t.Fatalf("failed to login: %s", err) } }) t.Run("get-ips", func(t *testing.T) { ips, err := scenario.GetIPs(user) if err != nil { t.Fatalf("failed to get tailscale ips: %s", err) } if len(ips) != count*2 { t.Fatalf("got the wrong amount of tailscale ips, %d != %d", len(ips), count*2) } }) }