This repository has been archived by the owner on Oct 23, 2023. It is now read-only.
/
runner.go
117 lines (93 loc) · 2.25 KB
/
runner.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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package awsapicall
import (
"context"
"fmt"
"github.com/giantswarm/k8sclient/v5/pkg/k8sclient"
"github.com/giantswarm/microerror"
"github.com/giantswarm/micrologger"
"github.com/spf13/cobra"
batchapiv1 "k8s.io/api/batch/v1"
apiv1 "k8s.io/api/core/v1"
k8sruntimeclient "sigs.k8s.io/controller-runtime/pkg/client"
"github.com/giantswarm/awscnfm/v15/pkg/client"
"github.com/giantswarm/awscnfm/v15/pkg/env"
"github.com/giantswarm/awscnfm/v15/pkg/project"
)
const (
kubeSystemNamespace = "kube-system"
)
type runner struct {
flag *flag
logger micrologger.Logger
}
func (r *runner) Run(cmd *cobra.Command, args []string) error {
ctx := context.Background()
err := r.flag.Validate()
if err != nil {
return microerror.Mask(err)
}
err = r.run(ctx, cmd, args)
if err != nil {
return microerror.Mask(err)
}
return nil
}
func (r *runner) run(ctx context.Context, cmd *cobra.Command, args []string) error {
var err error
var cpClients k8sclient.Interface
{
c := client.ControlPlaneConfig{
Logger: r.logger,
KubeConfig: env.ControlPlaneKubeConfig(),
}
cpClients, err = client.NewControlPlane(c)
if err != nil {
return microerror.Mask(err)
}
}
var tcClients k8sclient.Interface
{
c := client.TenantClusterConfig{
ControlPlane: cpClients,
Logger: r.logger,
TenantCluster: r.flag.TenantCluster,
}
tcClients, err = client.NewTenantCluster(c)
if err != nil {
return microerror.Mask(err)
}
}
err = r.checkKiamAWScallPod(ctx, tcClients.CtrlClient())
if err != nil {
return microerror.Mask(err)
}
return nil
}
// checkKiamAWScallPod will check if the AWS API call job was successful
func (r *runner) checkKiamAWScallPod(ctx context.Context, tcClient k8sruntimeclient.Client) error {
name := fmt.Sprintf("%s-kiam-test", project.Name())
job := &batchapiv1.Job{}
err := tcClient.Get(
ctx,
k8sruntimeclient.ObjectKey{
Namespace: kubeSystemNamespace,
Name: name,
},
job,
)
if err != nil {
return microerror.Mask(err)
}
if !isJobCompleted(job) {
return microerror.Mask(jobNotCompleted)
}
return nil
}
func isJobCompleted(j *batchapiv1.Job) bool {
for _, c := range j.Status.Conditions {
if c.Type == "Complete" && c.Status == apiv1.ConditionTrue {
return true
}
}
return false
}