mirror of
https://github.com/edgelesssys/constellation.git
synced 2024-12-26 16:09:45 -05:00
26e9c67a00
Decouples cloud provider metadata packages from kubernetes related code Signed-off-by: Malte Poll <mp@edgeless.systems>
145 lines
3.9 KiB
Go
145 lines
3.9 KiB
Go
package gcp
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"testing"
|
|
|
|
"github.com/edgelesssys/constellation/internal/cloud/metadata"
|
|
"github.com/edgelesssys/constellation/internal/gcpshared"
|
|
"github.com/edgelesssys/constellation/internal/kubernetes"
|
|
"github.com/edgelesssys/constellation/internal/versions"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
k8s "k8s.io/api/core/v1"
|
|
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
)
|
|
|
|
func TestConfigMaps(t *testing.T) {
|
|
testCases := map[string]struct {
|
|
instance metadata.InstanceMetadata
|
|
wantConfigMaps kubernetes.ConfigMaps
|
|
wantErr bool
|
|
}{
|
|
"ConfigMaps works": {
|
|
instance: metadata.InstanceMetadata{ProviderID: "gce://project-id/zone/instanceName-UID-0", Name: "instanceName-UID-0"},
|
|
wantConfigMaps: kubernetes.ConfigMaps{
|
|
&k8s.ConfigMap{
|
|
TypeMeta: v1.TypeMeta{
|
|
Kind: "ConfigMap",
|
|
APIVersion: "v1",
|
|
},
|
|
ObjectMeta: v1.ObjectMeta{
|
|
Name: "gceconf",
|
|
Namespace: "kube-system",
|
|
},
|
|
Data: map[string]string{
|
|
"gce.conf": `[global]
|
|
project-id = project-id
|
|
use-metadata-server = true
|
|
node-tags = constellation-UID
|
|
`,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
"invalid providerID fails": {
|
|
instance: metadata.InstanceMetadata{ProviderID: "invalid"},
|
|
wantErr: true,
|
|
},
|
|
}
|
|
|
|
for name, tc := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
assert := assert.New(t)
|
|
require := require.New(t)
|
|
|
|
cloud := CloudControllerManager{}
|
|
configMaps, err := cloud.ConfigMaps(tc.instance)
|
|
|
|
if tc.wantErr {
|
|
assert.Error(err)
|
|
return
|
|
}
|
|
require.NoError(err)
|
|
assert.Equal(tc.wantConfigMaps, configMaps)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestSecrets(t *testing.T) {
|
|
serviceAccountKey := gcpshared.ServiceAccountKey{
|
|
Type: "type",
|
|
ProjectID: "project-id",
|
|
PrivateKeyID: "private-key-id",
|
|
PrivateKey: "private-key",
|
|
ClientEmail: "client-email",
|
|
ClientID: "client-id",
|
|
AuthURI: "auth-uri",
|
|
TokenURI: "token-uri",
|
|
AuthProviderX509CertURL: "auth-provider-x509-cert-url",
|
|
ClientX509CertURL: "client-x509-cert-url",
|
|
}
|
|
rawKey, err := json.Marshal(serviceAccountKey)
|
|
require.NoError(t, err)
|
|
testCases := map[string]struct {
|
|
instance metadata.InstanceMetadata
|
|
cloudServiceAccountURI string
|
|
wantSecrets kubernetes.Secrets
|
|
wantErr bool
|
|
}{
|
|
"Secrets works": {
|
|
cloudServiceAccountURI: "serviceaccount://gcp?type=type&project_id=project-id&private_key_id=private-key-id&private_key=private-key&client_email=client-email&client_id=client-id&auth_uri=auth-uri&token_uri=token-uri&auth_provider_x509_cert_url=auth-provider-x509-cert-url&client_x509_cert_url=client-x509-cert-url",
|
|
wantSecrets: kubernetes.Secrets{
|
|
&k8s.Secret{
|
|
TypeMeta: v1.TypeMeta{
|
|
Kind: "Secret",
|
|
APIVersion: "v1",
|
|
},
|
|
ObjectMeta: v1.ObjectMeta{
|
|
Name: "gcekey",
|
|
Namespace: "kube-system",
|
|
},
|
|
Data: map[string][]byte{
|
|
"key.json": rawKey,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
"invalid serviceAccountKey fails": {
|
|
cloudServiceAccountURI: "invalid",
|
|
wantErr: true,
|
|
},
|
|
}
|
|
|
|
for name, tc := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
assert := assert.New(t)
|
|
require := require.New(t)
|
|
|
|
cloud := CloudControllerManager{}
|
|
secrets, err := cloud.Secrets(context.Background(), tc.instance.ProviderID, tc.cloudServiceAccountURI)
|
|
if tc.wantErr {
|
|
assert.Error(err)
|
|
return
|
|
}
|
|
require.NoError(err)
|
|
assert.Equal(tc.wantSecrets, secrets)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestTrivialCCMFunctions(t *testing.T) {
|
|
assert := assert.New(t)
|
|
cloud := CloudControllerManager{}
|
|
|
|
assert.NotEmpty(cloud.Image(versions.Latest))
|
|
assert.NotEmpty(cloud.Path())
|
|
assert.NotEmpty(cloud.Name())
|
|
assert.NotEmpty(cloud.ExtraArgs())
|
|
assert.NotEmpty(cloud.Volumes())
|
|
assert.NotEmpty(cloud.VolumeMounts())
|
|
assert.NotEmpty(cloud.Env())
|
|
assert.True(cloud.Supported())
|
|
}
|