From 87d772a7d708fec12f48cd8adc0dedff6e1025da Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 26 Aug 2024 10:15:20 +0200 Subject: Adding upstream version 1.47.0. Signed-off-by: Daniel Baumann --- .../modules/prometheus/prometheus_test.go | 611 --------------------- 1 file changed, 611 deletions(-) delete mode 100644 src/go/collectors/go.d.plugin/modules/prometheus/prometheus_test.go (limited to 'src/go/collectors/go.d.plugin/modules/prometheus/prometheus_test.go') diff --git a/src/go/collectors/go.d.plugin/modules/prometheus/prometheus_test.go b/src/go/collectors/go.d.plugin/modules/prometheus/prometheus_test.go deleted file mode 100644 index 52c30f143..000000000 --- a/src/go/collectors/go.d.plugin/modules/prometheus/prometheus_test.go +++ /dev/null @@ -1,611 +0,0 @@ -// SPDX-License-Identifier: GPL-3.0-or-later - -package prometheus - -import ( - "fmt" - "net/http" - "net/http/httptest" - "os" - "testing" - - "github.com/netdata/netdata/go/go.d.plugin/agent/module" - "github.com/netdata/netdata/go/go.d.plugin/pkg/prometheus/selector" - "github.com/netdata/netdata/go/go.d.plugin/pkg/web" - - "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/require" -) - -var ( - dataConfigJSON, _ = os.ReadFile("testdata/config.json") - dataConfigYAML, _ = os.ReadFile("testdata/config.yaml") -) - -func Test_testDataIsValid(t *testing.T) { - for name, data := range map[string][]byte{ - "dataConfigJSON": dataConfigJSON, - "dataConfigYAML": dataConfigYAML, - } { - require.NotNil(t, data, name) - } -} - -func TestPrometheus_ConfigurationSerialize(t *testing.T) { - module.TestConfigurationSerialize(t, &Prometheus{}, dataConfigJSON, dataConfigYAML) -} - -func TestPrometheus_Init(t *testing.T) { - tests := map[string]struct { - config Config - wantFail bool - }{ - "non empty URL": { - wantFail: false, - config: Config{HTTP: web.HTTP{Request: web.Request{URL: "http://127.0.0.1:9090/metric"}}}, - }, - "invalid selector syntax": { - wantFail: true, - config: Config{ - HTTP: web.HTTP{Request: web.Request{URL: "http://127.0.0.1:9090/metric"}}, - Selector: selector.Expr{Allow: []string{`name{label=#"value"}`}}, - }, - }, - "default": { - wantFail: true, - config: New().Config, - }, - } - - for name, test := range tests { - t.Run(name, func(t *testing.T) { - prom := New() - prom.Config = test.config - - if test.wantFail { - assert.Error(t, prom.Init()) - } else { - assert.NoError(t, prom.Init()) - } - }) - } -} - -func TestPrometheus_Cleanup(t *testing.T) { - assert.NotPanics(t, New().Cleanup) - - prom := New() - prom.URL = "http://127.0.0.1" - require.NoError(t, prom.Init()) - assert.NotPanics(t, prom.Cleanup) -} - -func TestPrometheus_Check(t *testing.T) { - tests := map[string]struct { - prepare func() (prom *Prometheus, cleanup func()) - wantFail bool - }{ - "success if endpoint returns valid metrics in prometheus format": { - wantFail: false, - prepare: func() (prom *Prometheus, cleanup func()) { - srv := httptest.NewServer(http.HandlerFunc( - func(w http.ResponseWriter, r *http.Request) { - _, _ = w.Write([]byte(`test_counter_no_meta_metric_1_total{label1="value1"} 11`)) - })) - prom = New() - prom.URL = srv.URL - - return prom, srv.Close - }, - }, - "fail if the total num of metrics exceeds the limit": { - wantFail: true, - prepare: func() (prom *Prometheus, cleanup func()) { - srv := httptest.NewServer(http.HandlerFunc( - func(w http.ResponseWriter, r *http.Request) { - _, _ = w.Write([]byte(` -test_counter_no_meta_metric_1_total{label1="value1"} 11 -test_counter_no_meta_metric_1_total{label1="value2"} 11 -`)) - })) - prom = New() - prom.URL = srv.URL - prom.MaxTS = 1 - - return prom, srv.Close - }, - }, - "fail if the num time series in the metric exceeds the limit": { - wantFail: true, - prepare: func() (prom *Prometheus, cleanup func()) { - srv := httptest.NewServer(http.HandlerFunc( - func(w http.ResponseWriter, r *http.Request) { - _, _ = w.Write([]byte(` -test_counter_no_meta_metric_1_total{label1="value1"} 11 -test_counter_no_meta_metric_1_total{label1="value2"} 11 -`)) - })) - prom = New() - prom.URL = srv.URL - prom.MaxTSPerMetric = 1 - - return prom, srv.Close - }, - }, - "fail if metrics have no expected prefix": { - wantFail: true, - prepare: func() (prom *Prometheus, cleanup func()) { - srv := httptest.NewServer(http.HandlerFunc( - func(w http.ResponseWriter, r *http.Request) { - _, _ = w.Write([]byte(`test_counter_no_meta_metric_1_total{label1="value1"} 11`)) - })) - prom = New() - prom.URL = srv.URL - prom.ExpectedPrefix = "prefix_" - - return prom, srv.Close - }, - }, - "fail if endpoint returns data not in prometheus format": { - wantFail: true, - prepare: func() (prom *Prometheus, cleanup func()) { - srv := httptest.NewServer(http.HandlerFunc( - func(w http.ResponseWriter, r *http.Request) { - _, _ = w.Write([]byte("hello and\n goodbye")) - })) - prom = New() - prom.URL = srv.URL - - return prom, srv.Close - }, - }, - "fail if connection refused": { - wantFail: true, - prepare: func() (prom *Prometheus, cleanup func()) { - prom = New() - prom.URL = "http://127.0.0.1:38001/metrics" - - return prom, func() {} - }, - }, - "fail if endpoint returns 404": { - wantFail: true, - prepare: func() (prom *Prometheus, cleanup func()) { - srv := httptest.NewServer(http.HandlerFunc( - func(w http.ResponseWriter, r *http.Request) { - w.WriteHeader(http.StatusNotFound) - })) - prom = New() - prom.URL = srv.URL - - return prom, srv.Close - }, - }, - } - - for name, test := range tests { - t.Run(name, func(t *testing.T) { - prom, cleanup := test.prepare() - defer cleanup() - - require.NoError(t, prom.Init()) - - if test.wantFail { - assert.Error(t, prom.Check()) - } else { - assert.NoError(t, prom.Check()) - } - }) - } -} - -func TestPrometheus_Collect(t *testing.T) { - type testCaseStep struct { - desc string - input string - wantCollected map[string]int64 - wantCharts int - } - tests := map[string]struct { - prepare func() *Prometheus - steps []testCaseStep - }{ - "Gauge": { - prepare: New, - steps: []testCaseStep{ - { - desc: "Two first seen series, no meta series ignored", - input: ` -# HELP test_gauge_metric_1 Test Gauge Metric 1 -# TYPE test_gauge_metric_1 gauge -test_gauge_metric_1{label1="value1"} 11 -test_gauge_metric_1{label1="value2"} 12 -test_gauge_no_meta_metric_1{label1="value1"} 11 -test_gauge_no_meta_metric_1{label1="value2"} 12 -`, - wantCollected: map[string]int64{ - "test_gauge_metric_1-label1=value1": 11000, - "test_gauge_metric_1-label1=value2": 12000, - }, - wantCharts: 2, - }, - { - desc: "One series removed", - input: ` -# HELP test_gauge_metric_1 Test Gauge Metric 1 -# TYPE test_gauge_metric_1 gauge -test_gauge_metric_1{label1="value1"} 11 -`, - wantCollected: map[string]int64{ - "test_gauge_metric_1-label1=value1": 11000, - }, - wantCharts: 1, - }, - { - desc: "One series (re)added", - input: ` -# HELP test_gauge_metric_1 Test Gauge Metric 1 -# TYPE test_gauge_metric_1 gauge -test_gauge_metric_1{label1="value1"} 11 -test_gauge_metric_1{label1="value2"} 12 -`, - wantCollected: map[string]int64{ - "test_gauge_metric_1-label1=value1": 11000, - "test_gauge_metric_1-label1=value2": 12000, - }, - wantCharts: 2, - }, - }, - }, - "Counter": { - prepare: New, - steps: []testCaseStep{ - { - desc: "Four first seen series, no meta series collected", - input: ` -# HELP test_counter_metric_1_total Test Counter Metric 1 -# TYPE test_counter_metric_1_total counter -test_counter_metric_1_total{label1="value1"} 11 -test_counter_metric_1_total{label1="value2"} 12 -test_counter_no_meta_metric_1_total{label1="value1"} 11 -test_counter_no_meta_metric_1_total{label1="value2"} 12 -`, - wantCollected: map[string]int64{ - "test_counter_metric_1_total-label1=value1": 11000, - "test_counter_metric_1_total-label1=value2": 12000, - "test_counter_no_meta_metric_1_total-label1=value1": 11000, - "test_counter_no_meta_metric_1_total-label1=value2": 12000, - }, - wantCharts: 4, - }, - { - desc: "Two series removed", - input: ` -# HELP test_counter_metric_1_total Test Counter Metric 1 -# TYPE test_counter_metric_1_total counter -test_counter_metric_1_total{label1="value1"} 11 -test_counter_no_meta_metric_1_total{label1="value1"} 11 -`, - wantCollected: map[string]int64{ - "test_counter_metric_1_total-label1=value1": 11000, - "test_counter_no_meta_metric_1_total-label1=value1": 11000, - }, - wantCharts: 2, - }, - { - desc: "Two series (re)added", - input: ` -# HELP test_counter_metric_1_total Test Counter Metric 1 -# TYPE test_counter_metric_1_total counter -test_counter_metric_1_total{label1="value1"} 11 -test_counter_metric_1_total{label1="value2"} 12 -test_counter_no_meta_metric_1_total{label1="value1"} 11 -test_counter_no_meta_metric_1_total{label1="value2"} 12 -`, - wantCollected: map[string]int64{ - "test_counter_metric_1_total-label1=value1": 11000, - "test_counter_metric_1_total-label1=value2": 12000, - "test_counter_no_meta_metric_1_total-label1=value1": 11000, - "test_counter_no_meta_metric_1_total-label1=value2": 12000, - }, - wantCharts: 4, - }, - }, - }, - "Summary": { - prepare: New, - steps: []testCaseStep{ - { - desc: "Two first seen series, no meta series collected", - input: ` -# HELP test_summary_1_duration_microseconds Test Summary Metric 1 -# TYPE test_summary_1_duration_microseconds summary -test_summary_1_duration_microseconds{label1="value1",quantile="0.5"} 4931.921 -test_summary_1_duration_microseconds{label1="value1",quantile="0.9"} 4932.921 -test_summary_1_duration_microseconds{label1="value1",quantile="0.99"} 4933.921 -test_summary_1_duration_microseconds_sum{label1="value1"} 283201.29 -test_summary_1_duration_microseconds_count{label1="value1"} 31 -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.5"} 4931.921 -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.9"} 4932.921 -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.99"} 4933.921 -test_summary_no_meta_1_duration_microseconds_sum{label1="value1"} 283201.29 -test_summary_no_meta_1_duration_microseconds_count{label1="value1"} 31 -`, - wantCollected: map[string]int64{ - "test_summary_1_duration_microseconds-label1=value1_count": 31, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.5": 4931921000, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.9": 4932921000, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.99": 4933921000, - "test_summary_1_duration_microseconds-label1=value1_sum": 283201290, - "test_summary_no_meta_1_duration_microseconds-label1=value1_count": 31, - "test_summary_no_meta_1_duration_microseconds-label1=value1_quantile=0.5": 4931921000, - "test_summary_no_meta_1_duration_microseconds-label1=value1_quantile=0.9": 4932921000, - "test_summary_no_meta_1_duration_microseconds-label1=value1_quantile=0.99": 4933921000, - "test_summary_no_meta_1_duration_microseconds-label1=value1_sum": 283201290, - }, - wantCharts: 6, - }, - { - desc: "One series removed", - input: ` -# HELP test_summary_1_duration_microseconds Test Summary Metric 1 -# TYPE test_summary_1_duration_microseconds summary -test_summary_1_duration_microseconds{label1="value1",quantile="0.5"} 4931.921 -test_summary_1_duration_microseconds{label1="value1",quantile="0.9"} 4932.921 -test_summary_1_duration_microseconds{label1="value1",quantile="0.99"} 4933.921 -test_summary_1_duration_microseconds_sum{label1="value1"} 283201.29 -test_summary_1_duration_microseconds_count{label1="value1"} 31 -`, - wantCollected: map[string]int64{ - "test_summary_1_duration_microseconds-label1=value1_count": 31, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.5": 4931921000, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.9": 4932921000, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.99": 4933921000, - "test_summary_1_duration_microseconds-label1=value1_sum": 283201290, - }, - wantCharts: 3, - }, - { - desc: "One series (re)added", - input: ` -# HELP test_summary_1_duration_microseconds Test Summary Metric 1 -# TYPE test_summary_1_duration_microseconds summary -test_summary_1_duration_microseconds{label1="value1",quantile="0.5"} 4931.921 -test_summary_1_duration_microseconds{label1="value1",quantile="0.9"} 4932.921 -test_summary_1_duration_microseconds{label1="value1",quantile="0.99"} 4933.921 -test_summary_1_duration_microseconds_sum{label1="value1"} 283201.29 -test_summary_1_duration_microseconds_count{label1="value1"} 31 -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.5"} 4931.921 -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.9"} 4932.921 -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.99"} 4933.921 -test_summary_no_meta_1_duration_microseconds_sum{label1="value1"} 283201.29 -test_summary_no_meta_1_duration_microseconds_count{label1="value1"} 31 -`, - wantCollected: map[string]int64{ - "test_summary_1_duration_microseconds-label1=value1_count": 31, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.5": 4931921000, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.9": 4932921000, - "test_summary_1_duration_microseconds-label1=value1_quantile=0.99": 4933921000, - "test_summary_1_duration_microseconds-label1=value1_sum": 283201290, - "test_summary_no_meta_1_duration_microseconds-label1=value1_count": 31, - "test_summary_no_meta_1_duration_microseconds-label1=value1_quantile=0.5": 4931921000, - "test_summary_no_meta_1_duration_microseconds-label1=value1_quantile=0.9": 4932921000, - "test_summary_no_meta_1_duration_microseconds-label1=value1_quantile=0.99": 4933921000, - "test_summary_no_meta_1_duration_microseconds-label1=value1_sum": 283201290, - }, - wantCharts: 6, - }, - }, - }, - "Summary with NaN": { - prepare: New, - steps: []testCaseStep{ - { - desc: "Two first seen series, no meta series collected", - input: ` -# HELP test_summary_1_duration_microseconds Test Summary Metric 1 -# TYPE test_summary_1_duration_microseconds summary -test_summary_1_duration_microseconds{label1="value1",quantile="0.5"} NaN -test_summary_1_duration_microseconds{label1="value1",quantile="0.9"} NaN -test_summary_1_duration_microseconds{label1="value1",quantile="0.99"} NaN -test_summary_1_duration_microseconds_sum{label1="value1"} 283201.29 -test_summary_1_duration_microseconds_count{label1="value1"} 31 -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.5"} NaN -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.9"} NaN -test_summary_no_meta_1_duration_microseconds{label1="value1",quantile="0.99"} NaN -test_summary_no_meta_1_duration_microseconds_sum{label1="value1"} 283201.29 -test_summary_no_meta_1_duration_microseconds_count{label1="value1"} 31 -`, - wantCollected: map[string]int64{ - "test_summary_1_duration_microseconds-label1=value1_count": 31, - "test_summary_1_duration_microseconds-label1=value1_sum": 283201290, - "test_summary_no_meta_1_duration_microseconds-label1=value1_count": 31, - "test_summary_no_meta_1_duration_microseconds-label1=value1_sum": 283201290, - }, - wantCharts: 6, - }, - }, - }, - "Histogram": { - prepare: New, - steps: []testCaseStep{ - { - desc: "Two first seen series, no meta series collected", - input: ` -# HELP test_histogram_1_duration_seconds Test Histogram Metric 1 -# TYPE test_histogram_1_duration_seconds histogram -test_histogram_1_duration_seconds_bucket{label1="value1",le="0.1"} 4 -test_histogram_1_duration_seconds_bucket{label1="value1",le="0.5"} 5 -test_histogram_1_duration_seconds_bucket{label1="value1",le="+Inf"} 6 -test_histogram_1_duration_seconds_sum{label1="value1"} 0.00147889 -test_histogram_1_duration_seconds_count{label1="value1"} 6 -test_histogram_no_meta_1_duration_seconds_bucket{label1="value1",le="0.1"} 4 -test_histogram_no_meta_1_duration_seconds_bucket{label1="value1",le="0.5"} 5 -test_histogram_no_meta_1_duration_seconds_bucket{label1="value1",le="+Inf"} 6 -test_histogram_no_meta_1_duration_seconds_sum{label1="value1"} 0.00147889 -test_histogram_no_meta_1_duration_seconds_count{label1="value1"} 6 -`, - wantCollected: map[string]int64{ - "test_histogram_1_duration_seconds-label1=value1_bucket=+Inf": 6, - "test_histogram_1_duration_seconds-label1=value1_bucket=0.1": 4, - "test_histogram_1_duration_seconds-label1=value1_bucket=0.5": 5, - "test_histogram_1_duration_seconds-label1=value1_count": 6, - "test_histogram_1_duration_seconds-label1=value1_sum": 1, - "test_histogram_no_meta_1_duration_seconds-label1=value1_bucket=+Inf": 6, - "test_histogram_no_meta_1_duration_seconds-label1=value1_bucket=0.1": 4, - "test_histogram_no_meta_1_duration_seconds-label1=value1_bucket=0.5": 5, - "test_histogram_no_meta_1_duration_seconds-label1=value1_count": 6, - "test_histogram_no_meta_1_duration_seconds-label1=value1_sum": 1, - }, - wantCharts: 6, - }, - { - desc: "One series removed", - input: ` -# HELP test_histogram_1_duration_seconds Test Histogram Metric 1 -# TYPE test_histogram_1_duration_seconds histogram -test_histogram_1_duration_seconds_bucket{label1="value1",le="0.1"} 4 -test_histogram_1_duration_seconds_bucket{label1="value1",le="0.5"} 5 -test_histogram_1_duration_seconds_bucket{label1="value1",le="+Inf"} 6 -`, - wantCollected: map[string]int64{ - "test_histogram_1_duration_seconds-label1=value1_bucket=+Inf": 6, - "test_histogram_1_duration_seconds-label1=value1_bucket=0.1": 4, - "test_histogram_1_duration_seconds-label1=value1_bucket=0.5": 5, - "test_histogram_1_duration_seconds-label1=value1_count": 0, - "test_histogram_1_duration_seconds-label1=value1_sum": 0, - }, - wantCharts: 3, - }, - { - desc: "One series (re)added", - input: ` -# HELP test_histogram_1_duration_seconds Test Histogram Metric 1 -# TYPE test_histogram_1_duration_seconds histogram -test_histogram_1_duration_seconds_bucket{label1="value1",le="0.1"} 4 -test_histogram_1_duration_seconds_bucket{label1="value1",le="0.5"} 5 -test_histogram_1_duration_seconds_bucket{label1="value1",le="+Inf"} 6 -test_histogram_1_duration_seconds_sum{label1="value1"} 0.00147889 -test_histogram_1_duration_seconds_count{label1="value1"} 6 -test_histogram_no_meta_1_duration_seconds_bucket{label1="value1",le="0.1"} 4 -test_histogram_no_meta_1_duration_seconds_bucket{label1="value1",le="0.5"} 5 -test_histogram_no_meta_1_duration_seconds_bucket{label1="value1",le="+Inf"} 6 -test_histogram_no_meta_1_duration_seconds_sum{label1="value1"} 0.00147889 -test_histogram_no_meta_1_duration_seconds_count{label1="value1"} 6 -`, - wantCollected: map[string]int64{ - "test_histogram_1_duration_seconds-label1=value1_bucket=+Inf": 6, - "test_histogram_1_duration_seconds-label1=value1_bucket=0.1": 4, - "test_histogram_1_duration_seconds-label1=value1_bucket=0.5": 5, - "test_histogram_1_duration_seconds-label1=value1_count": 6, - "test_histogram_1_duration_seconds-label1=value1_sum": 1, - "test_histogram_no_meta_1_duration_seconds-label1=value1_bucket=+Inf": 6, - "test_histogram_no_meta_1_duration_seconds-label1=value1_bucket=0.1": 4, - "test_histogram_no_meta_1_duration_seconds-label1=value1_bucket=0.5": 5, - "test_histogram_no_meta_1_duration_seconds-label1=value1_count": 6, - "test_histogram_no_meta_1_duration_seconds-label1=value1_sum": 1, - }, - wantCharts: 6, - }, - }, - }, - "match Untyped as Gauge": { - prepare: func() *Prometheus { - prom := New() - prom.FallbackType.Gauge = []string{"test_gauge_no_meta*"} - return prom - }, - steps: []testCaseStep{ - { - desc: "Two first seen series, meta series processed as Gauge", - input: ` -# HELP test_gauge_metric_1 Test Untyped Metric 1 -# TYPE test_gauge_metric_1 gauge -test_gauge_metric_1{label1="value1"} 11 -test_gauge_metric_1{label1="value2"} 12 -test_gauge_no_meta_metric_1{label1="value1"} 11 -test_gauge_no_meta_metric_1{label1="value2"} 12 -`, - wantCollected: map[string]int64{ - "test_gauge_metric_1-label1=value1": 11000, - "test_gauge_metric_1-label1=value2": 12000, - "test_gauge_no_meta_metric_1-label1=value1": 11000, - "test_gauge_no_meta_metric_1-label1=value2": 12000, - }, - wantCharts: 4, - }, - }, - }, - "match Untyped as Counter": { - prepare: func() *Prometheus { - prom := New() - prom.FallbackType.Counter = []string{"test_gauge_no_meta*"} - return prom - }, - steps: []testCaseStep{ - { - desc: "Two first seen series, meta series processed as Counter", - input: ` -# HELP test_gauge_metric_1 Test Untyped Metric 1 -# TYPE test_gauge_metric_1 gauge -test_gauge_metric_1{label1="value1"} 11 -test_gauge_metric_1{label1="value2"} 12 -test_gauge_no_meta_metric_1{label1="value1"} 11 -test_gauge_no_meta_metric_1{label1="value2"} 12 -`, - wantCollected: map[string]int64{ - "test_gauge_metric_1-label1=value1": 11000, - "test_gauge_metric_1-label1=value2": 12000, - "test_gauge_no_meta_metric_1-label1=value1": 11000, - "test_gauge_no_meta_metric_1-label1=value2": 12000, - }, - wantCharts: 4, - }, - }, - }, - } - - for name, test := range tests { - t.Run(name, func(t *testing.T) { - prom := test.prepare() - - var metrics []byte - srv := httptest.NewServer(http.HandlerFunc( - func(w http.ResponseWriter, r *http.Request) { - _, _ = w.Write(metrics) - })) - defer srv.Close() - - prom.URL = srv.URL - require.NoError(t, prom.Init()) - - for num, step := range test.steps { - t.Run(fmt.Sprintf("step num %d ('%s')", num+1, step.desc), func(t *testing.T) { - - metrics = []byte(step.input) - - var mx map[string]int64 - - for i := 0; i < maxNotSeenTimes+1; i++ { - mx = prom.Collect() - } - - assert.Equal(t, step.wantCollected, mx) - removeObsoleteCharts(prom.Charts()) - assert.Len(t, *prom.Charts(), step.wantCharts) - }) - } - }) - } -} - -func removeObsoleteCharts(charts *module.Charts) { - var i int - for _, chart := range *charts { - if !chart.Obsolete { - (*charts)[i] = chart - i++ - } - } - *charts = (*charts)[:i] -} -- cgit v1.2.3