refactored store tests to share common code
This commit is contained in:
parent
d48eee948e
commit
cd5ea0991f
|
@ -3,80 +3,16 @@ package gouchstore
|
||||||
import (
|
import (
|
||||||
"os"
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/couchbaselabs/bleve/index/store/test"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestGouchstoreStore(t *testing.T) {
|
func TestGouchstoreStore(t *testing.T) {
|
||||||
store, err := Open("test")
|
s, err := Open("test")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
defer os.RemoveAll("test")
|
defer os.RemoveAll("test")
|
||||||
|
|
||||||
err = store.Set([]byte("a"), []byte("val-a"))
|
store_test.CommonTestKVStore(t, s)
|
||||||
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()
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,78 +2,16 @@ package inmem
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/couchbaselabs/bleve/index/store/test"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestInMemStore(t *testing.T) {
|
func TestInMemStore(t *testing.T) {
|
||||||
store, err := Open()
|
s, err := Open()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
defer s.Close()
|
||||||
|
|
||||||
err = store.Set([]byte("a"), []byte("val-a"))
|
store_test.CommonTestKVStore(t, s)
|
||||||
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()
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,79 +3,16 @@ package leveldb
|
||||||
import (
|
import (
|
||||||
"os"
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/couchbaselabs/bleve/index/store/test"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestLevelDBStore(t *testing.T) {
|
func TestLevelDBStore(t *testing.T) {
|
||||||
store, err := Open("test")
|
s, err := Open("test")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
defer os.RemoveAll("test")
|
defer os.RemoveAll("test")
|
||||||
|
|
||||||
err = store.Set([]byte("a"), []byte("val-a"))
|
store_test.CommonTestKVStore(t, s)
|
||||||
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()
|
|
||||||
}
|
}
|
||||||
|
|
77
index/store/test/common.go
Normal file
77
index/store/test/common.go
Normal 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()
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user