2022-09-05 09:06:08 +02:00
|
|
|
/*
|
|
|
|
Copyright (c) Edgeless Systems GmbH
|
|
|
|
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2022-03-22 16:03:15 +01:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
2022-08-01 16:51:34 +02:00
|
|
|
"net/http"
|
2022-03-22 16:03:15 +01:00
|
|
|
"testing"
|
|
|
|
|
2022-06-07 11:08:44 +02:00
|
|
|
"github.com/edgelesssys/constellation/internal/cloud/cloudprovider"
|
2022-06-08 08:17:52 +02:00
|
|
|
"github.com/edgelesssys/constellation/internal/cloud/cloudtypes"
|
2022-03-22 16:03:15 +01:00
|
|
|
"github.com/edgelesssys/constellation/internal/state"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
2022-06-30 15:24:36 +02:00
|
|
|
"go.uber.org/goleak"
|
2022-08-01 16:51:34 +02:00
|
|
|
"google.golang.org/api/googleapi"
|
2022-03-22 16:03:15 +01:00
|
|
|
)
|
|
|
|
|
2022-06-30 15:24:36 +02:00
|
|
|
func TestMain(m *testing.M) {
|
|
|
|
goleak.VerifyTestMain(m,
|
|
|
|
// https://github.com/census-instrumentation/opencensus-go/issues/1262
|
|
|
|
goleak.IgnoreTopFunction("go.opencensus.io/stats/view.(*worker).start"),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-03-22 16:03:15 +01:00
|
|
|
func TestSetGetState(t *testing.T) {
|
2022-08-01 12:35:35 +02:00
|
|
|
state := state.ConstellationState{
|
|
|
|
CloudProvider: cloudprovider.GCP.String(),
|
2022-07-29 08:10:51 +02:00
|
|
|
GCPWorkerInstances: cloudtypes.Instances{
|
2022-03-22 16:03:15 +01:00
|
|
|
"id-1": {
|
|
|
|
PublicIP: "ip1",
|
|
|
|
PrivateIP: "ip2",
|
|
|
|
},
|
|
|
|
},
|
2022-07-29 08:10:51 +02:00
|
|
|
GCPControlPlaneInstances: cloudtypes.Instances{
|
2022-03-22 16:03:15 +01:00
|
|
|
"id-1": {
|
|
|
|
PublicIP: "ip3",
|
|
|
|
PrivateIP: "ip4",
|
|
|
|
},
|
|
|
|
},
|
2022-06-29 15:26:29 +02:00
|
|
|
GCPWorkerInstanceGroup: "group-id",
|
|
|
|
GCPControlPlaneInstanceGroup: "group-id",
|
|
|
|
GCPProject: "proj-id",
|
|
|
|
GCPZone: "zone-id",
|
|
|
|
GCPRegion: "region-id",
|
|
|
|
Name: "name",
|
|
|
|
UID: "uid",
|
2022-08-01 16:51:34 +02:00
|
|
|
LoadBalancerIP: "ip5",
|
2022-06-29 15:26:29 +02:00
|
|
|
GCPNetwork: "net-id",
|
|
|
|
GCPSubnetwork: "subnet-id",
|
|
|
|
GCPFirewalls: []string{"fw-1", "fw-2"},
|
|
|
|
GCPWorkerInstanceTemplate: "temp-id",
|
|
|
|
GCPControlPlaneInstanceTemplate: "temp-id",
|
2022-08-01 16:51:34 +02:00
|
|
|
GCPLoadbalancers: []string{"lb-1", "lb-2"},
|
2022-03-22 16:03:15 +01:00
|
|
|
}
|
2022-08-01 12:35:35 +02:00
|
|
|
|
|
|
|
t.Run("SetState", func(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
|
|
|
|
client := Client{}
|
|
|
|
client.SetState(state)
|
|
|
|
assert.Equal(state.GCPWorkerInstances, client.workers)
|
|
|
|
assert.Equal(state.GCPControlPlaneInstances, client.controlPlanes)
|
|
|
|
assert.Equal(state.GCPWorkerInstanceGroup, client.workerInstanceGroup)
|
|
|
|
assert.Equal(state.GCPControlPlaneInstanceGroup, client.controlPlaneInstanceGroup)
|
|
|
|
assert.Equal(state.GCPProject, client.project)
|
|
|
|
assert.Equal(state.GCPZone, client.zone)
|
|
|
|
assert.Equal(state.Name, client.name)
|
|
|
|
assert.Equal(state.UID, client.uid)
|
|
|
|
assert.Equal(state.GCPNetwork, client.network)
|
|
|
|
assert.Equal(state.GCPFirewalls, client.firewalls)
|
|
|
|
assert.Equal(state.GCPControlPlaneInstanceTemplate, client.controlPlaneTemplate)
|
|
|
|
assert.Equal(state.GCPWorkerInstanceTemplate, client.workerTemplate)
|
2022-08-01 16:51:34 +02:00
|
|
|
assert.Equal(state.LoadBalancerIP, client.loadbalancerIP)
|
|
|
|
for _, lb := range client.loadbalancers {
|
|
|
|
assert.Contains(state.GCPLoadbalancers, lb.name)
|
|
|
|
assert.True(lb.hasBackendService)
|
|
|
|
assert.True(lb.hasHealthCheck)
|
|
|
|
assert.True(lb.hasForwardingRules)
|
|
|
|
}
|
2022-08-01 12:35:35 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("GetState", func(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
|
|
|
|
client := Client{
|
|
|
|
workers: state.GCPWorkerInstances,
|
|
|
|
controlPlanes: state.GCPControlPlaneInstances,
|
|
|
|
workerInstanceGroup: state.GCPWorkerInstanceGroup,
|
|
|
|
controlPlaneInstanceGroup: state.GCPControlPlaneInstanceGroup,
|
|
|
|
project: state.GCPProject,
|
|
|
|
zone: state.GCPZone,
|
|
|
|
region: state.GCPRegion,
|
|
|
|
name: state.Name,
|
|
|
|
uid: state.UID,
|
|
|
|
network: state.GCPNetwork,
|
|
|
|
subnetwork: state.GCPSubnetwork,
|
|
|
|
firewalls: state.GCPFirewalls,
|
|
|
|
workerTemplate: state.GCPWorkerInstanceTemplate,
|
|
|
|
controlPlaneTemplate: state.GCPControlPlaneInstanceTemplate,
|
2022-08-01 16:51:34 +02:00
|
|
|
loadbalancerIP: state.LoadBalancerIP,
|
|
|
|
loadbalancerIPname: state.GCPLoadbalancerIPname,
|
|
|
|
}
|
|
|
|
for _, lbName := range state.GCPLoadbalancers {
|
|
|
|
client.loadbalancers = append(client.loadbalancers, &loadBalancer{name: lbName})
|
2022-08-01 12:35:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
stat := client.GetState()
|
|
|
|
|
|
|
|
assert.Equal(state, stat)
|
|
|
|
})
|
2022-03-22 16:03:15 +01:00
|
|
|
}
|
|
|
|
|
2022-08-05 12:18:26 +02:00
|
|
|
func TestBuildResourceName(t *testing.T) {
|
|
|
|
testCases := map[string]struct {
|
|
|
|
clientUID string
|
|
|
|
clientName string
|
|
|
|
names []string
|
|
|
|
wantName string
|
|
|
|
}{
|
|
|
|
"no names": {
|
|
|
|
clientUID: "uid",
|
|
|
|
clientName: "name",
|
|
|
|
wantName: "name-uid",
|
|
|
|
},
|
|
|
|
"one name": {
|
|
|
|
clientUID: "uid",
|
|
|
|
clientName: "name",
|
|
|
|
names: []string{"foo"},
|
|
|
|
wantName: "name-foo-uid",
|
|
|
|
},
|
|
|
|
"two names": {
|
|
|
|
clientUID: "uid",
|
|
|
|
clientName: "name",
|
|
|
|
names: []string{"foo", "bar"},
|
|
|
|
wantName: "name-foo-bar-uid",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for name, tc := range testCases {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
|
|
|
|
client := Client{
|
|
|
|
name: tc.clientName,
|
|
|
|
uid: tc.clientUID,
|
|
|
|
}
|
|
|
|
|
|
|
|
name := client.buildResourceName(tc.names...)
|
|
|
|
|
|
|
|
assert.Equal(tc.wantName, name)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-05 12:09:39 +02:00
|
|
|
func TestResourceURI(t *testing.T) {
|
|
|
|
testCases := map[string]struct {
|
|
|
|
scope resourceScope
|
|
|
|
resourceType string
|
|
|
|
resourceName string
|
|
|
|
wantURI string
|
|
|
|
}{
|
|
|
|
"global resource": {
|
|
|
|
scope: scopeGlobal,
|
|
|
|
resourceType: "healthChecks",
|
|
|
|
resourceName: "name",
|
|
|
|
wantURI: "https://www.googleapis.com/compute/v1/projects/project/global/healthChecks/name",
|
|
|
|
},
|
|
|
|
"regional resource": {
|
|
|
|
scope: scopeRegion,
|
|
|
|
resourceType: "healthChecks",
|
|
|
|
resourceName: "name",
|
|
|
|
wantURI: "https://www.googleapis.com/compute/v1/projects/project/regions/region/healthChecks/name",
|
|
|
|
},
|
|
|
|
"zonal resource": {
|
|
|
|
scope: scopeZone,
|
|
|
|
resourceType: "instanceGroups",
|
|
|
|
resourceName: "name",
|
|
|
|
wantURI: "https://www.googleapis.com/compute/v1/projects/project/zones/zone/instanceGroups/name",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for name, tc := range testCases {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
|
|
|
|
client := Client{
|
|
|
|
project: "project",
|
|
|
|
zone: "zone",
|
|
|
|
region: "region",
|
|
|
|
}
|
|
|
|
|
|
|
|
uri := client.resourceURI(tc.scope, tc.resourceType, tc.resourceName)
|
|
|
|
|
|
|
|
assert.Equal(tc.wantURI, uri)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-23 17:49:55 +02:00
|
|
|
func TestInit(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
require := require.New(t)
|
|
|
|
|
|
|
|
client := Client{}
|
|
|
|
require.NoError(client.init("project", "zone", "region", "name"))
|
|
|
|
assert.Equal("project", client.project)
|
|
|
|
assert.Equal("zone", client.zone)
|
|
|
|
assert.Equal("region", client.region)
|
|
|
|
assert.Equal("name", client.name)
|
|
|
|
}
|
|
|
|
|
2022-03-22 16:03:15 +01:00
|
|
|
func TestCloseAll(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
|
|
|
|
closers := []closer{&someCloser{}, &someCloser{}, &someCloser{}}
|
|
|
|
assert.NoError(closeAll(closers))
|
|
|
|
for _, c := range closers {
|
|
|
|
assert.True(c.(*someCloser).closed)
|
|
|
|
}
|
|
|
|
|
|
|
|
someErr := errors.New("failed")
|
|
|
|
closers = []closer{&someCloser{}, &someCloser{closeErr: someErr}, &someCloser{}}
|
|
|
|
assert.Error(closeAll(closers))
|
|
|
|
for _, c := range closers {
|
|
|
|
assert.True(c.(*someCloser).closed)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type someCloser struct {
|
|
|
|
closeErr error
|
|
|
|
closed bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *someCloser) Close() error {
|
|
|
|
c.closed = true
|
|
|
|
return c.closeErr
|
|
|
|
}
|
2022-08-01 16:51:34 +02:00
|
|
|
|
|
|
|
func TestIsNotFoundError(t *testing.T) {
|
|
|
|
testCases := map[string]struct {
|
|
|
|
err error
|
|
|
|
result bool
|
|
|
|
}{
|
|
|
|
"not found error": {err: &googleapi.Error{Code: http.StatusNotFound}, result: true},
|
|
|
|
"nil error": {err: nil, result: false},
|
|
|
|
"other error": {err: errors.New("failed"), result: false},
|
|
|
|
}
|
|
|
|
|
|
|
|
for name, tc := range testCases {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
assert := assert.New(t)
|
|
|
|
assert.Equal(tc.result, isNotFoundError(tc.err))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|