-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathservicediscovery.go
57 lines (51 loc) · 1.69 KB
/
servicediscovery.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
package kubernetes
import (
"fmt"
log "github.com/Sirupsen/logrus"
"github.com/cnbm/container-orchestration/pkg/generic"
)
// ServiceDiscovery represents the Kubernetes specific benchmark run for the servicediscovery benchmark
type ServiceDiscovery struct {
Config map[string]string
}
// Setup prepares and inits the Kubernetes environment for the servicediscovery benchmark
func (bench ServiceDiscovery) Setup() error {
log.Info("Setting up Kubernetes servicediscovery benchmark")
cs, err := getclient(bench.Config["kubeconfig"])
if err != nil {
return err
}
sisepod := gensisep(bench.Config["ns"])
_, err = cs.CoreV1().Pods(bench.Config["ns"]).Create(sisepod)
if err != nil {
return fmt.Errorf("Can't create pod 'sise': %s", err)
}
//TODO: wait until pod is up
return nil
}
// Execute executes the servicediscovery benchmark against a Kubernetes cluster
func (bench ServiceDiscovery) Execute() (generic.BenchmarkResult, error) {
log.Info("Executing Kubernetes servicediscovery benchmark")
r := generic.BenchmarkResult{}
cs, err := getclient(bench.Config["kubeconfig"])
if err != nil {
return r, err
}
_ = cs
sise := gensises(bench.Config["ns"])
s, err := cs.Services(bench.Config["ns"]).Create(sise)
if err != nil {
return r, fmt.Errorf("Can't create service: %s", err)
}
_ = s
// TODO: wait until 'sise.cnbm.svc/info' returns 200:
// svcdone(cs, ns string, s)
r.Output = "benchmark succeeded"
return r, nil
}
// Teardown tears down and cleans up the Kubernetes environment after the servicediscovery benchmark has executed
func (bench ServiceDiscovery) Teardown() error {
log.Info("Tearing down Kubernetes servicediscovery benchmark")
// TODO: delete pod, delete svc
return nil
}