mirror of https://github.com/kubernetes/kops.git
Test that AWS launch templates include wrong SG
This commit is contained in:
parent
2ccc6f4990
commit
c61311bff2
|
|
@ -39,5 +39,6 @@ go_test(
|
||||||
"//pkg/testutils:go_default_library",
|
"//pkg/testutils:go_default_library",
|
||||||
"//upup/pkg/fi:go_default_library",
|
"//upup/pkg/fi:go_default_library",
|
||||||
"//upup/pkg/fi/cloudup/awstasks:go_default_library",
|
"//upup/pkg/fi/cloudup/awstasks:go_default_library",
|
||||||
|
"//vendor/k8s.io/apimachinery/pkg/apis/meta/v1:go_default_library",
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
|
||||||
|
|
@ -17,8 +17,10 @@ limitations under the License.
|
||||||
package awsmodel
|
package awsmodel
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||||
"k8s.io/kops/pkg/apis/kops"
|
"k8s.io/kops/pkg/apis/kops"
|
||||||
"k8s.io/kops/pkg/model"
|
"k8s.io/kops/pkg/model"
|
||||||
"k8s.io/kops/pkg/model/iam"
|
"k8s.io/kops/pkg/model/iam"
|
||||||
|
|
@ -27,6 +29,10 @@ import (
|
||||||
"k8s.io/kops/upup/pkg/fi/cloudup/awstasks"
|
"k8s.io/kops/upup/pkg/fi/cloudup/awstasks"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
sshPublicKeyEntry = "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCySdqIU+FhCWl3BNrAvPaOe5VfL2aCARUWwy91ZP+T7LBwFa9lhdttfjp/VX1D1/PVwntn2EhN079m8c2kfdmiZ/iCHqrLyIGSd+BOiCz0lT47znvANSfxYjLUuKrWWWeaXqerJkOsAD4PHchRLbZGPdbfoBKwtb/WT4GMRQmb9vmiaZYjsfdPPM9KkWI9ECoWFGjGehA8D+iYIPR711kRacb1xdYmnjHqxAZHFsb5L8wDWIeAyhy49cBD+lbzTiioq2xWLorXuFmXh6Do89PgzvHeyCLY6816f/kCX6wIFts8A2eaEHFL4rAOsuh6qHmSxGCR9peSyuRW8DxV725x justin@test"
|
||||||
|
)
|
||||||
|
|
||||||
func buildMinimalCluster() *kops.Cluster {
|
func buildMinimalCluster() *kops.Cluster {
|
||||||
return testutils.BuildMinimalCluster("testcluster.test.com")
|
return testutils.BuildMinimalCluster("testcluster.test.com")
|
||||||
|
|
||||||
|
|
@ -48,7 +54,7 @@ func TestRootVolumeOptimizationFlag(t *testing.T) {
|
||||||
ig.Spec.RootVolumeOptimization = fi.Bool(true)
|
ig.Spec.RootVolumeOptimization = fi.Bool(true)
|
||||||
|
|
||||||
k := [][]byte{}
|
k := [][]byte{}
|
||||||
k = append(k, []byte("ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCySdqIU+FhCWl3BNrAvPaOe5VfL2aCARUWwy91ZP+T7LBwFa9lhdttfjp/VX1D1/PVwntn2EhN079m8c2kfdmiZ/iCHqrLyIGSd+BOiCz0lT47znvANSfxYjLUuKrWWWeaXqerJkOsAD4PHchRLbZGPdbfoBKwtb/WT4GMRQmb9vmiaZYjsfdPPM9KkWI9ECoWFGjGehA8D+iYIPR711kRacb1xdYmnjHqxAZHFsb5L8wDWIeAyhy49cBD+lbzTiioq2xWLorXuFmXh6Do89PgzvHeyCLY6816f/kCX6wIFts8A2eaEHFL4rAOsuh6qHmSxGCR9peSyuRW8DxV725x justin@test"))
|
k = append(k, []byte(sshPublicKeyEntry))
|
||||||
|
|
||||||
igs := []*kops.InstanceGroup{}
|
igs := []*kops.InstanceGroup{}
|
||||||
igs = append(igs, ig)
|
igs = append(igs, ig)
|
||||||
|
|
@ -75,3 +81,109 @@ func TestRootVolumeOptimizationFlag(t *testing.T) {
|
||||||
t.Fatalf("RootVolumeOptimization was expected to be true, but was false")
|
t.Fatalf("RootVolumeOptimization was expected to be true, but was false")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestAPIServerAdditionalSecurityGroupsWithNLB(t *testing.T) {
|
||||||
|
const sgID = "sg-01234567890abcdef"
|
||||||
|
|
||||||
|
cluster := buildMinimalCluster()
|
||||||
|
cluster.Spec.API = &kops.AccessSpec{
|
||||||
|
LoadBalancer: &kops.LoadBalancerAccessSpec{
|
||||||
|
Class: kops.LoadBalancerClassNetwork,
|
||||||
|
AdditionalSecurityGroups: []string{sgID},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
roleBastion = iota
|
||||||
|
roleMaster
|
||||||
|
roleNode
|
||||||
|
_roleCount
|
||||||
|
)
|
||||||
|
igs := make([]*kops.InstanceGroup, _roleCount)
|
||||||
|
// NB: (*AutoscalingGroupModelBuilder).buildLaunchConfigurationTask expects there to be at least
|
||||||
|
// one subnet specified in each InstanceGroup.
|
||||||
|
subnets := []string{cluster.Spec.Subnets[0].Name}
|
||||||
|
igs[roleBastion] = &kops.InstanceGroup{
|
||||||
|
ObjectMeta: v1.ObjectMeta{
|
||||||
|
Name: "bastion1",
|
||||||
|
},
|
||||||
|
Spec: kops.InstanceGroupSpec{
|
||||||
|
Role: kops.InstanceGroupRoleBastion,
|
||||||
|
Subnets: subnets,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
igs[roleMaster] = &kops.InstanceGroup{
|
||||||
|
ObjectMeta: v1.ObjectMeta{
|
||||||
|
Name: "master1",
|
||||||
|
},
|
||||||
|
Spec: kops.InstanceGroupSpec{
|
||||||
|
Role: kops.InstanceGroupRoleMaster,
|
||||||
|
Subnets: subnets,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
igs[roleNode] = &kops.InstanceGroup{
|
||||||
|
ObjectMeta: v1.ObjectMeta{
|
||||||
|
Name: "node1",
|
||||||
|
},
|
||||||
|
Spec: kops.InstanceGroupSpec{
|
||||||
|
Role: kops.InstanceGroupRoleNode,
|
||||||
|
Subnets: subnets,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
b := AutoscalingGroupModelBuilder{
|
||||||
|
AWSModelContext: &AWSModelContext{
|
||||||
|
KopsModelContext: &model.KopsModelContext{
|
||||||
|
IAMModelContext: iam.IAMModelContext{Cluster: cluster},
|
||||||
|
SSHPublicKeys: [][]byte{[]byte(sshPublicKeyEntry)},
|
||||||
|
InstanceGroups: igs,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
c := &fi.ModelBuilderContext{
|
||||||
|
Tasks: make(map[string]fi.Task),
|
||||||
|
}
|
||||||
|
|
||||||
|
b.Build(c)
|
||||||
|
|
||||||
|
hasDesignatedSecurityGroup := func(lt *awstasks.LaunchTemplate) bool {
|
||||||
|
for _, sg := range lt.SecurityGroups {
|
||||||
|
if sg.ID != nil && *sg.ID == sgID {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
launchTemplateForGroup := func(t *testing.T, ig *kops.InstanceGroup) *awstasks.LaunchTemplate {
|
||||||
|
t.Helper()
|
||||||
|
subdomain := ig.Name
|
||||||
|
if ig.Spec.Role == kops.InstanceGroupRoleMaster {
|
||||||
|
subdomain = ig.Name + ".masters"
|
||||||
|
}
|
||||||
|
task, ok := c.Tasks[fmt.Sprintf("LaunchTemplate/%s.%s", subdomain, cluster.Name)]
|
||||||
|
if !ok {
|
||||||
|
t.Fatalf("No task available in model build context for InstanceGroup %q", ig.Name)
|
||||||
|
}
|
||||||
|
if task == nil {
|
||||||
|
t.Fatalf("Task pointer in model build context for InstanceGroup %q is nil", ig.Name)
|
||||||
|
}
|
||||||
|
return task.(*awstasks.LaunchTemplate)
|
||||||
|
}
|
||||||
|
tests := []struct {
|
||||||
|
ig *kops.InstanceGroup
|
||||||
|
expectHasSG bool
|
||||||
|
}{
|
||||||
|
{igs[roleBastion], false},
|
||||||
|
{igs[roleMaster], true},
|
||||||
|
{igs[roleNode], false},
|
||||||
|
}
|
||||||
|
for _, test := range tests {
|
||||||
|
role := test.ig.Spec.Role
|
||||||
|
t.Run(string(role), func(t *testing.T) {
|
||||||
|
if want, got := test.expectHasSG, hasDesignatedSecurityGroup(launchTemplateForGroup(t, test.ig)); got != want {
|
||||||
|
t.Errorf("%q (role %q): launch template includes API server security group: want %t, got %t", test.ig.Name, role, want, got)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue