0
0

refactored store tests to share common code

This commit is contained in:
Marty Schoch 2014-05-15 10:18:43 -04:00
parent d48eee948e
commit cd5ea0991f
4 changed files with 90 additions and 202 deletions

View File

@ -3,80 +3,16 @@ package gouchstore
import (
"os"
"testing"
"github.com/couchbaselabs/bleve/index/store/test"
)
func TestGouchstoreStore(t *testing.T) {
store, err := Open("test")
s, err := Open("test")
if err != nil {
t.Fatal(err)
}
defer os.RemoveAll("test")
err = store.Set([]byte("a"), []byte("val-a"))
if err != nil {
t.Fatal(err)
}
err = store.Set([]byte("z"), []byte("val-z"))
if err != nil {
t.Fatal(err)
}
err = store.Delete([]byte("z"))
if err != nil {
t.Fatal(err)
}
batch := store.NewBatch()
batch.Set([]byte("a"), []byte("val-a"))
batch.Set([]byte("b"), []byte("val-b"))
batch.Set([]byte("c"), []byte("val-c"))
batch.Set([]byte("d"), []byte("val-d"))
batch.Set([]byte("e"), []byte("val-e"))
batch.Set([]byte("f"), []byte("val-f"))
batch.Set([]byte("g"), []byte("val-g"))
batch.Set([]byte("h"), []byte("val-h"))
batch.Set([]byte("i"), []byte("val-i"))
batch.Set([]byte("j"), []byte("val-j"))
err = batch.Execute()
if err != nil {
t.Fatal(err)
}
it := store.Iterator([]byte("b"))
key, val, valid := it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "b" {
t.Fatalf("exepcted key b, got %s", key)
}
if string(val) != "val-b" {
t.Fatalf("expected value val-b, got %s", val)
}
it.Next()
key, val, valid = it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "c" {
t.Fatalf("exepcted key c, got %s", key)
}
if string(val) != "val-c" {
t.Fatalf("expected value val-c, got %s", val)
}
it.Seek([]byte("i"))
key, val, valid = it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "i" {
t.Fatalf("exepcted key i, got %s", key)
}
if string(val) != "val-i" {
t.Fatalf("expected value val-i, got %s", val)
}
it.Close()
store_test.CommonTestKVStore(t, s)
}

View File

@ -2,78 +2,16 @@ package inmem
import (
"testing"
"github.com/couchbaselabs/bleve/index/store/test"
)
func TestInMemStore(t *testing.T) {
store, err := Open()
s, err := Open()
if err != nil {
t.Fatal(err)
}
defer s.Close()
err = store.Set([]byte("a"), []byte("val-a"))
if err != nil {
t.Fatal(err)
}
err = store.Set([]byte("z"), []byte("val-z"))
if err != nil {
t.Fatal(err)
}
err = store.Delete([]byte("z"))
if err != nil {
t.Fatal(err)
}
batch := store.NewBatch()
batch.Set([]byte("b"), []byte("val-b"))
batch.Set([]byte("c"), []byte("val-c"))
batch.Set([]byte("d"), []byte("val-d"))
batch.Set([]byte("e"), []byte("val-e"))
batch.Set([]byte("f"), []byte("val-f"))
batch.Set([]byte("g"), []byte("val-g"))
batch.Set([]byte("h"), []byte("val-h"))
batch.Set([]byte("i"), []byte("val-i"))
batch.Set([]byte("j"), []byte("val-j"))
err = batch.Execute()
if err != nil {
t.Fatal(err)
}
it := store.Iterator([]byte("b"))
key, val, valid := it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "b" {
t.Fatalf("exepcted key b, got %s", key)
}
if string(val) != "val-b" {
t.Fatalf("expected value val-b, got %s", val)
}
it.Next()
key, val, valid = it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "c" {
t.Fatalf("exepcted key c, got %s", key)
}
if string(val) != "val-c" {
t.Fatalf("expected value val-c, got %s", val)
}
it.Seek([]byte("i"))
key, val, valid = it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "i" {
t.Fatalf("exepcted key i, got %s", key)
}
if string(val) != "val-i" {
t.Fatalf("expected value val-i, got %s", val)
}
it.Close()
store_test.CommonTestKVStore(t, s)
}

View File

@ -3,79 +3,16 @@ package leveldb
import (
"os"
"testing"
"github.com/couchbaselabs/bleve/index/store/test"
)
func TestLevelDBStore(t *testing.T) {
store, err := Open("test")
s, err := Open("test")
if err != nil {
t.Fatal(err)
}
defer os.RemoveAll("test")
err = store.Set([]byte("a"), []byte("val-a"))
if err != nil {
t.Fatal(err)
}
err = store.Set([]byte("z"), []byte("val-z"))
if err != nil {
t.Fatal(err)
}
err = store.Delete([]byte("z"))
if err != nil {
t.Fatal(err)
}
batch := store.NewBatch()
batch.Set([]byte("b"), []byte("val-b"))
batch.Set([]byte("c"), []byte("val-c"))
batch.Set([]byte("d"), []byte("val-d"))
batch.Set([]byte("e"), []byte("val-e"))
batch.Set([]byte("f"), []byte("val-f"))
batch.Set([]byte("g"), []byte("val-g"))
batch.Set([]byte("h"), []byte("val-h"))
batch.Set([]byte("i"), []byte("val-i"))
batch.Set([]byte("j"), []byte("val-j"))
err = batch.Execute()
if err != nil {
t.Fatal(err)
}
it := store.Iterator([]byte("b"))
key, val, valid := it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "b" {
t.Fatalf("exepcted key b, got %s", key)
}
if string(val) != "val-b" {
t.Fatalf("expected value val-b, got %s", val)
}
it.Next()
key, val, valid = it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "c" {
t.Fatalf("exepcted key c, got %s", key)
}
if string(val) != "val-c" {
t.Fatalf("expected value val-c, got %s", val)
}
it.Seek([]byte("i"))
key, val, valid = it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "i" {
t.Fatalf("exepcted key i, got %s", key)
}
if string(val) != "val-i" {
t.Fatalf("expected value val-i, got %s", val)
}
it.Close()
store_test.CommonTestKVStore(t, s)
}

View File

@ -0,0 +1,77 @@
package store_test
import (
"testing"
"github.com/couchbaselabs/bleve/index/store"
)
func CommonTestKVStore(t *testing.T, s store.KVStore) {
err := s.Set([]byte("a"), []byte("val-a"))
if err != nil {
t.Fatal(err)
}
err = s.Set([]byte("z"), []byte("val-z"))
if err != nil {
t.Fatal(err)
}
err = s.Delete([]byte("z"))
if err != nil {
t.Fatal(err)
}
batch := s.NewBatch()
batch.Set([]byte("b"), []byte("val-b"))
batch.Set([]byte("c"), []byte("val-c"))
batch.Set([]byte("d"), []byte("val-d"))
batch.Set([]byte("e"), []byte("val-e"))
batch.Set([]byte("f"), []byte("val-f"))
batch.Set([]byte("g"), []byte("val-g"))
batch.Set([]byte("h"), []byte("val-h"))
batch.Set([]byte("i"), []byte("val-i"))
batch.Set([]byte("j"), []byte("val-j"))
err = batch.Execute()
if err != nil {
t.Fatal(err)
}
it := s.Iterator([]byte("b"))
key, val, valid := it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "b" {
t.Fatalf("exepcted key b, got %s", key)
}
if string(val) != "val-b" {
t.Fatalf("expected value val-b, got %s", val)
}
it.Next()
key, val, valid = it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "c" {
t.Fatalf("exepcted key c, got %s", key)
}
if string(val) != "val-c" {
t.Fatalf("expected value val-c, got %s", val)
}
it.Seek([]byte("i"))
key, val, valid = it.Current()
if !valid {
t.Fatalf("valid false, expected true")
}
if string(key) != "i" {
t.Fatalf("exepcted key i, got %s", key)
}
if string(val) != "val-i" {
t.Fatalf("expected value val-i, got %s", val)
}
it.Close()
}