X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/c447d4a79f653bbf2c172a0a715d30db896a4a32..b7b9ea44ada30b1251fb10c872cb1da1d7c29bd0:/services/keepstore/keepstore_test.go diff --git a/services/keepstore/keepstore_test.go b/services/keepstore/keepstore_test.go index 7a882e0eec..c0adbc0bd7 100644 --- a/services/keepstore/keepstore_test.go +++ b/services/keepstore/keepstore_test.go @@ -10,6 +10,8 @@ import ( "sort" "strings" "testing" + + "git.curoverse.com/arvados.git/sdk/go/arvadostest" ) var TestBlock = []byte("The quick brown fox jumps over the lazy dog.") @@ -64,12 +66,13 @@ func TestGetBlock(t *testing.T) { } // Check that GetBlock returns success. - result, err := GetBlock(TestHash) + buf := make([]byte, BlockSize) + size, err := GetBlock(TestHash, buf, nil) if err != nil { t.Errorf("GetBlock error: %s", err) } - if fmt.Sprint(result) != fmt.Sprint(TestBlock) { - t.Errorf("expected %s, got %s", TestBlock, result) + if bytes.Compare(buf[:size], TestBlock) != 0 { + t.Errorf("got %v, expected %v", buf[:size], TestBlock) } } @@ -84,9 +87,10 @@ func TestGetBlockMissing(t *testing.T) { defer KeepVM.Close() // Check that GetBlock returns failure. - result, err := GetBlock(TestHash) + buf := make([]byte, BlockSize) + size, err := GetBlock(TestHash, buf, nil) if err != NotFoundError { - t.Errorf("Expected NotFoundError, got %v", result) + t.Errorf("Expected NotFoundError, got %v, err %v", buf[:size], err) } } @@ -105,9 +109,10 @@ func TestGetBlockCorrupt(t *testing.T) { vols[0].Put(TestHash, BadBlock) // Check that GetBlock returns failure. - result, err := GetBlock(TestHash) + buf := make([]byte, BlockSize) + size, err := GetBlock(TestHash, buf, nil) if err != DiskHashError { - t.Errorf("Expected DiskHashError, got %v (buf: %v)", err, result) + t.Errorf("Expected DiskHashError, got %v (buf: %v)", err, buf[:size]) } } @@ -126,18 +131,19 @@ func TestPutBlockOK(t *testing.T) { defer KeepVM.Close() // Check that PutBlock stores the data as expected. - if err := PutBlock(TestBlock, TestHash); err != nil { - t.Fatalf("PutBlock: %v", err) + if n, err := PutBlock(TestBlock, TestHash); err != nil || n < 1 { + t.Fatalf("PutBlock: n %d err %v", n, err) } vols := KeepVM.AllReadable() - result, err := vols[1].Get(TestHash) + buf := make([]byte, BlockSize) + n, err := vols[1].Get(TestHash, buf) if err != nil { t.Fatalf("Volume #0 Get returned error: %v", err) } - if string(result) != string(TestBlock) { + if string(buf[:n]) != string(TestBlock) { t.Fatalf("PutBlock stored '%s', Get retrieved '%s'", - string(TestBlock), string(result)) + string(TestBlock), string(buf[:n])) } } @@ -156,18 +162,18 @@ func TestPutBlockOneVol(t *testing.T) { vols[0].(*MockVolume).Bad = true // Check that PutBlock stores the data as expected. - if err := PutBlock(TestBlock, TestHash); err != nil { - t.Fatalf("PutBlock: %v", err) + if n, err := PutBlock(TestBlock, TestHash); err != nil || n < 1 { + t.Fatalf("PutBlock: n %d err %v", n, err) } - result, err := GetBlock(TestHash) + buf := make([]byte, BlockSize) + size, err := GetBlock(TestHash, buf, nil) if err != nil { t.Fatalf("GetBlock: %v", err) } - if string(result) != string(TestBlock) { - t.Error("PutBlock/GetBlock mismatch") - t.Fatalf("PutBlock stored '%s', GetBlock retrieved '%s'", - string(TestBlock), string(result)) + if bytes.Compare(buf[:size], TestBlock) != 0 { + t.Fatalf("PutBlock stored %+q, GetBlock retrieved %+q", + TestBlock, buf[:size]) } } @@ -184,12 +190,12 @@ func TestPutBlockMD5Fail(t *testing.T) { // Check that PutBlock returns the expected error when the hash does // not match the block. - if err := PutBlock(BadBlock, TestHash); err != RequestHashError { - t.Error("Expected RequestHashError, got %v", err) + if _, err := PutBlock(BadBlock, TestHash); err != RequestHashError { + t.Errorf("Expected RequestHashError, got %v", err) } // Confirm that GetBlock fails to return anything. - if result, err := GetBlock(TestHash); err != NotFoundError { + if result, err := GetBlock(TestHash, make([]byte, BlockSize), nil); err != NotFoundError { t.Errorf("GetBlock succeeded after a corrupt block store (result = %s, err = %v)", string(result), err) } @@ -209,15 +215,16 @@ func TestPutBlockCorrupt(t *testing.T) { // Store a corrupted block under TestHash. vols := KeepVM.AllWritable() vols[0].Put(TestHash, BadBlock) - if err := PutBlock(TestBlock, TestHash); err != nil { - t.Errorf("PutBlock: %v", err) + if n, err := PutBlock(TestBlock, TestHash); err != nil || n < 1 { + t.Errorf("PutBlock: n %d err %v", n, err) } // The block on disk should now match TestBlock. - if block, err := GetBlock(TestHash); err != nil { + buf := make([]byte, BlockSize) + if size, err := GetBlock(TestHash, buf, nil); err != nil { t.Errorf("GetBlock: %v", err) - } else if bytes.Compare(block, TestBlock) != 0 { - t.Errorf("GetBlock returned: '%s'", string(block)) + } else if bytes.Compare(buf[:size], TestBlock) != 0 { + t.Errorf("Got %+q, expected %+q", buf[:size], TestBlock) } } @@ -229,9 +236,9 @@ func TestPutBlockCollision(t *testing.T) { defer teardown() // These blocks both hash to the MD5 digest cee9a457e790cf20d4bdaa6d69f01e41. - var b1 = []byte("\x0e0eaU\x9a\xa7\x87\xd0\x0b\xc6\xf7\x0b\xbd\xfe4\x04\xcf\x03e\x9epO\x854\xc0\x0f\xfbe\x9cL\x87@\xcc\x94/\xeb-\xa1\x15\xa3\xf4\x15\\\xbb\x86\x07Is\x86em}\x1f4\xa4 Y\xd7\x8fZ\x8d\xd1\xef") - var b2 = []byte("\x0e0eaU\x9a\xa7\x87\xd0\x0b\xc6\xf7\x0b\xbd\xfe4\x04\xcf\x03e\x9etO\x854\xc0\x0f\xfbe\x9cL\x87@\xcc\x94/\xeb-\xa1\x15\xa3\xf4\x15\xdc\xbb\x86\x07Is\x86em}\x1f4\xa4 Y\xd7\x8fZ\x8d\xd1\xef") - var locator = "cee9a457e790cf20d4bdaa6d69f01e41" + b1 := arvadostest.MD5CollisionData[0] + b2 := arvadostest.MD5CollisionData[1] + locator := arvadostest.MD5CollisionMD5 // Prepare two test Keep volumes. KeepVM = MakeTestVolumeManager(2) @@ -239,10 +246,10 @@ func TestPutBlockCollision(t *testing.T) { // Store one block, then attempt to store the other. Confirm that // PutBlock reported a CollisionError. - if err := PutBlock(b1, locator); err != nil { + if _, err := PutBlock(b1, locator); err != nil { t.Error(err) } - if err := PutBlock(b2, locator); err == nil { + if _, err := PutBlock(b2, locator); err == nil { t.Error("PutBlock did not report a collision") } else if err != CollisionError { t.Errorf("PutBlock returned %v", err) @@ -273,8 +280,8 @@ func TestPutBlockTouchFails(t *testing.T) { // vols[0].Touch will fail on the next call, so the volume // manager will store a copy on vols[1] instead. vols[0].(*MockVolume).Touchable = false - if err := PutBlock(TestBlock, TestHash); err != nil { - t.Fatalf("PutBlock: %v", err) + if n, err := PutBlock(TestBlock, TestHash); err != nil || n < 1 { + t.Fatalf("PutBlock: n %d err %v", n, err) } vols[0].(*MockVolume).Touchable = true @@ -288,12 +295,13 @@ func TestPutBlockTouchFails(t *testing.T) { t.Errorf("mtime was changed on vols[0]:\noldMtime = %v\nnewMtime = %v\n", oldMtime, newMtime) } - result, err := vols[1].Get(TestHash) + buf := make([]byte, BlockSize) + n, err := vols[1].Get(TestHash, buf) if err != nil { t.Fatalf("vols[1]: %v", err) } - if bytes.Compare(result, TestBlock) != 0 { - t.Errorf("new block does not match test block\nnew block = %v\n", result) + if bytes.Compare(buf[:n], TestBlock) != 0 { + t.Errorf("new block does not match test block\nnew block = %v\n", buf[:n]) } } @@ -333,8 +341,8 @@ func TestDiscoverTmpfs(t *testing.T) { f.Close() ProcMounts = f.Name() - var resultVols volumeSet - added := resultVols.Discover() + resultVols := volumeSet{} + added := (&unixVolumeAdder{&resultVols}).Discover() if added != len(resultVols) { t.Errorf("Discover returned %d, but added %d volumes", @@ -373,8 +381,8 @@ func TestDiscoverNone(t *testing.T) { f.Close() ProcMounts = f.Name() - var resultVols volumeSet - added := resultVols.Discover() + resultVols := volumeSet{} + added := (&unixVolumeAdder{&resultVols}).Discover() if added != 0 || len(resultVols) != 0 { t.Fatalf("got %d, %v; expected 0, []", added, resultVols) } @@ -418,44 +426,6 @@ func TestIndex(t *testing.T) { } } -// TestKeepStoreGetEmptyBlock -func TestKeepStoreGetEmptyBlock(t *testing.T) { - defer teardown() - - // Prepare two mock volumes - KeepVM = MakeTestVolumeManager(2) - defer KeepVM.Close() - - vols := KeepVM.AllWritable() - if err := vols[0].Put(EmptyHash, EmptyBlock); err != nil { - t.Error("Error putting empty block: %s", err) - } - - // Check that GetBlock returns success. - result, err := GetBlock(EmptyHash) - if err != nil { - t.Errorf("Get error for empty hash: %s", err) - } - if bytes.Compare(result, EmptyBlock) != 0 { - t.Errorf("Get response incorrect. Expected %q; found %q", EmptyBlock, result) - } -} - -// TestKeepStoreGetEmptyBlockNotExists that does not exist -func TestKeepStoreGetEmptyBlockNotExists(t *testing.T) { - defer teardown() - - // Prepare two mock volumes - KeepVM = MakeTestVolumeManager(2) - defer KeepVM.Close() - - // Check that GetBlock returns error. - _, err := GetBlock(EmptyHash) - if err == nil { - t.Errorf("Expected error when getting non-existing empty block") - } -} - // ======================================== // Helper functions for unit tests. // ========================================