From 97435b912494bccb494331f356b3b0be4cdf74e6 Mon Sep 17 00:00:00 2001 From: Jason Wilder Date: Thu, 10 Dec 2015 14:15:40 -0700 Subject: [PATCH] Return minTime/maxTime from BlockIterator.Read --- tsdb/engine/tsm1/reader.go | 8 ++++---- tsdb/engine/tsm1/reader_test.go | 29 ++++++++++++++++------------- tsdb/engine/tsm1/writer_test.go | 4 ++-- 3 files changed, 22 insertions(+), 19 deletions(-) diff --git a/tsdb/engine/tsm1/reader.go b/tsdb/engine/tsm1/reader.go index 0b68abb7d4..4ece9c8fbd 100644 --- a/tsdb/engine/tsm1/reader.go +++ b/tsdb/engine/tsm1/reader.go @@ -61,16 +61,16 @@ func (b *BlockIterator) Next() bool { return false } -func (b *BlockIterator) Read() (string, *IndexEntry, []byte, error) { +func (b *BlockIterator) Read() (string, time.Time, time.Time, []byte, error) { if b.err != nil { - return "", nil, nil, b.err + return "", time.Unix(0, 0), time.Unix(0, 0), nil, b.err } buf, err := b.r.readBytes(b.entries[0], nil) if err != nil { - return "", nil, nil, err + return "", time.Unix(0, 0), time.Unix(0, 0), nil, err } - return b.key, b.entries[0], buf, err + return b.key, b.entries[0].MinTime, b.entries[0].MaxTime, buf, err } // blockAccessor abstracts a method of accessing blocks from a diff --git a/tsdb/engine/tsm1/reader_test.go b/tsdb/engine/tsm1/reader_test.go index 1f93485680..69d87a93fe 100644 --- a/tsdb/engine/tsm1/reader_test.go +++ b/tsdb/engine/tsm1/reader_test.go @@ -573,7 +573,7 @@ func TestBlockIterator_Single(t *testing.T) { var count int iter := r.BlockIterator() for iter.Next() { - key, index, buf, err := iter.Read() + key, minTime, maxTime, buf, err := iter.Read() if err != nil { t.Fatalf("unexpected error creating iterator: %v", err) @@ -583,17 +583,18 @@ func TestBlockIterator_Single(t *testing.T) { t.Fatalf("key mismatch: got %v, exp %v", got, exp) } - if got, exp := index.MinTime, time.Unix(0, 0); got != exp { + if got, exp := minTime, time.Unix(0, 0); got != exp { t.Fatalf("min time mismatch: got %v, exp %v", got, exp) } - if got, exp := index.MaxTime, time.Unix(0, 0); got != exp { + if got, exp := maxTime, time.Unix(0, 0); got != exp { t.Fatalf("max time mismatch: got %v, exp %v", got, exp) } - if got, exp := uint32(len(buf)), index.Size; got != exp { - t.Fatalf("size mismatch: got %v, exp %v", got, exp) + if len(buf) == 0 { + t.Fatalf("buf length = 0") } + count++ } @@ -633,7 +634,7 @@ func TestBlockIterator_MultipleBlocks(t *testing.T) { iter := r.BlockIterator() var i int for iter.Next() { - key, index, buf, err := iter.Read() + key, minTime, maxTime, buf, err := iter.Read() if err != nil { t.Fatalf("unexpected error creating iterator: %v", err) @@ -643,17 +644,18 @@ func TestBlockIterator_MultipleBlocks(t *testing.T) { t.Fatalf("key mismatch: got %v, exp %v", got, exp) } - if got, exp := index.MinTime, expData[i][0].Time(); got != exp { + if got, exp := minTime, expData[i][0].Time(); got != exp { t.Fatalf("min time mismatch: got %v, exp %v", got, exp) } - if got, exp := index.MaxTime, expData[i][0].Time(); got != exp { + if got, exp := maxTime, expData[i][0].Time(); got != exp { t.Fatalf("max time mismatch: got %v, exp %v", got, exp) } - if got, exp := uint32(len(buf)), index.Size; got != exp { - t.Fatalf("size mismatch: got %v, exp %v", got, exp) + if len(buf) == 0 { + t.Fatalf("buf length = 0") } + count++ i++ } @@ -696,7 +698,7 @@ func TestBlockIterator_Sorted(t *testing.T) { iter := r.BlockIterator() var lastKey string for iter.Next() { - key, index, buf, err := iter.Read() + key, _, _, buf, err := iter.Read() if key < lastKey { t.Fatalf("keys not sorted: got %v, last %v", key, lastKey) @@ -708,9 +710,10 @@ func TestBlockIterator_Sorted(t *testing.T) { t.Fatalf("unexpected error creating iterator: %v", err) } - if got, exp := uint32(len(buf)), index.Size; got != exp { - t.Fatalf("size mismatch: got %v, exp %v", got, exp) + if len(buf) == 0 { + t.Fatalf("buf length = 0") } + count++ } diff --git a/tsdb/engine/tsm1/writer_test.go b/tsdb/engine/tsm1/writer_test.go index 812011c4ed..dc86a7642f 100644 --- a/tsdb/engine/tsm1/writer_test.go +++ b/tsdb/engine/tsm1/writer_test.go @@ -402,11 +402,11 @@ func TestTSMWriter_WriteBlock_Multiple(t *testing.T) { iter := r.BlockIterator() for iter.Next() { - key, entry, b, err := iter.Read() + key, minTime, maxTime, b, err := iter.Read() if err != nil { t.Fatalf("unexpected error reading block: %v", err) } - if err := w.WriteBlock(key, entry.MinTime, entry.MaxTime, b); err != nil { + if err := w.WriteBlock(key, minTime, maxTime, b); err != nil { t.Fatalf("unexpected error writing block: %v", err) } }