2019-01-20 18:26:22 +00:00
|
|
|
package prometheus_test
|
2019-01-18 13:38:58 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"reflect"
|
|
|
|
"testing"
|
|
|
|
|
2020-06-26 23:54:09 +00:00
|
|
|
"github.com/golang/protobuf/proto"
|
2020-04-03 17:39:20 +00:00
|
|
|
pr "github.com/influxdata/influxdb/v2/prometheus"
|
2019-01-18 13:38:58 +00:00
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
dto "github.com/prometheus/client_model/go"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestFilter_Gather(t *testing.T) {
|
|
|
|
type fields struct {
|
|
|
|
Gatherer prometheus.Gatherer
|
2019-01-20 18:26:22 +00:00
|
|
|
Matcher pr.Matcher
|
2019-01-18 13:38:58 +00:00
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
fields fields
|
|
|
|
want []*dto.MetricFamily
|
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "no metrics returns nil",
|
|
|
|
fields: fields{
|
|
|
|
Gatherer: prometheus.GathererFunc(func() ([]*dto.MetricFamily, error) {
|
|
|
|
return nil, nil
|
|
|
|
}),
|
2019-01-20 18:26:22 +00:00
|
|
|
Matcher: pr.NewMatcher().
|
2019-01-18 13:38:58 +00:00
|
|
|
Family("http_api_requests_total",
|
2019-01-20 18:26:22 +00:00
|
|
|
pr.L("handler", "platform"),
|
|
|
|
pr.L("method", "GET"),
|
|
|
|
pr.L("path", "/api/v2"),
|
|
|
|
pr.L("status", "2XX"),
|
2019-01-18 13:38:58 +00:00
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "gather error returns error",
|
|
|
|
fields: fields{
|
|
|
|
Gatherer: prometheus.GathererFunc(func() ([]*dto.MetricFamily, error) {
|
|
|
|
return nil, fmt.Errorf("e1")
|
|
|
|
}),
|
|
|
|
},
|
|
|
|
wantErr: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "no matches returns no metric families",
|
|
|
|
fields: fields{
|
|
|
|
Gatherer: prometheus.GathererFunc(func() ([]*dto.MetricFamily, error) {
|
|
|
|
mf := &dto.MetricFamily{
|
|
|
|
Name: proto.String("n1"),
|
|
|
|
Help: proto.String("h1"),
|
|
|
|
}
|
|
|
|
return []*dto.MetricFamily{mf}, nil
|
|
|
|
}),
|
2019-01-20 18:26:22 +00:00
|
|
|
Matcher: pr.NewMatcher().
|
2019-01-18 13:38:58 +00:00
|
|
|
Family("http_api_requests_total",
|
2019-01-20 18:26:22 +00:00
|
|
|
pr.L("handler", "platform"),
|
|
|
|
pr.L("method", "GET"),
|
|
|
|
pr.L("path", "/api/v2"),
|
|
|
|
pr.L("status", "2XX"),
|
2019-01-18 13:38:58 +00:00
|
|
|
),
|
|
|
|
},
|
|
|
|
want: []*dto.MetricFamily{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "matching family without metric matches nothing",
|
|
|
|
fields: fields{
|
|
|
|
Gatherer: prometheus.GathererFunc(func() ([]*dto.MetricFamily, error) {
|
|
|
|
mf := &dto.MetricFamily{
|
|
|
|
Name: proto.String("go_memstats_frees_total"),
|
|
|
|
}
|
|
|
|
return []*dto.MetricFamily{mf}, nil
|
|
|
|
}),
|
2019-01-20 18:26:22 +00:00
|
|
|
Matcher: pr.NewMatcher().
|
2019-01-18 13:38:58 +00:00
|
|
|
Family("go_memstats_frees_total"),
|
|
|
|
},
|
|
|
|
want: []*dto.MetricFamily{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "matching family with no labels matches",
|
|
|
|
fields: fields{
|
|
|
|
Gatherer: prometheus.GathererFunc(func() ([]*dto.MetricFamily, error) {
|
|
|
|
return []*dto.MetricFamily{NewCounter("go_memstats_frees_total", 1.0)}, nil
|
|
|
|
}),
|
2019-01-20 18:26:22 +00:00
|
|
|
Matcher: pr.NewMatcher().
|
2019-01-18 13:38:58 +00:00
|
|
|
Family("go_memstats_frees_total"),
|
|
|
|
},
|
|
|
|
want: []*dto.MetricFamily{NewCounter("go_memstats_frees_total", 1.0)},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "matching with labels a family with labels matches",
|
|
|
|
fields: fields{
|
|
|
|
Gatherer: prometheus.GathererFunc(func() ([]*dto.MetricFamily, error) {
|
2019-01-20 18:26:22 +00:00
|
|
|
return []*dto.MetricFamily{NewCounter("go_memstats_frees_total", 1.0, pr.L("n1", "v1"))}, nil
|
2019-01-18 13:38:58 +00:00
|
|
|
}),
|
2019-01-20 18:26:22 +00:00
|
|
|
Matcher: pr.NewMatcher().
|
|
|
|
Family("go_memstats_frees_total", pr.L("n1", "v1")),
|
2019-01-18 13:38:58 +00:00
|
|
|
},
|
2019-01-20 18:26:22 +00:00
|
|
|
want: []*dto.MetricFamily{NewCounter("go_memstats_frees_total", 1.0, pr.L("n1", "v1"))},
|
2019-01-18 13:38:58 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "matching a family that has no labels with labels matches",
|
|
|
|
fields: fields{
|
|
|
|
Gatherer: prometheus.GathererFunc(func() ([]*dto.MetricFamily, error) {
|
2019-01-20 18:26:22 +00:00
|
|
|
return []*dto.MetricFamily{NewCounter("go_memstats_frees_total", 1.0, pr.L("n1", "v1"))}, nil
|
2019-01-18 13:38:58 +00:00
|
|
|
}),
|
2019-01-20 18:26:22 +00:00
|
|
|
Matcher: pr.NewMatcher().
|
2019-01-18 13:38:58 +00:00
|
|
|
Family("go_memstats_frees_total"),
|
|
|
|
},
|
2019-01-20 18:26:22 +00:00
|
|
|
want: []*dto.MetricFamily{NewCounter("go_memstats_frees_total", 1.0, pr.L("n1", "v1"))},
|
2019-01-18 13:38:58 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2019-01-20 18:26:22 +00:00
|
|
|
f := &pr.Filter{
|
2019-01-18 13:38:58 +00:00
|
|
|
Gatherer: tt.fields.Gatherer,
|
|
|
|
Matcher: tt.fields.Matcher,
|
|
|
|
}
|
|
|
|
got, err := f.Gather()
|
|
|
|
if (err != nil) != tt.wantErr {
|
|
|
|
t.Errorf("Filter.Gather() error = %v, wantErr %v", err, tt.wantErr)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(got, tt.want) {
|
|
|
|
t.Errorf("Filter.Gather() = %v, want %v", got, tt.want)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|