mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-12 14:27:27 -08:00
Merge pull request #12505 from pracucci/fix-infinite-loop-in-index-writer
Fix infinite loop in index Writer when a series contains duplicated label names
This commit is contained in:
commit
9ff1f24efa
|
@ -864,7 +864,10 @@ func (w *Writer) writePostingsToTmpFiles() error {
|
|||
// using more memory than a single label name can.
|
||||
for len(names) > 0 {
|
||||
if w.labelNames[names[0]]+c > maxPostings {
|
||||
break
|
||||
if c > 0 {
|
||||
break
|
||||
}
|
||||
return fmt.Errorf("corruption detected when writing postings to index: label %q has %d uses, but maxPostings is %d", names[0], w.labelNames[names[0]], maxPostings)
|
||||
}
|
||||
batchNames = append(batchNames, names[0])
|
||||
c += w.labelNames[names[0]]
|
||||
|
|
|
@ -471,6 +471,21 @@ func TestPersistence_index_e2e(t *testing.T) {
|
|||
require.NoError(t, ir.Close())
|
||||
}
|
||||
|
||||
func TestWriter_ShouldReturnErrorOnSeriesWithDuplicatedLabelNames(t *testing.T) {
|
||||
w, err := NewWriter(context.Background(), filepath.Join(t.TempDir(), "index"))
|
||||
require.NoError(t, err)
|
||||
|
||||
require.NoError(t, w.AddSymbol("__name__"))
|
||||
require.NoError(t, w.AddSymbol("metric_1"))
|
||||
require.NoError(t, w.AddSymbol("metric_2"))
|
||||
|
||||
require.NoError(t, w.AddSeries(0, labels.FromStrings("__name__", "metric_1", "__name__", "metric_2")))
|
||||
|
||||
err = w.Close()
|
||||
require.Error(t, err)
|
||||
require.ErrorContains(t, err, "corruption detected when writing postings to index")
|
||||
}
|
||||
|
||||
func TestDecbufUvarintWithInvalidBuffer(t *testing.T) {
|
||||
b := realByteSlice([]byte{0x81, 0x81, 0x81, 0x81, 0x81, 0x81})
|
||||
|
||||
|
|
Loading…
Reference in a new issue