Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
gitpod-io
GitHub Repository: gitpod-io/gitpod
Path: blob/main/test/tests/workspace/k3s_test.go
2496 views
1
// Copyright (c) 2021 Gitpod GmbH. All rights reserved.
2
// Licensed under the GNU Affero General Public License (AGPL).
3
// See License.AGPL.txt in the project root for license information.
4
5
package workspace
6
7
import (
8
"context"
9
"fmt"
10
"testing"
11
"time"
12
13
"sigs.k8s.io/e2e-framework/pkg/envconf"
14
"sigs.k8s.io/e2e-framework/pkg/features"
15
16
agent "github.com/gitpod-io/gitpod/test/pkg/agent/workspace/api"
17
"github.com/gitpod-io/gitpod/test/pkg/integration"
18
)
19
20
const (
21
K3S_VERSION = "1.23.4"
22
TIME_OUT = 10 * time.Minute
23
)
24
25
func TestK3s(t *testing.T) {
26
f := features.New("k3s").
27
WithLabel("component", "workspace").
28
Assess("it should start a k3s", func(testCtx context.Context, t *testing.T, cfg *envconf.Config) context.Context {
29
t.Skip("k3s is currently not supported in workspaces")
30
t.Parallel()
31
32
ctx, cancel := context.WithTimeout(testCtx, TIME_OUT)
33
defer cancel()
34
35
api := integration.NewComponentAPI(ctx, cfg.Namespace(), kubeconfig, cfg.Client())
36
t.Cleanup(func() {
37
api.Done(t)
38
})
39
40
ws, stopWs, err := integration.LaunchWorkspaceDirectly(t, ctx, api)
41
if err != nil {
42
t.Fatal(err)
43
}
44
t.Cleanup(func() {
45
sctx, scancel := context.WithTimeout(context.Background(), 5*time.Minute)
46
defer scancel()
47
48
sapi := integration.NewComponentAPI(sctx, cfg.Namespace(), kubeconfig, cfg.Client())
49
defer sapi.Done(t)
50
51
_, err = stopWs(true, sapi)
52
if err != nil {
53
t.Fatal(err)
54
}
55
})
56
57
rsa, closer, err := integration.Instrument(integration.ComponentWorkspace, "workspace", cfg.Namespace(), kubeconfig, cfg.Client(), integration.WithInstanceID(ws.Req.Id), integration.WithWorkspacekitLift(true))
58
if err != nil {
59
t.Fatalf("unexpected error instrumenting workspace: %v", err)
60
}
61
defer rsa.Close()
62
integration.DeferCloser(t, closer)
63
64
cgv2, err := integration.IsCgroupV2(rsa)
65
if err != nil {
66
t.Fatalf("unexpected error checking cgroup v2: %v", err)
67
}
68
69
if !cgv2 {
70
t.Fatalf("This test only works for cgroup v2")
71
}
72
73
k3sExit := make(chan error, 1)
74
waitForK3s := make(chan error, 1)
75
go func() {
76
var respReadyForK3s agent.ExecResponse
77
k3sUrl := fmt.Sprintf("https://github.com/k3s-io/k3s/releases/download/v%s%%2Bk3s1/k3s", K3S_VERSION)
78
err = rsa.Call("WorkspaceAgent.Exec", &agent.ExecRequest{
79
Dir: "/",
80
Command: "bash",
81
Args: []string{
82
"-c",
83
fmt.Sprintf("curl -L %s -o /workspace/k3s && sudo chmod +x /workspace/k3s && sudo /workspace/k3s server -d /workspace/data --flannel-backend=host-gw", k3sUrl),
84
},
85
}, &respReadyForK3s)
86
k3sExit <- fmt.Errorf("k3s exited: %v\n%s\n%s", err, respReadyForK3s.Stdout, respReadyForK3s.Stderr)
87
}()
88
89
kubeEnv := []string{
90
"KUBECONFIG=/etc/rancher/k3s/k3s.yaml",
91
}
92
var respWaitForK3s agent.ExecResponse
93
timeout := fmt.Sprintf("%.0fm", TIME_OUT.Minutes())
94
go func() {
95
err = rsa.Call("WorkspaceAgent.Exec", &agent.ExecRequest{
96
Dir: "/",
97
Command: "bash",
98
Env: kubeEnv,
99
Args: []string{
100
"-c",
101
fmt.Sprintf("timeout %s bash -c 'while [ ! -e /etc/rancher/k3s/k3s.yaml ]; do sleep 1; done' && sudo chmod 777 /etc/rancher/k3s/k3s.yaml && timeout %s bash -c 'until /workspace/k3s kubectl wait --for=condition=Ready nodes -l node-role.kubernetes.io/master=true --timeout %s; do sleep 1; done'", timeout, timeout, timeout),
102
},
103
}, &respWaitForK3s)
104
if err != nil {
105
waitForK3s <- fmt.Errorf("failed to wait for starting k3s: %v\n%s\n%s", err, respWaitForK3s.Stdout, respWaitForK3s.Stderr)
106
return
107
}
108
109
if respWaitForK3s.ExitCode != 0 {
110
waitForK3s <- fmt.Errorf("failed to wait for starting k3s: %s\n%s", respWaitForK3s.Stdout, respWaitForK3s.Stderr)
111
return
112
}
113
waitForK3s <- nil
114
}()
115
116
select {
117
case err := <-waitForK3s:
118
if err != nil {
119
t.Fatalf("failed to wait for starting k3s: %v", err)
120
}
121
t.Logf("k3s is ready")
122
case err := <-k3sExit:
123
t.Fatalf("k3s exited: %v", err)
124
case <-time.After(TIME_OUT):
125
t.Fatalf("timeout waiting for k3s")
126
}
127
128
var respGetPods agent.ExecResponse
129
err = rsa.Call("WorkspaceAgent.Exec", &agent.ExecRequest{
130
Dir: "/",
131
Command: "bash",
132
Env: kubeEnv,
133
Args: []string{
134
"-c",
135
"/workspace/k3s kubectl get nodes",
136
},
137
}, &respGetPods)
138
if err != nil {
139
t.Fatalf("failed to get nodes: %v\n%s\n%s", err, respGetPods.Stdout, respGetPods.Stderr)
140
}
141
142
if respGetPods.ExitCode != 0 {
143
t.Fatalf("failed to get nodes: %s\n%s", respGetPods.Stdout, respGetPods.Stderr)
144
}
145
146
return testCtx
147
}).
148
Feature()
149
150
testEnv.Test(t, f)
151
}
152
153