89 lines
2.0 KiB
Go
89 lines
2.0 KiB
Go
|
// Copyright (c) 2016 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.
|
||
|
|
||
|
package moss
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/blevesearch/bleve/index/store"
|
||
|
"github.com/blevesearch/bleve/index/store/test"
|
||
|
)
|
||
|
|
||
|
func open(t *testing.T, mo store.MergeOperator) store.KVStore {
|
||
|
rv, err := New(mo, nil)
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
return rv
|
||
|
}
|
||
|
|
||
|
func cleanup(t *testing.T, s store.KVStore) {
|
||
|
err := s.Close()
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestMossKVCrud(t *testing.T) {
|
||
|
s := open(t, nil)
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestKVCrud(t, s)
|
||
|
}
|
||
|
|
||
|
func TestMossReaderIsolation(t *testing.T) {
|
||
|
s := open(t, nil)
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestReaderIsolation(t, s)
|
||
|
}
|
||
|
|
||
|
func TestMossReaderOwnsGetBytes(t *testing.T) {
|
||
|
s := open(t, nil)
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestReaderOwnsGetBytes(t, s)
|
||
|
}
|
||
|
|
||
|
func TestMossWriterOwnsBytes(t *testing.T) {
|
||
|
s := open(t, nil)
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestWriterOwnsBytes(t, s)
|
||
|
}
|
||
|
|
||
|
func TestMossPrefixIterator(t *testing.T) {
|
||
|
s := open(t, nil)
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestPrefixIterator(t, s)
|
||
|
}
|
||
|
|
||
|
func TestMossPrefixIteratorSeek(t *testing.T) {
|
||
|
s := open(t, nil)
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestPrefixIteratorSeek(t, s)
|
||
|
}
|
||
|
|
||
|
func TestMossRangeIterator(t *testing.T) {
|
||
|
s := open(t, nil)
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestRangeIterator(t, s)
|
||
|
}
|
||
|
|
||
|
func TestMossRangeIteratorSeek(t *testing.T) {
|
||
|
s := open(t, nil)
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestRangeIteratorSeek(t, s)
|
||
|
}
|
||
|
|
||
|
func TestMossMerge(t *testing.T) {
|
||
|
s := open(t, &test.TestMergeCounter{})
|
||
|
defer cleanup(t, s)
|
||
|
test.CommonTestMerge(t, s)
|
||
|
}
|