forked from knative/pkg
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprometheus_exporter_test.go
77 lines (72 loc) · 1.99 KB
/
prometheus_exporter_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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/*
Copyright 2019 The Knative Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package metrics
import (
"testing"
"time"
. "knative.dev/pkg/logging/testing"
)
func TestNewPrometheusExporter(t *testing.T) {
testCases := []struct {
name string
config metricsConfig
expectedAddr string
}{{
name: "port 9090",
config: metricsConfig{
domain: servingDomain,
component: testComponent,
backendDestination: Prometheus,
prometheusPort: 9090,
},
expectedAddr: ":9090",
}, {
name: "port 9091",
config: metricsConfig{
domain: servingDomain,
component: testComponent,
backendDestination: Prometheus,
prometheusPort: 9091,
},
expectedAddr: ":9091",
}}
for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
e, err := newPrometheusExporter(&tc.config, TestLogger(t))
if err != nil {
t.Error(err)
}
if e == nil {
t.Fatal("expected a non-nil metrics exporter")
}
expectPromSrv(t, tc.expectedAddr)
})
}
}
func expectPromSrv(t *testing.T, expectedAddr string) {
time.Sleep(200 * time.Millisecond)
srv := getCurPromSrv()
if srv == nil {
t.Fatal("expected a server for prometheus exporter")
}
if got, want := srv.Addr, expectedAddr; got != want {
t.Errorf("metrics port addresses diff, got=%v, want=%v", got, want)
}
}
func expectNoPromSrv(t *testing.T) {
time.Sleep(200 * time.Millisecond)
srv := getCurPromSrv()
if srv != nil {
t.Error("expected no server for stackdriver exporter")
}
}