-
Notifications
You must be signed in to change notification settings - Fork 0
/
cm.go
190 lines (166 loc) · 5.15 KB
/
cm.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
package cluster
import (
"fmt"
"io/ioutil"
"log"
"strings"
g "github.com/onsi/ginkgo"
"k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kclientset "k8s.io/client-go/kubernetes"
e2e "k8s.io/kubernetes/test/e2e/framework"
exutil "github.com/openshift/origin/test/extended/util"
"gopkg.in/yaml.v2"
)
var _ = g.Describe("[Feature:Performance][Serial][Slow] Mirror cluster", func() {
defer g.GinkgoRecover()
const filename string = "cm.yml"
var oc = exutil.NewCLI("cl", exutil.KubeConfigPath())
var c kclientset.Interface
g.BeforeEach(func() {
var err error
c = oc.AdminKubeClient()
viperConfig := e2e.TestContext.Viper
if viperConfig == "e2e" {
e2e.Logf("Undefined config file")
} else if viperConfig == "mirror" {
e2e.Logf("We will try to mirror the cluster state.")
}
if err != nil {
e2e.Failf("Error parsing config: %v\n", err)
}
})
g.It("it should read the node info", func() {
nodeinfo := map[string]map[string]int{}
nodes, err := c.CoreV1().Nodes().List(metav1.ListOptions{})
if err != nil || len(nodes.Items) == 0 {
e2e.Failf("Error listing nodes: %v\n", err)
}
for _, node := range nodes.Items {
if _, ok := nodeinfo[node.Labels["type"]]; !ok {
nodeinfo[node.Labels["type"]] = make(map[string]int)
}
nodeinfo[node.Labels["type"]][node.Labels["beta.kubernetes.io/instance-type"]] += 1
}
e2e.Logf("We have %v\n", nodeinfo)
})
g.It("it should read the cluster apps", func() {
var pods *v1.PodList
config := ContextType{}
config.ClusterLoader.Cleanup = true
nsPod := make(map[string][]v1.Pod)
nsTemplate := map[string]map[string]struct{}{}
excludedNS := map[string]struct{}{
"default": {},
"kube-system": {}}
// Get all namespaces
nsList, err := c.CoreV1().Namespaces().List(metav1.ListOptions{})
if err != nil {
e2e.Failf("Error listing namespaces: %v\n", err)
}
// Crawl namespace slice
for _, ns := range nsList.Items {
var goodIndex int
if strings.Contains(ns.Name, "openshift") {
continue
}
// List objects in current namespace
e2e.Logf("Listing objects in namespace %v", ns.Name)
// Check for DeploymentConfigs
dcs, err := oc.AdminAppsClient().AppsV1().DeploymentConfigs(ns.Name).List(metav1.ListOptions{})
if err != nil {
e2e.Failf("Error listing DeploymentConfigs: %v\n", err)
}
for _, dc := range dcs.Items {
dc, err := oc.AdminAppsClient().AppsV1().DeploymentConfigs(ns.Name).Get(dc.Name, metav1.GetOptions{})
if err != nil {
e2e.Failf("Error DC not found: %v\n", err)
}
if templateName, ok := dc.Labels["template"]; ok {
// Get DC that has template label
nsTemplate[ns.Name] = make(map[string]struct{})
nsTemplate[ns.Name][templateName] = struct{}{}
e2e.Logf("DC found, with template label: %+v", templateName)
} else {
e2e.Logf("No template associated with this DC: %s", dc.Name)
}
}
// List pods in namespace
pods, err = c.CoreV1().Pods(ns.Name).List(metav1.ListOptions{})
if err != nil {
e2e.Failf("Error listing pods: %v\n", err)
}
for i, pod := range pods.Items {
// Only consider running pods
if pod.Status.Phase == v1.PodRunning {
// If the pod is part of a deployment we will take the template name instead
if value, ok := pod.Labels["deployment"]; ok {
// Get RC that matches pod label
rc, err := c.CoreV1().ReplicationControllers(ns.Name).Get(value, metav1.GetOptions{})
if err != nil {
e2e.Failf("Error RC not found: %v\n", err)
}
// Find template name from RC labels
if templateName, ok := rc.Labels["template"]; ok {
nsTemplate[ns.Name] = make(map[string]struct{})
nsTemplate[ns.Name][templateName] = struct{}{}
e2e.Logf("RC found, with template label: %+v", templateName)
} else {
e2e.Logf("No template associated with this RC: %s", rc.Name)
}
} else {
// Save standalone pods only
pods.Items[goodIndex] = pods.Items[i]
goodIndex++
}
}
}
nsPod[ns.Name] = pods.Items[:goodIndex]
}
// Crawl of namespace-pod map
for k, v := range nsPod {
if _, ok := excludedNS[k]; !ok {
ns := newNS(k)
for i := range v {
ns.Pods = append(ns.Pods, newPod(nsPod[k][i]))
}
for i := range nsTemplate[k] {
ns.Templates = append(ns.Templates, newTemplate(i))
}
if len(ns.Pods) > 0 || len(ns.Templates) > 0 {
config.ClusterLoader.Projects = append(config.ClusterLoader.Projects, ns)
}
}
}
// Marshal CL config struct to yaml
d, err := yaml.Marshal(&config)
if err != nil {
log.Fatalf("error: %v", err)
}
// Write to file
err = ioutil.WriteFile(filename, d, 0644)
if err != nil {
log.Fatalf("error: %v", err)
}
})
})
func newNS(ns string) ClusterLoaderType {
return ClusterLoaderType{
Number: 1,
Tuning: "default",
Basename: ns,
}
}
func newPod(pod v1.Pod) ClusterLoaderObjectType {
return ClusterLoaderObjectType{
Number: 1,
Image: pod.Spec.Containers[0].Image,
Basename: pod.Name,
}
}
func newTemplate(template string) ClusterLoaderObjectType {
return ClusterLoaderObjectType{
Number: 1,
File: fmt.Sprint("./examples/quickstarts/", template, ".json"),
}
}