2014-08-24 09:06:44 +02:00
|
|
|
// Copyright (c) 2014 Couchbase, Inc.
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
|
|
|
|
// except in compliance with the License. You may obtain a copy of the License at
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
// Unless required by applicable law or agreed to in writing, software distributed under the
|
|
|
|
// License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
|
|
// either express or implied. See the License for the specific language governing permissions
|
|
|
|
// and limitations under the License.
|
2014-09-02 16:54:50 +02:00
|
|
|
|
2014-08-24 09:06:44 +02:00
|
|
|
package boltdb
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
2014-11-26 03:52:23 +01:00
|
|
|
"github.com/blevesearch/bleve/index/store"
|
2015-09-23 20:25:47 +02:00
|
|
|
"github.com/blevesearch/bleve/index/store/test"
|
2016-06-14 21:36:40 +02:00
|
|
|
"github.com/boltdb/bolt"
|
2014-08-24 09:06:44 +02:00
|
|
|
)
|
|
|
|
|
2015-09-28 22:50:27 +02:00
|
|
|
func open(t *testing.T, mo store.MergeOperator) store.KVStore {
|
|
|
|
rv, err := New(mo, map[string]interface{}{"path": "test"})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
return rv
|
2015-09-23 20:25:47 +02:00
|
|
|
}
|
|
|
|
|
2015-09-28 22:50:27 +02:00
|
|
|
func cleanup(t *testing.T, s store.KVStore) {
|
|
|
|
err := s.Close()
|
2014-08-24 09:06:44 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2015-09-28 22:50:27 +02:00
|
|
|
err = os.RemoveAll("test")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
2014-08-24 09:06:44 +02:00
|
|
|
|
2015-09-28 22:50:27 +02:00
|
|
|
func TestBoltDBKVCrud(t *testing.T) {
|
|
|
|
s := open(t, nil)
|
|
|
|
defer cleanup(t, s)
|
2015-09-23 20:25:47 +02:00
|
|
|
test.CommonTestKVCrud(t, s)
|
2014-08-24 09:06:44 +02:00
|
|
|
}
|
2014-09-12 23:21:35 +02:00
|
|
|
|
2015-09-23 20:25:47 +02:00
|
|
|
func TestBoltDBReaderIsolation(t *testing.T) {
|
2015-09-28 22:50:27 +02:00
|
|
|
s := open(t, nil)
|
|
|
|
defer cleanup(t, s)
|
2015-09-23 20:25:47 +02:00
|
|
|
test.CommonTestReaderIsolation(t, s)
|
2014-11-26 03:52:23 +01:00
|
|
|
}
|
|
|
|
|
2015-09-23 20:25:47 +02:00
|
|
|
func TestBoltDBReaderOwnsGetBytes(t *testing.T) {
|
2015-09-28 22:50:27 +02:00
|
|
|
s := open(t, nil)
|
|
|
|
defer cleanup(t, s)
|
2015-09-23 20:25:47 +02:00
|
|
|
test.CommonTestReaderOwnsGetBytes(t, s)
|
2014-11-26 03:52:23 +01:00
|
|
|
}
|
|
|
|
|
2015-09-23 20:25:47 +02:00
|
|
|
func TestBoltDBWriterOwnsBytes(t *testing.T) {
|
2015-09-28 22:50:27 +02:00
|
|
|
s := open(t, nil)
|
|
|
|
defer cleanup(t, s)
|
2015-09-23 20:25:47 +02:00
|
|
|
test.CommonTestWriterOwnsBytes(t, s)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBoltDBPrefixIterator(t *testing.T) {
|
2015-09-28 22:50:27 +02:00
|
|
|
s := open(t, nil)
|
|
|
|
defer cleanup(t, s)
|
2015-09-23 20:25:47 +02:00
|
|
|
test.CommonTestPrefixIterator(t, s)
|
|
|
|
}
|
2014-11-26 03:52:23 +01:00
|
|
|
|
2015-10-26 21:14:29 +01:00
|
|
|
func TestBoltDBPrefixIteratorSeek(t *testing.T) {
|
|
|
|
s := open(t, nil)
|
|
|
|
defer cleanup(t, s)
|
|
|
|
test.CommonTestPrefixIteratorSeek(t, s)
|
|
|
|
}
|
|
|
|
|
2015-09-23 20:25:47 +02:00
|
|
|
func TestBoltDBRangeIterator(t *testing.T) {
|
2015-09-28 22:50:27 +02:00
|
|
|
s := open(t, nil)
|
|
|
|
defer cleanup(t, s)
|
2015-09-23 20:25:47 +02:00
|
|
|
test.CommonTestRangeIterator(t, s)
|
|
|
|
}
|
2014-11-26 03:52:23 +01:00
|
|
|
|
2015-10-20 19:01:29 +02:00
|
|
|
func TestBoltDBRangeIteratorSeek(t *testing.T) {
|
|
|
|
s := open(t, nil)
|
|
|
|
defer cleanup(t, s)
|
|
|
|
test.CommonTestRangeIteratorSeek(t, s)
|
|
|
|
}
|
|
|
|
|
2015-09-23 20:25:47 +02:00
|
|
|
func TestBoltDBMerge(t *testing.T) {
|
2015-09-28 22:50:27 +02:00
|
|
|
s := open(t, &test.TestMergeCounter{})
|
|
|
|
defer cleanup(t, s)
|
2015-09-23 20:25:47 +02:00
|
|
|
test.CommonTestMerge(t, s)
|
2014-09-12 23:21:35 +02:00
|
|
|
}
|
2016-06-14 21:36:40 +02:00
|
|
|
|
|
|
|
func TestBoltDBConfig(t *testing.T) {
|
|
|
|
var tests = []struct {
|
|
|
|
in map[string]interface{}
|
|
|
|
path string
|
|
|
|
bucket string
|
|
|
|
noSync bool
|
|
|
|
fillPercent float64
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
map[string]interface{}{"path": "test", "bucket": "mybucket", "nosync": true, "fillPercent": 0.75},
|
|
|
|
"test",
|
|
|
|
"mybucket",
|
|
|
|
true,
|
|
|
|
0.75,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
map[string]interface{}{"path": "test"},
|
|
|
|
"test",
|
|
|
|
"bleve",
|
|
|
|
false,
|
|
|
|
bolt.DefaultFillPercent,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
kv, err := New(nil, test.in)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
bs, ok := kv.(*Store)
|
|
|
|
if !ok {
|
|
|
|
t.Fatal("failed type assertion to *boltdb.Store")
|
|
|
|
}
|
|
|
|
if bs.path != test.path {
|
|
|
|
t.Fatalf("path: expected %q, got %q", test.path, bs.path)
|
|
|
|
}
|
|
|
|
if bs.bucket != test.bucket {
|
|
|
|
t.Fatalf("bucket: expected %q, got %q", test.bucket, bs.bucket)
|
|
|
|
}
|
|
|
|
if bs.noSync != test.noSync {
|
|
|
|
t.Fatalf("noSync: expected %t, got %t", test.noSync, bs.noSync)
|
|
|
|
}
|
|
|
|
if bs.fillPercent != test.fillPercent {
|
|
|
|
t.Fatalf("fillPercent: expected %f, got %f", test.fillPercent, bs.fillPercent)
|
|
|
|
}
|
|
|
|
cleanup(t, kv)
|
|
|
|
}
|
|
|
|
}
|