influxdb/kit/prom/registry_test.go

65 lines
1.4 KiB
Go

package prom_test
import (
"errors"
"net/http"
"net/http/httptest"
"strings"
"testing"
"github.com/influxdata/platform/kit/prom"
"github.com/prometheus/client_golang/prometheus"
"go.uber.org/zap"
"go.uber.org/zap/zaptest/observer"
)
func TestRegistry_Logger(t *testing.T) {
reg := prom.NewRegistry()
// Normal use: HTTP handler is created immediately...
s := httptest.NewServer(reg.HTTPHandler())
defer s.Close()
// ... and then WithLogger is called.
core, logs := observer.New(zap.DebugLevel)
logger := zap.New(core)
reg.WithLogger(logger)
// Force an error with a fake collector.
reg.MustRegister(errorCollector{})
resp, err := http.Get(s.URL)
if err != nil {
t.Fatal(err)
}
defer resp.Body.Close()
foundLog := false
for _, le := range logs.All() {
if strings.Contains(le.Message, "invalid metric from errorCollector") {
foundLog = true
break
}
}
if !foundLog {
t.Fatalf("registry logger did not log error from metric collection")
}
}
type errorCollector struct{}
var _ prometheus.Collector = errorCollector{}
var ecDesc = prometheus.NewDesc("error_collector_desc", "A required description for the error collector", nil, nil)
func (errorCollector) Describe(ch chan<- *prometheus.Desc) {
ch <- ecDesc
}
func (errorCollector) Collect(ch chan<- prometheus.Metric) {
ch <- prometheus.NewInvalidMetric(
ecDesc,
errors.New("invalid metric from errorCollector"),
)
}