2018-06-21 14:33:36 -07:00
|
|
|
package store
|
|
|
|
|
|
|
|
import (
|
|
|
|
"math/rand"
|
|
|
|
"testing"
|
|
|
|
|
2018-06-29 18:10:15 -07:00
|
|
|
"github.com/stretchr/testify/require"
|
2018-06-21 14:33:36 -07:00
|
|
|
|
|
|
|
"github.com/tendermint/iavl"
|
2018-07-02 13:34:06 -07:00
|
|
|
dbm "github.com/tendermint/tendermint/libs/db"
|
2018-06-21 14:33:36 -07:00
|
|
|
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
)
|
|
|
|
|
|
|
|
type kvpair struct {
|
|
|
|
key []byte
|
|
|
|
value []byte
|
|
|
|
}
|
|
|
|
|
|
|
|
func setRandomKVPairs(t *testing.T, store KVStore) []kvpair {
|
|
|
|
kvps := make([]kvpair, 20)
|
|
|
|
|
|
|
|
for i := 0; i < 20; i++ {
|
|
|
|
kvps[i].key = make([]byte, 32)
|
|
|
|
rand.Read(kvps[i].key)
|
|
|
|
kvps[i].value = make([]byte, 32)
|
|
|
|
rand.Read(kvps[i].value)
|
|
|
|
|
|
|
|
store.Set(kvps[i].key, kvps[i].value)
|
|
|
|
}
|
|
|
|
|
|
|
|
return kvps
|
|
|
|
}
|
|
|
|
|
|
|
|
func testPrefixStore(t *testing.T, baseStore KVStore, prefix []byte) {
|
|
|
|
prefixStore := baseStore.Prefix(prefix)
|
2018-07-26 18:24:18 -07:00
|
|
|
prefixPrefixStore := prefixStore.Prefix([]byte("prefix"))
|
2018-06-21 14:33:36 -07:00
|
|
|
|
2018-07-26 18:24:18 -07:00
|
|
|
kvps := setRandomKVPairs(t, prefixPrefixStore)
|
2018-06-21 14:33:36 -07:00
|
|
|
|
|
|
|
for i := 0; i < 20; i++ {
|
|
|
|
key := kvps[i].key
|
2018-07-26 18:24:18 -07:00
|
|
|
value := kvps[i].value
|
|
|
|
require.True(t, prefixPrefixStore.Has(key))
|
|
|
|
require.Equal(t, value, prefixPrefixStore.Get(key))
|
|
|
|
|
|
|
|
key = append([]byte("prefix"), key...)
|
|
|
|
require.True(t, prefixStore.Has(key))
|
|
|
|
require.Equal(t, value, prefixStore.Get(key))
|
|
|
|
key = append(prefix, key...)
|
|
|
|
require.True(t, baseStore.Has(key))
|
|
|
|
require.Equal(t, value, baseStore.Get(key))
|
|
|
|
|
|
|
|
key = kvps[i].key
|
|
|
|
prefixPrefixStore.Delete(key)
|
|
|
|
require.False(t, prefixPrefixStore.Has(key))
|
|
|
|
require.Nil(t, prefixPrefixStore.Get(key))
|
|
|
|
key = append([]byte("prefix"), key...)
|
|
|
|
require.False(t, prefixStore.Has(key))
|
|
|
|
require.Nil(t, prefixStore.Get(key))
|
|
|
|
key = append(prefix, key...)
|
|
|
|
require.False(t, baseStore.Has(key))
|
|
|
|
require.Nil(t, baseStore.Get(key))
|
2018-06-21 14:33:36 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestIAVLStorePrefix(t *testing.T) {
|
|
|
|
db := dbm.NewMemDB()
|
|
|
|
tree := iavl.NewVersionedTree(db, cacheSize)
|
2018-06-26 13:01:45 -07:00
|
|
|
iavlStore := newIAVLStore(tree, numRecent, storeEvery)
|
2018-06-21 14:33:36 -07:00
|
|
|
|
|
|
|
testPrefixStore(t, iavlStore, []byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCacheKVStorePrefix(t *testing.T) {
|
|
|
|
cacheStore := newCacheKVStore()
|
|
|
|
|
|
|
|
testPrefixStore(t, cacheStore, []byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGasKVStorePrefix(t *testing.T) {
|
|
|
|
meter := sdk.NewGasMeter(100000000)
|
|
|
|
mem := dbStoreAdapter{dbm.NewMemDB()}
|
2018-07-26 18:24:18 -07:00
|
|
|
gasStore := NewGasKVStore(meter, sdk.DefaultGasConfig(), mem)
|
2018-06-21 14:33:36 -07:00
|
|
|
|
|
|
|
testPrefixStore(t, gasStore, []byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPrefixStoreIterate(t *testing.T) {
|
|
|
|
db := dbm.NewMemDB()
|
|
|
|
baseStore := dbStoreAdapter{db}
|
|
|
|
prefix := []byte("test")
|
|
|
|
prefixStore := baseStore.Prefix(prefix)
|
|
|
|
|
|
|
|
setRandomKVPairs(t, prefixStore)
|
|
|
|
|
|
|
|
bIter := sdk.KVStorePrefixIterator(baseStore, prefix)
|
|
|
|
pIter := sdk.KVStorePrefixIterator(prefixStore, nil)
|
|
|
|
|
|
|
|
for bIter.Valid() && pIter.Valid() {
|
2018-06-29 18:10:15 -07:00
|
|
|
require.Equal(t, bIter.Key(), append(prefix, pIter.Key()...))
|
|
|
|
require.Equal(t, bIter.Value(), pIter.Value())
|
2018-06-21 14:33:36 -07:00
|
|
|
|
|
|
|
bIter.Next()
|
|
|
|
pIter.Next()
|
|
|
|
}
|
|
|
|
|
2018-06-29 18:10:15 -07:00
|
|
|
require.Equal(t, bIter.Valid(), pIter.Valid())
|
2018-06-21 14:33:36 -07:00
|
|
|
bIter.Close()
|
|
|
|
pIter.Close()
|
|
|
|
}
|