From b2f086c6c43cf4b1cc0ed5dc00ddd6ea45c76f96 Mon Sep 17 00:00:00 2001 From: beorn7 Date: Wed, 1 Feb 2017 15:34:03 +0100 Subject: [PATCH 1/2] storage: Expose bug of not setting the shrink ratio in the contstructor --- storage/local/persistence_test.go | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/storage/local/persistence_test.go b/storage/local/persistence_test.go index 27f620366..e88b17592 100644 --- a/storage/local/persistence_test.go +++ b/storage/local/persistence_test.go @@ -42,7 +42,7 @@ var ( func newTestPersistence(t *testing.T, encoding chunk.Encoding) (*persistence, testutil.Closer) { chunk.DefaultEncoding = encoding dir := testutil.NewTemporaryDirectory("test_persistence", t) - p, err := newPersistence(dir.Path(), false, false, func() bool { return false }, 0.1) + p, err := newPersistence(dir.Path(), false, false, func() bool { return false }, 0.15) if err != nil { dir.Close() t.Fatal(err) @@ -173,6 +173,25 @@ func testPersistLoadDropChunks(t *testing.T, encoding chunk.Encoding) { } } + // Try to drop one chunk, which must be prevented by the shrink ratio. + for fp, _ := range fpToChunks { + firstTime, offset, numDropped, allDropped, err := p.dropAndPersistChunks(fp, 1, nil) + if err != nil { + t.Fatal(err) + } + if offset != 0 { + t.Errorf("want offset 0, got %d", offset) + } + if firstTime != 0 { + t.Errorf("want first time 0, got %d", firstTime) + } + if numDropped != 0 { + t.Errorf("want 0 dropped chunks, got %v", numDropped) + } + if allDropped { + t.Error("all chunks dropped") + } + } // Drop half of the chunks. for fp, expectedChunks := range fpToChunks { firstTime, offset, numDropped, allDropped, err := p.dropAndPersistChunks(fp, 5, nil) From 4ccfc93dcfd2891a2fa9943175186bd796bcadb5 Mon Sep 17 00:00:00 2001 From: beorn7 Date: Wed, 1 Feb 2017 15:36:38 +0100 Subject: [PATCH 2/2] storage: Set shrink ratio in the constructor. --- storage/local/persistence.go | 1 + 1 file changed, 1 insertion(+) diff --git a/storage/local/persistence.go b/storage/local/persistence.go index 4d2733496..5015fb3c6 100644 --- a/storage/local/persistence.go +++ b/storage/local/persistence.go @@ -310,6 +310,7 @@ func newPersistence( dirtyFileName: dirtyPath, fLock: fLock, shouldSync: shouldSync, + minShrinkRatio: minShrinkRatio, // Create buffers of length 3*chunkLenWithHeader by default because that is still reasonably small // and at the same time enough for many uses. The contract is to never return buffer smaller than // that to the pool so that callers can rely on a minimum buffer size.