gitpod/test/tests/components/server/server_test.go
2022-11-10 09:03:45 +01:00

109 lines
3.0 KiB
Go

// Copyright (c) 2020 Gitpod GmbH. All rights reserved.
// Licensed under the GNU Affero General Public License (AGPL).
// See License-AGPL.txt in the project root for license information.
package server
import (
"context"
"testing"
"time"
"sigs.k8s.io/e2e-framework/pkg/envconf"
"sigs.k8s.io/e2e-framework/pkg/features"
protocol "github.com/gitpod-io/gitpod/gitpod-protocol"
"github.com/gitpod-io/gitpod/test/pkg/integration"
)
func TestServerAccess(t *testing.T) {
f := features.New("GetLoggedInUser").
WithLabel("component", "server").
Assess("it can get a not built-in logged user", func(_ context.Context, t *testing.T, cfg *envconf.Config) context.Context {
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Minute)
defer cancel()
api := integration.NewComponentAPI(ctx, cfg.Namespace(), kubeconfig, cfg.Client())
t.Cleanup(func() {
api.Done(t)
})
username := integration.EnsureUserExists(t, username, api)
server, err := api.GitpodServer(integration.WithGitpodUser(username))
if err != nil {
t.Fatalf("cannot get GitpodServer: %q", err)
}
_, err = server.GetLoggedInUser(ctx)
if err != nil {
t.Fatal(err)
}
return ctx
}).
Feature()
testEnv.Test(t, f)
}
func TestStartWorkspace(t *testing.T) {
integration.SkipWithoutUsername(t, username)
f := features.New("CreateWorkspace").
WithLabel("component", "server").
Assess("it can run workspace tasks", func(_ context.Context, t *testing.T, cfg *envconf.Config) context.Context {
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Minute)
defer cancel()
api := integration.NewComponentAPI(ctx, cfg.Namespace(), kubeconfig, cfg.Client())
t.Cleanup(func() {
api.Done(t)
})
server, err := api.GitpodServer(integration.WithGitpodUser(username))
if err != nil {
t.Fatalf("cannot get GitpodServer: %q", err)
}
resp, err := server.CreateWorkspace(ctx, &protocol.CreateWorkspaceOptions{
ContextURL: "github.com/gitpod-io/gitpod",
IgnoreRunningPrebuild: true,
IgnoreRunningWorkspaceOnSameCommit: true,
})
if err != nil {
t.Fatalf("cannot start workspace: %q", err)
}
t.Cleanup(func() {
cctx, ccancel := context.WithTimeout(context.Background(), 10*time.Second)
err := server.StopWorkspace(cctx, resp.CreatedWorkspaceID)
ccancel()
if err != nil {
t.Logf("cannot stop workspace: %q", err)
}
})
t.Logf("created workspace: workspaceID=%s url=%s", resp.CreatedWorkspaceID, resp.WorkspaceURL)
nfo, err := server.GetWorkspace(ctx, resp.CreatedWorkspaceID)
if err != nil {
t.Fatalf("cannot get workspace: %q", err)
}
if nfo.LatestInstance == nil {
t.Fatal("CreateWorkspace did not start the workspace")
}
_, err = integration.WaitForWorkspaceStart(ctx, nfo.LatestInstance.ID, api)
if err != nil {
t.Fatalf("cannot get workspace: %q", err)
}
t.Logf("workspace is running: instanceID=%s", nfo.LatestInstance.ID)
return ctx
}).
Feature()
testEnv.Test(t, f)
}