-
Notifications
You must be signed in to change notification settings - Fork 1.4k
/
iamserviceaccount_test.go
63 lines (56 loc) · 2.49 KB
/
iamserviceaccount_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
package delete
import (
"fmt"
"strings"
api "github.com/weaveworks/eksctl/pkg/apis/eksctl.io/v1alpha5"
"github.com/weaveworks/eksctl/pkg/ctl/cmdutils"
. "github.com/onsi/ginkgo/extensions/table"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
)
var _ = Describe("delete iamserviceaccount", func() {
DescribeTable("delete service account successfully",
func(args ...string) {
commandArgs := append([]string{"iamserviceaccount"}, args...)
cmd := newMockEmptyCmd(commandArgs...)
count := 0
cmdutils.AddResourceCmd(cmdutils.NewGrouping(), cmd.parentCmd, func(cmd *cmdutils.Cmd) {
deleteIAMServiceAccountCmdWithRunFunc(cmd, func(cmd *cmdutils.Cmd, serviceAccount *api.ClusterIAMServiceAccount, onlyMissing bool) error {
Expect(cmd.ClusterConfig.Metadata.Name).To(Equal("clusterName"))
Expect(cmd.ClusterConfig.IAM.ServiceAccounts[0].Name).To(Equal("serviceAccountName"))
Expect(onlyMissing).To(Equal(strings.Contains(strings.Join(commandArgs, " "), "only-missing")))
count++
return nil
})
})
_, err := cmd.execute()
Expect(err).To(Not(HaveOccurred()))
Expect(count).To(Equal(1))
},
Entry("with all required flags", "--cluster", "clusterName", "--name", "serviceAccountName"),
Entry("with namespace flag", "--cluster", "clusterName", "--name", "serviceAccountName", "--namespace", "dev"),
Entry("with only-missing flag", "--cluster", "clusterName", "--name", "serviceAccountName", "--only-missing"),
Entry("with approve flag", "--cluster", "clusterName", "--name", "serviceAccountName", "--approve"),
)
DescribeTable("invalid flags or arguments",
func(c invalidParamsCase) {
commandArgs := append([]string{"iamserviceaccount"}, c.args...)
cmd := newDefaultCmd(commandArgs...)
_, err := cmd.execute()
Expect(err).To(HaveOccurred())
Expect(err.Error()).To(ContainSubstring(c.error.Error()))
},
Entry("without cluster name", invalidParamsCase{
args: []string{"--name", "serviceAccountName"},
error: fmt.Errorf("Error: --cluster must be set"),
}),
Entry("with iamserviceaccount name as argument and flag", invalidParamsCase{
args: []string{"--cluster", "clusterName", "--name", "serviceAccountName", "serviceAccountName"},
error: fmt.Errorf("Error: --name=serviceAccountName and argument serviceAccountName cannot be used at the same time"),
}),
Entry("with invalid flags", invalidParamsCase{
args: []string{"iamserviceaccount", "--invalid", "dummy"},
error: fmt.Errorf("Error: unknown flag: --invalid"),
}),
)
})