From ada0945b8fcbdc7ead552111424b6bc003242e13 Mon Sep 17 00:00:00 2001 From: Brian Brazil Date: Sat, 4 Jan 2020 14:55:02 +0000 Subject: [PATCH] Fix tsdb code and tests to work on Windows. (#6547) Add back Windows CI, we lost it when tsdb was merged into the prometheus repo. There's many tests failing outside tsdb, so only test tsdb for now. Fixes #6513 Signed-off-by: Brian Brazil --- .circleci/config.yml | 12 ++++++++++++ tsdb/block_test.go | 2 ++ tsdb/db_test.go | 2 ++ tsdb/index/index.go | 25 ++++++++++++++++++------- tsdb/index/index_test.go | 1 + tsdb/wal/watcher_test.go | 1 + 6 files changed, 36 insertions(+), 7 deletions(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index 55496f2f6..e7992d245 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -4,6 +4,7 @@ version: 2.1 orbs: prometheus: prometheus/prometheus@0.3.0 go: circleci/go@0.2.0 + win: circleci/windows@2.3.0 executors: # Whenever the Go version is updated here, .promu.yml @@ -49,6 +50,13 @@ jobs: key: v1-npm-deps-{{ checksum "web/ui/react-app/yarn.lock" }} paths: - web/ui/react-app/node_modules + test_windows: + executor: win/default + working_directory: /go/src/github.com/prometheus/prometheus + steps: + - checkout + # TSDB is where the most risk is Windows wise, so only test there for now. + - run: go test ./tsdb/... fuzzit_regression: executor: fuzzit working_directory: /go/src/github.com/prometheus/prometheus @@ -78,6 +86,10 @@ workflows: filters: tags: only: /.*/ + - test_windows: + filters: + tags: + only: /.*/ - fuzzit_regression: filters: tags: diff --git a/tsdb/block_test.go b/tsdb/block_test.go index f746ccd4b..0f83ac5c0 100644 --- a/tsdb/block_test.go +++ b/tsdb/block_test.go @@ -197,9 +197,11 @@ func TestCorruptedChunk(t *testing.T) { testutil.Equals(t, test.openErr.Error(), err.Error()) return } + defer func() { testutil.Ok(t, b.Close()) }() querier, err := NewBlockQuerier(b, 0, 1) testutil.Ok(t, err) + defer func() { testutil.Ok(t, querier.Close()) }() set, err := querier.Select(labels.MustNewMatcher(labels.MatchEqual, "a", "b")) testutil.Ok(t, err) diff --git a/tsdb/db_test.go b/tsdb/db_test.go index 70d79118f..9063b741a 100644 --- a/tsdb/db_test.go +++ b/tsdb/db_test.go @@ -2655,6 +2655,7 @@ func TestChunkWriter_ReadAfterWrite(t *testing.T) { // Check the content of the chunks. r, err := chunks.NewDirReader(tempDir, nil) testutil.Ok(t, err) + defer func() { testutil.Ok(t, r.Close()) }() for _, chks := range test.chks { for _, chkExp := range chks { @@ -2705,4 +2706,5 @@ func TestChunkReader_ConcurrentReads(t *testing.T) { } wg.Wait() } + testutil.Ok(t, r.Close()) } diff --git a/tsdb/index/index.go b/tsdb/index/index.go index 700c5da7e..18fa0360e 100644 --- a/tsdb/index/index.go +++ b/tsdb/index/index.go @@ -511,11 +511,11 @@ func (w *Writer) finishSymbols() error { return err } - var err error - w.symbolFile, err = fileutil.OpenMmapFile(w.f.name) + sf, err := fileutil.OpenMmapFile(w.f.name) if err != nil { return err } + w.symbolFile = sf hash := crc32.Checksum(w.symbolFile.Bytes()[w.toc.Symbols+4:hashPos], castagnoliTable) w.buf1.Reset() w.buf1.PutBE32(hash) @@ -700,7 +700,11 @@ func (w *Writer) writePostingsOffsetTable() error { if err != nil { return err } - defer f.Close() + defer func() { + if f != nil { + f.Close() + } + }() d := encoding.NewDecbufRaw(realByteSlice(f.Bytes()), int(w.fPO.pos)) cnt := w.cntPO for d.Err() == nil && cnt > 0 { @@ -720,6 +724,10 @@ func (w *Writer) writePostingsOffsetTable() error { } // Cleanup temporary file. + if err := f.Close(); err != nil { + return err + } + f = nil if err := w.fPO.close(); err != nil { return err } @@ -962,9 +970,9 @@ type labelIndexHashEntry struct { } func (w *Writer) Close() error { - if err := w.ensureStage(idxStageDone); err != nil { - return err - } + // Even if this fails, we need to close all the files. + ensureErr := w.ensureStage(idxStageDone) + if w.symbolFile != nil { if err := w.symbolFile.Close(); err != nil { return err @@ -980,7 +988,10 @@ func (w *Writer) Close() error { return err } } - return w.f.close() + if err := w.f.close(); err != nil { + return err + } + return ensureErr } // StringTuples provides access to a sorted list of string tuples. diff --git a/tsdb/index/index_test.go b/tsdb/index/index_test.go index a8bf59112..4a0b6b8df 100644 --- a/tsdb/index/index_test.go +++ b/tsdb/index/index_test.go @@ -280,6 +280,7 @@ func TestPostingsMany(t *testing.T) { ir, err := NewFileReader(fn) testutil.Ok(t, err) + defer func() { testutil.Ok(t, ir.Close()) }() cases := []struct { in []string diff --git a/tsdb/wal/watcher_test.go b/tsdb/wal/watcher_test.go index 8378e997d..db8e3e89f 100644 --- a/tsdb/wal/watcher_test.go +++ b/tsdb/wal/watcher_test.go @@ -427,6 +427,7 @@ func TestReadCheckpointMultipleSegments(t *testing.T) { } } } + testutil.Ok(t, w.Close()) // At this point we should have at least 6 segments, lets create a checkpoint dir of the first 5. checkpointDir := dir + "/wal/checkpoint.000004"