2021-11-29 01:47:56 -08:00
|
|
|
// Copyright 2021 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 storage
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
2021-11-30 08:20:28 -08:00
|
|
|
|
2022-11-29 03:04:13 -08:00
|
|
|
"github.com/prometheus/prometheus/model/labels"
|
2021-11-30 08:20:28 -08:00
|
|
|
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
2022-11-29 03:04:13 -08:00
|
|
|
"github.com/prometheus/prometheus/tsdb/tsdbutil"
|
2021-11-29 01:47:56 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestListSeriesIterator(t *testing.T) {
|
2021-11-30 08:20:28 -08:00
|
|
|
it := NewListSeriesIterator(samples{
|
2022-12-08 04:31:08 -08:00
|
|
|
fSample{0, 0},
|
|
|
|
fSample{1, 1},
|
|
|
|
fSample{1, 1.5},
|
|
|
|
fSample{2, 2},
|
|
|
|
fSample{3, 3},
|
2021-11-30 08:20:28 -08:00
|
|
|
})
|
2021-11-29 01:47:56 -08:00
|
|
|
|
|
|
|
// Seek to the first sample with ts=1.
|
2021-11-30 08:20:28 -08:00
|
|
|
require.Equal(t, chunkenc.ValFloat, it.Seek(1))
|
2021-11-29 01:47:56 -08:00
|
|
|
ts, v := it.At()
|
|
|
|
require.Equal(t, int64(1), ts)
|
|
|
|
require.Equal(t, 1., v)
|
|
|
|
|
|
|
|
// Seek one further, next sample still has ts=1.
|
2021-11-30 08:20:28 -08:00
|
|
|
require.Equal(t, chunkenc.ValFloat, it.Next())
|
2021-11-29 01:47:56 -08:00
|
|
|
ts, v = it.At()
|
|
|
|
require.Equal(t, int64(1), ts)
|
|
|
|
require.Equal(t, 1.5, v)
|
|
|
|
|
|
|
|
// Seek again to 1 and make sure we stay where we are.
|
2021-11-30 08:20:28 -08:00
|
|
|
require.Equal(t, chunkenc.ValFloat, it.Seek(1))
|
2021-11-29 01:47:56 -08:00
|
|
|
ts, v = it.At()
|
|
|
|
require.Equal(t, int64(1), ts)
|
|
|
|
require.Equal(t, 1.5, v)
|
|
|
|
|
|
|
|
// Another seek.
|
2021-11-30 08:20:28 -08:00
|
|
|
require.Equal(t, chunkenc.ValFloat, it.Seek(3))
|
2021-11-29 01:47:56 -08:00
|
|
|
ts, v = it.At()
|
|
|
|
require.Equal(t, int64(3), ts)
|
|
|
|
require.Equal(t, 3., v)
|
|
|
|
|
|
|
|
// And we don't go back.
|
2021-11-30 08:20:28 -08:00
|
|
|
require.Equal(t, chunkenc.ValFloat, it.Seek(2))
|
2021-11-29 01:47:56 -08:00
|
|
|
ts, v = it.At()
|
|
|
|
require.Equal(t, int64(3), ts)
|
|
|
|
require.Equal(t, 3., v)
|
2021-12-16 03:01:54 -08:00
|
|
|
|
|
|
|
// Seek beyond the end.
|
2021-12-18 05:12:01 -08:00
|
|
|
require.Equal(t, chunkenc.ValNone, it.Seek(5))
|
2021-12-16 03:01:54 -08:00
|
|
|
// And we don't go back. (This exposes issue #10027.)
|
2021-12-18 05:12:01 -08:00
|
|
|
require.Equal(t, chunkenc.ValNone, it.Seek(2))
|
2021-11-29 01:47:56 -08:00
|
|
|
}
|
2022-11-29 03:04:13 -08:00
|
|
|
|
|
|
|
// TestSeriesSetToChunkSet test the property of SeriesSet that says
|
|
|
|
// returned series should be iterable even after Next is called.
|
|
|
|
func TestChunkSeriesSetToSeriesSet(t *testing.T) {
|
|
|
|
series := []struct {
|
|
|
|
lbs labels.Labels
|
|
|
|
samples []tsdbutil.Sample
|
|
|
|
}{
|
|
|
|
{
|
2022-12-20 09:59:22 -08:00
|
|
|
lbs: labels.FromStrings("__name__", "up", "instance", "localhost:8080"),
|
2022-11-29 03:04:13 -08:00
|
|
|
samples: []tsdbutil.Sample{
|
2022-12-08 04:31:08 -08:00
|
|
|
fSample{t: 1, f: 1},
|
|
|
|
fSample{t: 2, f: 2},
|
|
|
|
fSample{t: 3, f: 3},
|
|
|
|
fSample{t: 4, f: 4},
|
2022-11-29 03:04:13 -08:00
|
|
|
},
|
|
|
|
}, {
|
2022-12-20 09:59:22 -08:00
|
|
|
lbs: labels.FromStrings("__name__", "up", "instance", "localhost:8081"),
|
2022-11-29 03:04:13 -08:00
|
|
|
samples: []tsdbutil.Sample{
|
2022-12-08 04:31:08 -08:00
|
|
|
fSample{t: 1, f: 2},
|
|
|
|
fSample{t: 2, f: 3},
|
|
|
|
fSample{t: 3, f: 4},
|
|
|
|
fSample{t: 4, f: 5},
|
|
|
|
fSample{t: 5, f: 6},
|
|
|
|
fSample{t: 6, f: 7},
|
2022-11-29 03:04:13 -08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
var chunkSeries []ChunkSeries
|
|
|
|
for _, s := range series {
|
|
|
|
chunkSeries = append(chunkSeries, NewListChunkSeriesFromSamples(s.lbs, s.samples))
|
|
|
|
}
|
|
|
|
css := NewMockChunkSeriesSet(chunkSeries...)
|
|
|
|
|
|
|
|
ss := NewSeriesSetFromChunkSeriesSet(css)
|
|
|
|
var ssSlice []Series
|
|
|
|
for ss.Next() {
|
|
|
|
ssSlice = append(ssSlice, ss.At())
|
|
|
|
}
|
|
|
|
require.Len(t, ssSlice, 2)
|
|
|
|
var iter chunkenc.Iterator
|
|
|
|
for i, s := range ssSlice {
|
|
|
|
require.EqualValues(t, series[i].lbs, s.Labels())
|
|
|
|
iter = s.Iterator(iter)
|
|
|
|
j := 0
|
|
|
|
for iter.Next() == chunkenc.ValFloat {
|
|
|
|
ts, v := iter.At()
|
2022-12-08 04:31:08 -08:00
|
|
|
require.EqualValues(t, series[i].samples[j], fSample{t: ts, f: v})
|
2022-11-29 03:04:13 -08:00
|
|
|
j++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|