2017-05-26 08:56:31 -07:00
|
|
|
// 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.
|
|
|
|
|
2017-05-16 00:13:33 -07:00
|
|
|
package tsdb
|
2017-11-21 03:15:02 -08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
2018-10-23 14:35:52 -07:00
|
|
|
"math/rand"
|
2017-11-21 03:15:02 -08:00
|
|
|
"os"
|
2017-11-30 06:34:49 -08:00
|
|
|
"path/filepath"
|
2017-11-21 03:15:02 -08:00
|
|
|
"testing"
|
2017-12-06 17:06:14 -08:00
|
|
|
|
2018-10-23 14:35:52 -07:00
|
|
|
"github.com/go-kit/kit/log"
|
2017-11-30 06:34:49 -08:00
|
|
|
"github.com/prometheus/tsdb/index"
|
2018-10-23 14:35:52 -07:00
|
|
|
"github.com/prometheus/tsdb/labels"
|
2017-12-05 08:17:33 -08:00
|
|
|
"github.com/prometheus/tsdb/testutil"
|
2017-11-21 03:15:02 -08:00
|
|
|
)
|
|
|
|
|
2018-02-12 02:40:12 -08:00
|
|
|
// In Prometheus 2.1.0 we had a bug where the meta.json version was falsely bumped
|
|
|
|
// to 2. We had a migration in place resetting it to 1 but we should move immediately to
|
|
|
|
// version 3 next time to avoid confusion and issues.
|
|
|
|
func TestBlockMetaMustNeverBeVersion2(t *testing.T) {
|
|
|
|
dir, err := ioutil.TempDir("", "metaversion")
|
|
|
|
testutil.Ok(t, err)
|
|
|
|
defer os.RemoveAll(dir)
|
|
|
|
|
|
|
|
testutil.Ok(t, writeMetaFile(dir, &BlockMeta{}))
|
|
|
|
|
|
|
|
meta, err := readMetaFile(dir)
|
|
|
|
testutil.Ok(t, err)
|
|
|
|
testutil.Assert(t, meta.Version != 2, "meta.json version must never be 2")
|
|
|
|
}
|
|
|
|
|
2017-11-21 03:15:02 -08:00
|
|
|
func TestSetCompactionFailed(t *testing.T) {
|
2018-02-23 07:04:50 -08:00
|
|
|
tmpdir, err := ioutil.TempDir("", "test")
|
2017-12-06 17:06:14 -08:00
|
|
|
testutil.Ok(t, err)
|
2018-02-23 07:04:50 -08:00
|
|
|
defer os.RemoveAll(tmpdir)
|
2017-11-21 03:15:02 -08:00
|
|
|
|
2018-05-28 13:00:36 -07:00
|
|
|
b := createEmptyBlock(t, tmpdir, &BlockMeta{Version: 2})
|
2017-11-21 03:15:02 -08:00
|
|
|
|
2017-12-06 17:06:14 -08:00
|
|
|
testutil.Equals(t, false, b.meta.Compaction.Failed)
|
|
|
|
testutil.Ok(t, b.setCompactionFailed())
|
|
|
|
testutil.Equals(t, true, b.meta.Compaction.Failed)
|
|
|
|
testutil.Ok(t, b.Close())
|
2017-11-21 03:15:02 -08:00
|
|
|
|
|
|
|
b, err = OpenBlock(tmpdir, nil)
|
2017-12-06 17:06:14 -08:00
|
|
|
testutil.Ok(t, err)
|
|
|
|
testutil.Equals(t, true, b.meta.Compaction.Failed)
|
2017-11-21 03:15:02 -08:00
|
|
|
}
|
|
|
|
|
2018-05-28 13:00:36 -07:00
|
|
|
// createEmpty block creates a block with the given meta but without any data.
|
|
|
|
func createEmptyBlock(t *testing.T, dir string, meta *BlockMeta) *Block {
|
2017-12-06 17:06:14 -08:00
|
|
|
testutil.Ok(t, os.MkdirAll(dir, 0777))
|
2017-11-21 03:15:02 -08:00
|
|
|
|
2018-05-28 13:00:36 -07:00
|
|
|
testutil.Ok(t, writeMetaFile(dir, meta))
|
2017-11-21 03:15:02 -08:00
|
|
|
|
2017-11-30 06:34:49 -08:00
|
|
|
ir, err := index.NewWriter(filepath.Join(dir, indexFilename))
|
2017-12-21 02:55:58 -08:00
|
|
|
testutil.Ok(t, err)
|
|
|
|
testutil.Ok(t, ir.Close())
|
2017-11-21 03:15:02 -08:00
|
|
|
|
2017-12-06 17:06:14 -08:00
|
|
|
testutil.Ok(t, os.MkdirAll(chunkDir(dir), 0777))
|
2017-11-21 03:15:02 -08:00
|
|
|
|
2018-06-08 04:52:01 -07:00
|
|
|
testutil.Ok(t, writeTombstoneFile(dir, NewMemTombstones()))
|
2017-11-21 03:15:02 -08:00
|
|
|
|
|
|
|
b, err := OpenBlock(dir, nil)
|
2017-12-06 17:06:14 -08:00
|
|
|
testutil.Ok(t, err)
|
2017-11-21 03:15:02 -08:00
|
|
|
return b
|
|
|
|
}
|
2018-10-23 14:35:52 -07:00
|
|
|
|
|
|
|
// createPopulatedBlock creates a block with nSeries series, and nSamples samples.
|
|
|
|
func createPopulatedBlock(tb testing.TB, dir string, nSeries, nSamples int) *Block {
|
|
|
|
head, err := NewHead(nil, nil, nil, 2*60*60*1000)
|
|
|
|
testutil.Ok(tb, err)
|
|
|
|
defer head.Close()
|
|
|
|
|
|
|
|
lbls, err := labels.ReadLabels(filepath.Join("testdata", "20kseries.json"), nSeries)
|
|
|
|
testutil.Ok(tb, err)
|
|
|
|
refs := make([]uint64, nSeries)
|
|
|
|
|
|
|
|
for n := 0; n < nSamples; n++ {
|
|
|
|
app := head.Appender()
|
|
|
|
ts := n * 1000
|
|
|
|
for i, lbl := range lbls {
|
|
|
|
if refs[i] != 0 {
|
|
|
|
err := app.AddFast(refs[i], int64(ts), rand.Float64())
|
|
|
|
if err == nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ref, err := app.Add(lbl, int64(ts), rand.Float64())
|
|
|
|
testutil.Ok(tb, err)
|
|
|
|
refs[i] = ref
|
|
|
|
}
|
|
|
|
err := app.Commit()
|
|
|
|
testutil.Ok(tb, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
compactor, err := NewLeveledCompactor(nil, log.NewNopLogger(), []int64{1000000}, nil)
|
|
|
|
testutil.Ok(tb, err)
|
|
|
|
|
|
|
|
testutil.Ok(tb, os.MkdirAll(dir, 0777))
|
|
|
|
|
|
|
|
ulid, err := compactor.Write(dir, head, head.MinTime(), head.MaxTime(), nil)
|
|
|
|
testutil.Ok(tb, err)
|
|
|
|
|
|
|
|
blk, err := OpenBlock(filepath.Join(dir, ulid.String()), nil)
|
|
|
|
testutil.Ok(tb, err)
|
|
|
|
return blk
|
|
|
|
}
|