From 1788643b14f2d513df144d6c4e973bbce2a2a744 Mon Sep 17 00:00:00 2001 From: Michael Hoffmann Date: Sat, 27 Jan 2024 18:54:17 +0100 Subject: [PATCH] Stores: convert tests to not rely on slice labels (#7098) Signed-off-by: Michael Hoffmann --- pkg/store/bucket_test.go | 33 ++++++++++++++++----------------- pkg/store/proxy_heap_test.go | 8 ++++---- pkg/store/proxy_test.go | 9 ++++----- pkg/store/tsdb_test.go | 6 +++--- 4 files changed, 27 insertions(+), 29 deletions(-) diff --git a/pkg/store/bucket_test.go b/pkg/store/bucket_test.go index f1d85a5a88..a13ff033dc 100644 --- a/pkg/store/bucket_test.go +++ b/pkg/store/bucket_test.go @@ -807,19 +807,19 @@ func TestBucketStore_Sharding(t *testing.T) { bkt := objstore.NewInMemBucket() series := []labels.Labels{labels.FromStrings("a", "1", "b", "1")} - id1, err := e2eutil.CreateBlock(ctx, dir, series, 10, 0, 1000, labels.Labels{{Name: "cluster", Value: "a"}, {Name: "region", Value: "r1"}}, 0, metadata.NoneFunc) + id1, err := e2eutil.CreateBlock(ctx, dir, series, 10, 0, 1000, labels.FromStrings("cluster", "a", "region", "r1"), 0, metadata.NoneFunc) testutil.Ok(t, err) testutil.Ok(t, block.Upload(ctx, logger, bkt, filepath.Join(dir, id1.String()), metadata.NoneFunc)) - id2, err := e2eutil.CreateBlock(ctx, dir, series, 10, 1000, 2000, labels.Labels{{Name: "cluster", Value: "a"}, {Name: "region", Value: "r1"}}, 0, metadata.NoneFunc) + id2, err := e2eutil.CreateBlock(ctx, dir, series, 10, 1000, 2000, labels.FromStrings("cluster", "a", "region", "r1"), 0, metadata.NoneFunc) testutil.Ok(t, err) testutil.Ok(t, block.Upload(ctx, logger, bkt, filepath.Join(dir, id2.String()), metadata.NoneFunc)) - id3, err := e2eutil.CreateBlock(ctx, dir, series, 10, 0, 1000, labels.Labels{{Name: "cluster", Value: "b"}, {Name: "region", Value: "r1"}}, 0, metadata.NoneFunc) + id3, err := e2eutil.CreateBlock(ctx, dir, series, 10, 0, 1000, labels.FromStrings("cluster", "b", "region", "r1"), 0, metadata.NoneFunc) testutil.Ok(t, err) testutil.Ok(t, block.Upload(ctx, logger, bkt, filepath.Join(dir, id3.String()), metadata.NoneFunc)) - id4, err := e2eutil.CreateBlock(ctx, dir, series, 10, 0, 1000, labels.Labels{{Name: "cluster", Value: "a"}, {Name: "region", Value: "r2"}}, 0, metadata.NoneFunc) + id4, err := e2eutil.CreateBlock(ctx, dir, series, 10, 0, 1000, labels.FromStrings("cluster", "a", "region", "r2"), 0, metadata.NoneFunc) testutil.Ok(t, err) testutil.Ok(t, block.Upload(ctx, logger, bkt, filepath.Join(dir, id4.String()), metadata.NoneFunc)) @@ -1204,7 +1204,7 @@ func uploadTestBlock(t testing.TB, tmpDir string, bkt objstore.Bucket, series in id := storetestutil.CreateBlockFromHead(t, filepath.Join(tmpDir, "tmp"), h) _, err = metadata.InjectThanos(log.NewNopLogger(), filepath.Join(tmpDir, "tmp", id.String()), metadata.Thanos{ - Labels: labels.Labels{{Name: "ext1", Value: "1"}}.Map(), + Labels: labels.FromStrings("ext1", "1").Map(), Downsample: metadata.ThanosDownsample{Resolution: 0}, Source: metadata.TestSource, }, nil) @@ -1376,13 +1376,12 @@ func benchBucketSeries(t testutil.TB, sampleType chunkenc.ValueType, skipChunk b random = rand.New(rand.NewSource(120)) ) - extLset := labels.Labels{{Name: "ext1", Value: "1"}} + extLset := labels.FromStrings("ext1", "1") thanosMeta := metadata.Thanos{ Labels: extLset.Map(), Downsample: metadata.ThanosDownsample{Resolution: 0}, Source: metadata.TestSource, } - blockDir := filepath.Join(tmpDir, "tmp") samplesPerSeriesPerBlock := samplesPerSeries / numOfBlocks @@ -1565,7 +1564,7 @@ func TestBucketSeries_OneBlock_InMemIndexCacheSegfault(t *testing.T) { logger := log.NewLogfmtLogger(os.Stderr) thanosMeta := metadata.Thanos{ - Labels: labels.Labels{{Name: "ext1", Value: "1"}}.Map(), + Labels: labels.FromStrings("ext1", "1").Map(), Downsample: metadata.ThanosDownsample{Resolution: 0}, Source: metadata.TestSource, } @@ -1679,7 +1678,7 @@ func TestBucketSeries_OneBlock_InMemIndexCacheSegfault(t *testing.T) { indexReaderPool: indexheader.NewReaderPool(log.NewNopLogger(), false, 0, indexheader.NewReaderPoolMetrics(nil)), metrics: newBucketStoreMetrics(nil), blockSets: map[uint64]*bucketBlockSet{ - labels.Labels{{Name: "ext1", Value: "1"}}.Hash(): {blocks: [][]*bucketBlock{{b1, b2}}}, + labels.FromStrings("ext1", "1").Hash(): {blocks: [][]*bucketBlock{{b1, b2}}}, }, blocks: map[ulid.ULID]*bucketBlock{ b1.meta.ULID: b1, @@ -1945,7 +1944,7 @@ func TestSeries_BlockWithMultipleChunks(t *testing.T) { blk := storetestutil.CreateBlockFromHead(t, headOpts.ChunkDirRoot, h) thanosMeta := metadata.Thanos{ - Labels: labels.Labels{{Name: "ext1", Value: "1"}}.Map(), + Labels: labels.FromStrings("ext1", "1").Map(), Downsample: metadata.ThanosDownsample{Resolution: 0}, Source: metadata.TestSource, } @@ -2197,7 +2196,7 @@ func uploadSeriesToBucket(t *testing.T, bkt *filesystem.Bucket, replica string, blk := storetestutil.CreateBlockFromHead(t, headOpts.ChunkDirRoot, h) thanosMeta := metadata.Thanos{ - Labels: labels.Labels{{Name: "ext1", Value: replica}}.Map(), + Labels: labels.FromStrings("ext1", replica).Map(), Downsample: metadata.ThanosDownsample{Resolution: 0}, Source: metadata.TestSource, } @@ -2251,7 +2250,7 @@ func createBlockWithOneSeriesWithStep(t testutil.TB, dir string, lbls labels.Lab ref, err := app.Append(0, lbls, ts, random.Float64()) testutil.Ok(t, err) for i := 1; i < totalSamples; i++ { - _, err := app.Append(ref, nil, ts+step*int64(i), random.Float64()) + _, err := app.Append(ref, labels.EmptyLabels(), ts+step*int64(i), random.Float64()) testutil.Ok(t, err) } testutil.Ok(t, app.Commit()) @@ -2277,7 +2276,7 @@ func setupStoreForHintsTest(t *testing.T) (testutil.TB, *BucketStore, []*storepb random = rand.New(rand.NewSource(120)) ) - extLset := labels.Labels{{Name: "ext1", Value: "1"}} + extLset := labels.FromStrings("ext1", "1") // Inject the Thanos meta to each block in the storage. thanosMeta := metadata.Thanos{ Labels: extLset.Map(), @@ -2508,7 +2507,7 @@ func TestSeries_ChunksHaveHashRepresentation(t *testing.T) { blk := storetestutil.CreateBlockFromHead(t, headOpts.ChunkDirRoot, h) thanosMeta := metadata.Thanos{ - Labels: labels.Labels{{Name: "ext1", Value: "1"}}.Map(), + Labels: labels.FromStrings("ext1", "1").Map(), Downsample: metadata.ThanosDownsample{Resolution: 0}, Source: metadata.TestSource, } @@ -2637,7 +2636,7 @@ func BenchmarkBucketBlock_readChunkRange(b *testing.B) { // Upload the block to the bucket. thanosMeta := metadata.Thanos{ - Labels: labels.Labels{{Name: "ext1", Value: "1"}}.Map(), + Labels: labels.FromStrings("ext1", "1").Map(), Downsample: metadata.ThanosDownsample{Resolution: 0}, Source: metadata.TestSource, } @@ -2699,7 +2698,7 @@ func prepareBucket(b testing.TB, resolutionLevel compact.ResolutionLevel, sample SamplesPerSeries: 86400 / 15, // Simulate 1 day block with 15s scrape interval. ScrapeInterval: 15 * time.Second, Series: 1000, - PrependLabels: nil, + PrependLabels: labels.EmptyLabels(), Random: rand.New(rand.NewSource(120)), SkipChunks: true, SampleType: sampleType, @@ -2708,7 +2707,7 @@ func prepareBucket(b testing.TB, resolutionLevel compact.ResolutionLevel, sample // Upload the block to the bucket. thanosMeta := metadata.Thanos{ - Labels: labels.Labels{{Name: "ext1", Value: "1"}}.Map(), + Labels: labels.FromStrings("ext1", "1").Map(), Downsample: metadata.ThanosDownsample{Resolution: 0}, Source: metadata.TestSource, } diff --git a/pkg/store/proxy_heap_test.go b/pkg/store/proxy_heap_test.go index e6f41da8dd..6be6b49bba 100644 --- a/pkg/store/proxy_heap_test.go +++ b/pkg/store/proxy_heap_test.go @@ -112,12 +112,12 @@ func labelsFromStrings(ss ...string) labels.Labels { if len(ss)%2 != 0 { panic("invalid number of strings") } - res := make(labels.Labels, 0, len(ss)/2) + + b := labels.NewScratchBuilder(len(ss) / 2) for i := 0; i < len(ss); i += 2 { - res = append(res, labels.Label{Name: ss[i], Value: ss[i+1]}) + b.Add(ss[i], ss[i+1]) } - - return res + return b.Labels() } func BenchmarkSortWithoutLabels(b *testing.B) { diff --git a/pkg/store/proxy_test.go b/pkg/store/proxy_test.go index cedf9f3fa4..b108c23ebc 100644 --- a/pkg/store/proxy_test.go +++ b/pkg/store/proxy_test.go @@ -68,7 +68,7 @@ func TestProxyStore_Info(t *testing.T) { nil, func() []Client { return nil }, component.Query, - nil, 0*time.Second, EagerRetrieval, + labels.EmptyLabels(), 0*time.Second, EagerRetrieval, ) resp, err := q.Info(ctx, &storepb.InfoRequest{}) @@ -97,7 +97,7 @@ func TestProxyStore_TSDBInfos(t *testing.T) { } q := NewProxyStore(nil, nil, func() []Client { return stores }, - component.Query, nil, 0*time.Second, EagerRetrieval, + component.Query, labels.EmptyLabels(), 0*time.Second, EagerRetrieval, ) expected := []infopb.TSDBInfo{ @@ -1349,7 +1349,6 @@ func TestProxyStore_Series_RequestParamsProxied(t *testing.T) { MaxTime: 300, }, } - req := &storepb.SeriesRequest{ MinTime: 1, MaxTime: 300, @@ -1495,7 +1494,7 @@ func TestProxyStore_LabelValues(t *testing.T) { nil, func() []Client { return cls }, component.Query, - nil, + labels.EmptyLabels(), 0*time.Second, EagerRetrieval, ) @@ -1695,7 +1694,7 @@ func TestProxyStore_LabelNames(t *testing.T) { nil, func() []Client { return tc.storeAPIs }, component.Query, - nil, + labels.EmptyLabels(), 5*time.Second, EagerRetrieval, ) diff --git a/pkg/store/tsdb_test.go b/pkg/store/tsdb_test.go index 587aaa7032..f67ac73d3f 100644 --- a/pkg/store/tsdb_test.go +++ b/pkg/store/tsdb_test.go @@ -690,7 +690,7 @@ func benchTSDBStoreSeries(t testutil.TB, totalSamples, totalSeries int) { // Add external labels & frame it. s := r.GetSeries() bytesLeftForChunks := store.maxBytesPerFrame - lbls := make([]labelpb.ZLabel, 0, len(s.Labels)+len(extLabels)) + lbls := make([]labelpb.ZLabel, 0, len(s.Labels)+extLabels.Len()) for _, l := range s.Labels { lbls = append(lbls, labelpb.ZLabel{ Name: l.Name, @@ -698,13 +698,13 @@ func benchTSDBStoreSeries(t testutil.TB, totalSamples, totalSeries int) { }) bytesLeftForChunks -= lbls[len(lbls)-1].Size() } - for _, l := range extLabels { + extLabels.Range(func(l labels.Label) { lbls = append(lbls, labelpb.ZLabel{ Name: l.Name, Value: l.Value, }) bytesLeftForChunks -= lbls[len(lbls)-1].Size() - } + }) sort.Slice(lbls, func(i, j int) bool { return lbls[i].Name < lbls[j].Name })