2022-10-13 10:03:38 -04:00
|
|
|
package integration
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2022-10-14 04:37:13 -04:00
|
|
|
"github.com/juanfont/headscale/integration/dockertestutil"
|
2022-10-13 10:03:38 -04:00
|
|
|
)
|
|
|
|
|
2022-11-08 16:33:11 -05:00
|
|
|
// This file is intended to "test the test framework", by proxy it will also test
|
2024-09-11 12:43:59 -04:00
|
|
|
// some Headscale/Tailscale stuff, but mostly in very simple ways.
|
2022-10-14 06:23:35 -04:00
|
|
|
|
2022-10-14 04:37:13 -04:00
|
|
|
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")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-01 08:01:06 -05:00
|
|
|
// 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
|
2022-10-13 10:03:38 -04:00
|
|
|
func TestHeadscale(t *testing.T) {
|
2022-10-14 04:37:13 -04:00
|
|
|
IntegrationSkip(t)
|
2022-11-22 06:05:58 -05:00
|
|
|
t.Parallel()
|
2022-10-14 06:18:28 -04:00
|
|
|
|
2022-10-13 10:03:38 -04:00
|
|
|
var err error
|
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
user := "test-space"
|
2022-10-14 06:38:34 -04:00
|
|
|
|
2024-04-21 12:28:17 -04:00
|
|
|
scenario, err := NewScenario(dockertestMaxWait())
|
2023-08-29 02:33:33 -04:00
|
|
|
assertNoErr(t, err)
|
2024-09-17 05:44:55 -04:00
|
|
|
defer scenario.ShutdownAssertNoPanics(t)
|
2022-10-13 10:03:38 -04:00
|
|
|
|
|
|
|
t.Run("start-headscale", func(t *testing.T) {
|
2022-11-14 08:27:02 -05:00
|
|
|
headscale, err := scenario.Headscale()
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to create start headcale: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
|
2023-08-29 02:33:33 -04:00
|
|
|
err = headscale.WaitForRunning()
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("headscale failed to become ready: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
t.Run("create-user", func(t *testing.T) {
|
|
|
|
err := scenario.CreateUser(user)
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to create user: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
if _, ok := scenario.users[user]; !ok {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("user is not in scenario")
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("create-auth-key", func(t *testing.T) {
|
2023-01-17 11:43:44 -05:00
|
|
|
_, err := scenario.CreatePreAuthKey(user, true, false)
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to create preauthkey: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-12-01 08:01:06 -05:00
|
|
|
// 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
|
2022-10-13 10:03:38 -04:00
|
|
|
func TestCreateTailscale(t *testing.T) {
|
2022-10-14 04:37:13 -04:00
|
|
|
IntegrationSkip(t)
|
2022-11-22 06:05:58 -05:00
|
|
|
t.Parallel()
|
2022-10-14 04:37:13 -04:00
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
user := "only-create-containers"
|
2022-10-13 10:03:38 -04:00
|
|
|
|
2024-04-21 12:28:17 -04:00
|
|
|
scenario, err := NewScenario(dockertestMaxWait())
|
2023-08-29 02:33:33 -04:00
|
|
|
assertNoErr(t, err)
|
2024-09-17 05:44:55 -04:00
|
|
|
defer scenario.ShutdownAssertNoPanics(t)
|
2022-10-13 10:03:38 -04:00
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
scenario.users[user] = &User{
|
2022-10-21 07:17:54 -04:00
|
|
|
Clients: make(map[string]TailscaleClient),
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
t.Run("create-tailscale", func(t *testing.T) {
|
2023-01-17 11:43:44 -05:00
|
|
|
err := scenario.CreateTailscaleNodesInUser(user, "all", 3)
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to add tailscale nodes: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
if clients := len(scenario.users[user].Clients); clients != 3 {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("wrong number of tailscale clients: %d != %d", clients, 3)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
2022-10-18 05:59:28 -04:00
|
|
|
|
|
|
|
// TODO(kradalby): Test "all" version logic
|
2022-10-13 10:03:38 -04:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-12-01 08:01:06 -05:00
|
|
|
// 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
|
2022-10-13 10:03:38 -04:00
|
|
|
func TestTailscaleNodesJoiningHeadcale(t *testing.T) {
|
2022-10-14 04:37:13 -04:00
|
|
|
IntegrationSkip(t)
|
2022-11-22 06:05:58 -05:00
|
|
|
t.Parallel()
|
2022-10-14 04:37:13 -04:00
|
|
|
|
2022-10-13 10:03:38 -04:00
|
|
|
var err error
|
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
user := "join-node-test"
|
2022-10-13 10:03:38 -04:00
|
|
|
|
2022-10-14 06:18:28 -04:00
|
|
|
count := 1
|
|
|
|
|
2024-04-21 12:28:17 -04:00
|
|
|
scenario, err := NewScenario(dockertestMaxWait())
|
2023-08-29 02:33:33 -04:00
|
|
|
assertNoErr(t, err)
|
2024-09-17 05:44:55 -04:00
|
|
|
defer scenario.ShutdownAssertNoPanics(t)
|
2022-10-13 10:03:38 -04:00
|
|
|
|
|
|
|
t.Run("start-headscale", func(t *testing.T) {
|
2022-11-14 08:27:02 -05:00
|
|
|
headscale, err := scenario.Headscale()
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to create start headcale: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
|
2023-08-29 02:33:33 -04:00
|
|
|
err = headscale.WaitForRunning()
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("headscale failed to become ready: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
t.Run("create-user", func(t *testing.T) {
|
|
|
|
err := scenario.CreateUser(user)
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to create user: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
if _, ok := scenario.users[user]; !ok {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("user is not in scenario")
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("create-tailscale", func(t *testing.T) {
|
2024-01-05 04:41:56 -05:00
|
|
|
err := scenario.CreateTailscaleNodesInUser(user, "unstable", count)
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to add tailscale nodes: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
|
2023-01-17 11:43:44 -05:00
|
|
|
if clients := len(scenario.users[user].Clients); clients != count {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("wrong number of tailscale clients: %d != %d", clients, count)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("join-headscale", func(t *testing.T) {
|
2023-01-17 11:43:44 -05:00
|
|
|
key, err := scenario.CreatePreAuthKey(user, true, false)
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to create preauthkey: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
|
|
|
|
2022-11-14 08:27:02 -05:00
|
|
|
headscale, err := scenario.Headscale()
|
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to create start headcale: %s", err)
|
2022-11-14 08:27:02 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
err = scenario.RunTailscaleUp(
|
2023-01-17 11:43:44 -05:00
|
|
|
user,
|
2022-11-14 08:27:02 -05:00
|
|
|
headscale.GetEndpoint(),
|
|
|
|
key.GetKey(),
|
|
|
|
)
|
2022-10-13 10:03:38 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to login: %s", err)
|
2022-10-13 10:03:38 -04:00
|
|
|
}
|
2022-10-14 06:18:28 -04:00
|
|
|
})
|
2022-10-13 10:03:38 -04:00
|
|
|
|
2022-10-14 06:18:28 -04:00
|
|
|
t.Run("get-ips", func(t *testing.T) {
|
2023-01-17 11:43:44 -05:00
|
|
|
ips, err := scenario.GetIPs(user)
|
2022-10-14 06:18:28 -04:00
|
|
|
if err != nil {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("failed to get tailscale ips: %s", err)
|
2022-10-14 06:18:28 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(ips) != count*2 {
|
2023-08-29 02:33:33 -04:00
|
|
|
t.Fatalf("got the wrong amount of tailscale ips, %d != %d", len(ips), count*2)
|
2022-10-14 06:18:28 -04:00
|
|
|
}
|
2022-10-13 10:03:38 -04:00
|
|
|
})
|
|
|
|
}
|