prysm-pulse/sharding/database/inmemory_test.go
Terence Tsao 035d0fb669 sharding/node: use ethdb.Database, remove database.ShardBackend
Former-commit-id: 44c0c5682c0296d94943b354171e69b4c8cf5312 [formerly 54da5cb45b098f0737fb3c37964e612dfe93c751]
Former-commit-id: 5d84d3c5038a01c4108e519d5a5c69033ace8ae2
2018-06-08 14:45:26 -07:00

81 lines
1.7 KiB
Go

package database
import (
"testing"
"github.com/ethereum/go-ethereum/ethdb"
)
// Verifies that ShardKV implements the ethdb interface.
var _ = ethdb.Database(&ShardKV{})
func Test_ShardKVPut(t *testing.T) {
kv := NewShardKV()
if err := kv.Put([]byte("ralph merkle"), []byte{1, 2, 3}); err != nil {
t.Errorf("could not save value in kv store: %v", err)
}
}
func Test_ShardKVHas(t *testing.T) {
kv := NewShardKV()
key := []byte("ralph merkle")
if err := kv.Put(key, []byte{1, 2, 3}); err != nil {
t.Fatalf("could not save value in kv store: %v", err)
}
has, err := kv.Has(key)
if err != nil {
t.Errorf("could not check if kv store has key: %v", err)
}
if !has {
t.Errorf("kv store should have key: %v", key)
}
key2 := []byte{}
has2, err := kv.Has(key2)
if err != nil {
t.Errorf("could not check if kv store has key: %v", err)
}
if has2 {
t.Errorf("kv store should not have non-existent key: %v", key2)
}
}
func Test_ShardKVGet(t *testing.T) {
kv := NewShardKV()
key := []byte("ralph merkle")
if err := kv.Put(key, []byte{1, 2, 3}); err != nil {
t.Fatalf("could not save value in kv store: %v", err)
}
val, err := kv.Get(key)
if err != nil {
t.Errorf("get failed: %v", err)
}
if len(val) == 0 {
t.Errorf("no value stored for key")
}
key2 := []byte{}
val2, err := kv.Get(key2)
if len(val2) != 0 {
t.Errorf("non-existent key should not have a value. key=%v, value=%v", key2, val2)
}
}
func Test_ShardKVDelete(t *testing.T) {
kv := NewShardKV()
key := []byte("ralph merkle")
if err := kv.Put(key, []byte{1, 2, 3}); err != nil {
t.Fatalf("could not save value in kv store: %v", err)
}
if err := kv.Delete(key); err != nil {
t.Errorf("could not delete key: %v", key)
}
}