mirror of
				https://github.com/prometheus/prometheus.git
				synced 2025-11-04 02:11:01 +01:00 
			
		
		
		
	staticcheck fails with: storage/remote/read_test.go:199:27: do not pass a nil Context, even if a function permits it; pass context.TODO if you are unsure about which Context to use (SA1012)
		
			
				
	
	
		
			208 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			208 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2017 The Prometheus 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 remote
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"reflect"
 | 
						|
	"sort"
 | 
						|
	"testing"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"github.com/prometheus/common/model"
 | 
						|
	"github.com/prometheus/prometheus/config"
 | 
						|
	"github.com/prometheus/prometheus/pkg/labels"
 | 
						|
	"github.com/prometheus/prometheus/prompb"
 | 
						|
	"github.com/prometheus/prometheus/storage"
 | 
						|
)
 | 
						|
 | 
						|
func mustNewLabelMatcher(mt labels.MatchType, name, val string) *labels.Matcher {
 | 
						|
	m, err := labels.NewMatcher(mt, name, val)
 | 
						|
	if err != nil {
 | 
						|
		panic(err)
 | 
						|
	}
 | 
						|
	return m
 | 
						|
}
 | 
						|
 | 
						|
func TestAddExternalLabels(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		el          model.LabelSet
 | 
						|
		inMatchers  []*labels.Matcher
 | 
						|
		outMatchers []*labels.Matcher
 | 
						|
		added       model.LabelSet
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			el: model.LabelSet{},
 | 
						|
			inMatchers: []*labels.Matcher{
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "job", "api-server"),
 | 
						|
			},
 | 
						|
			outMatchers: []*labels.Matcher{
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "job", "api-server"),
 | 
						|
			},
 | 
						|
			added: model.LabelSet{},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			el: model.LabelSet{"region": "europe", "dc": "berlin-01"},
 | 
						|
			inMatchers: []*labels.Matcher{
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "job", "api-server"),
 | 
						|
			},
 | 
						|
			outMatchers: []*labels.Matcher{
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "job", "api-server"),
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "region", "europe"),
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "dc", "berlin-01"),
 | 
						|
			},
 | 
						|
			added: model.LabelSet{"region": "europe", "dc": "berlin-01"},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			el: model.LabelSet{"region": "europe", "dc": "berlin-01"},
 | 
						|
			inMatchers: []*labels.Matcher{
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "job", "api-server"),
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "dc", "munich-02"),
 | 
						|
			},
 | 
						|
			outMatchers: []*labels.Matcher{
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "job", "api-server"),
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "region", "europe"),
 | 
						|
				mustNewLabelMatcher(labels.MatchEqual, "dc", "munich-02"),
 | 
						|
			},
 | 
						|
			added: model.LabelSet{"region": "europe"},
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	for i, test := range tests {
 | 
						|
		q := querier{
 | 
						|
			externalLabels: test.el,
 | 
						|
		}
 | 
						|
 | 
						|
		matchers, added := q.addExternalLabels(test.inMatchers)
 | 
						|
 | 
						|
		sort.Slice(test.outMatchers, func(i, j int) bool { return test.outMatchers[i].Name < test.outMatchers[j].Name })
 | 
						|
		sort.Slice(matchers, func(i, j int) bool { return matchers[i].Name < matchers[j].Name })
 | 
						|
 | 
						|
		if !reflect.DeepEqual(matchers, test.outMatchers) {
 | 
						|
			t.Fatalf("%d. unexpected matchers; want %v, got %v", i, test.outMatchers, matchers)
 | 
						|
		}
 | 
						|
		if !reflect.DeepEqual(added, test.added) {
 | 
						|
			t.Fatalf("%d. unexpected added labels; want %v, got %v", i, test.added, added)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestRemoveLabels(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		in       labels.Labels
 | 
						|
		out      labels.Labels
 | 
						|
		toRemove model.LabelSet
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			toRemove: model.LabelSet{"foo": "bar"},
 | 
						|
			in:       labels.FromStrings("foo", "bar", "a", "b"),
 | 
						|
			out:      labels.FromStrings("a", "b"),
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	for i, test := range tests {
 | 
						|
		in := test.in.Copy()
 | 
						|
		removeLabels(&in, test.toRemove)
 | 
						|
 | 
						|
		if !reflect.DeepEqual(in, test.out) {
 | 
						|
			t.Fatalf("%d. unexpected labels; want %v, got %v", i, test.out, in)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestConcreteSeriesSet(t *testing.T) {
 | 
						|
	series1 := &concreteSeries{
 | 
						|
		labels:  labels.FromStrings("foo", "bar"),
 | 
						|
		samples: []*prompb.Sample{&prompb.Sample{Value: 1, Timestamp: 2}},
 | 
						|
	}
 | 
						|
	series2 := &concreteSeries{
 | 
						|
		labels:  labels.FromStrings("foo", "baz"),
 | 
						|
		samples: []*prompb.Sample{&prompb.Sample{Value: 3, Timestamp: 4}},
 | 
						|
	}
 | 
						|
	c := &concreteSeriesSet{
 | 
						|
		series: []storage.Series{series1, series2},
 | 
						|
	}
 | 
						|
	if !c.Next() {
 | 
						|
		t.Fatalf("Expected Next() to be true.")
 | 
						|
	}
 | 
						|
	if c.At() != series1 {
 | 
						|
		t.Fatalf("Unexpected series returned.")
 | 
						|
	}
 | 
						|
	if !c.Next() {
 | 
						|
		t.Fatalf("Expected Next() to be true.")
 | 
						|
	}
 | 
						|
	if c.At() != series2 {
 | 
						|
		t.Fatalf("Unexpected series returned.")
 | 
						|
	}
 | 
						|
	if c.Next() {
 | 
						|
		t.Fatalf("Expected Next() to be false.")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
type mockMergeQuerier struct{ queriersCount int }
 | 
						|
 | 
						|
func (*mockMergeQuerier) Select(...*labels.Matcher) storage.SeriesSet { return nil }
 | 
						|
func (*mockMergeQuerier) LabelValues(name string) ([]string, error)   { return nil, nil }
 | 
						|
func (*mockMergeQuerier) Close() error                                { return nil }
 | 
						|
 | 
						|
func TestRemoteStorageQuerier(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		localStartTime        int64
 | 
						|
		readRecentClients     []bool
 | 
						|
		mint                  int64
 | 
						|
		maxt                  int64
 | 
						|
		expectedQueriersCount int
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			localStartTime:    int64(20),
 | 
						|
			readRecentClients: []bool{true, true, false},
 | 
						|
			mint:              int64(0),
 | 
						|
			maxt:              int64(50),
 | 
						|
			expectedQueriersCount: 3,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			localStartTime:    int64(20),
 | 
						|
			readRecentClients: []bool{true, true, false},
 | 
						|
			mint:              int64(30),
 | 
						|
			maxt:              int64(50),
 | 
						|
			expectedQueriersCount: 2,
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	for i, test := range tests {
 | 
						|
		s := NewStorage(nil, func() (int64, error) { return test.localStartTime, nil })
 | 
						|
		s.clients = []*Client{}
 | 
						|
		for _, readRecent := range test.readRecentClients {
 | 
						|
			c, _ := NewClient(0, &clientConfig{
 | 
						|
				url:              nil,
 | 
						|
				timeout:          model.Duration(30 * time.Second),
 | 
						|
				httpClientConfig: config.HTTPClientConfig{},
 | 
						|
				readRecent:       readRecent,
 | 
						|
			})
 | 
						|
			s.clients = append(s.clients, c)
 | 
						|
		}
 | 
						|
		// overrides mergeQuerier to mockMergeQuerier so we can reflect its type
 | 
						|
		newMergeQueriers = func(queriers []storage.Querier) storage.Querier {
 | 
						|
			return &mockMergeQuerier{queriersCount: len(queriers)}
 | 
						|
		}
 | 
						|
 | 
						|
		querier, _ := s.Querier(context.Background(), test.mint, test.maxt)
 | 
						|
		actualQueriersCount := reflect.ValueOf(querier).Interface().(*mockMergeQuerier).queriersCount
 | 
						|
 | 
						|
		if !reflect.DeepEqual(actualQueriersCount, test.expectedQueriersCount) {
 | 
						|
			t.Fatalf("%d. unexpected queriers count; want %v, got %v", i, test.expectedQueriersCount, actualQueriersCount)
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |