/
pcp_test.go
72 lines (57 loc) · 1.56 KB
/
pcp_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
package pcp
import (
"testing"
"github.com/performancecopilot/speed/v4"
"github.com/go-kit/kit/metrics/teststat"
)
func TestCounter(t *testing.T) {
r, err := NewReporter("test_counter")
if err != nil {
t.Fatal(err)
}
counter, err := r.NewCounter("speed_counter")
if err != nil {
t.Fatal(err)
}
counter = counter.With("label values", "not supported").(*Counter)
value := func() float64 { f := counter.c.Val(); return float64(f) }
if err := teststat.TestCounter(counter, value); err != nil {
t.Fatal(err)
}
}
func TestGauge(t *testing.T) {
r, err := NewReporter("test_gauge")
if err != nil {
t.Fatal(err)
}
gauge, err := r.NewGauge("speed_gauge")
if err != nil {
t.Fatal(err)
}
gauge = gauge.With("label values", "not supported").(*Gauge)
value := func() []float64 { f := gauge.g.Val(); return []float64{f} }
if err := teststat.TestGauge(gauge, value); err != nil {
t.Fatal(err)
}
}
func TestHistogram(t *testing.T) {
r, err := NewReporter("test_histogram")
if err != nil {
t.Fatal(err)
}
histogram, err := r.NewHistogram("speed_histogram", 0, 3600000000, speed.OneUnit)
if err != nil {
t.Fatal(err)
}
histogram = histogram.With("label values", "not supported").(*Histogram)
quantiles := func() (float64, float64, float64, float64) {
p50 := float64(histogram.Percentile(50))
p90 := float64(histogram.Percentile(90))
p95 := float64(histogram.Percentile(95))
p99 := float64(histogram.Percentile(99))
return p50, p90, p95, p99
}
if err := teststat.TestHistogram(histogram, quantiles, 0.01); err != nil {
t.Fatal(err)
}
}