nim-eth/tests/db/test_kvstore.nim
Jacek Sieka 1995afb87e
kvstore fixes (#350)
Storing large blobs in a "WITHOUT ROWID" table turns out to be extremely
slow when the tree must be rebalanced.

* Split out keystore capability into separate interface, making each
keystore a separate instance
* Disable "WITHOUT ROWID" optimization by default
* Implement prefix lookup that allows iterating over all values with a
certain prefix in their key
2021-05-17 15:55:57 +02:00

73 lines
1.5 KiB
Nim

{.used.}
import
std/unittest,
../../eth/db/kvstore
const
key = [0'u8, 1, 2, 3]
value = [3'u8, 2, 1, 0]
value2 = [5'u8, 2, 1, 0]
key2 = [255'u8, 255]
proc testKvStore*(db: KvStoreRef, supportsFind: bool) =
check:
db != nil
not db.get(key, proc(data: openArray[byte]) = discard)[]
not db.contains(key)[]
db.del(key)[] # does nothing
db.put(key, value)[]
var k, v: seq[byte]
proc grab(data: openArray[byte]) =
v = @data
proc grab2(key, value: openArray[byte]) =
k = @key
v = @value
check:
db.contains(key)[]
db.get(key, grab)[]
v == value
db.put(key, value2)[] # overwrite old value
check:
db.contains(key)[]
db.get(key, grab)[]
v == value2
db.del(key)[]
check:
not db.get(key, proc(data: openArray[byte]) = discard)[]
not db.contains(key)[]
db.del(key)[] # does nothing
if supportsFind:
check:
db.find([], proc(key, value: openArray[byte]) = discard).get() == 0
db.put(key, value)[]
check:
db.find([], grab2).get() == 1
db.find(key, grab2).get() == 1
k == key
v == value
db.put(key2, value2)[]
check:
db.find([], grab2).get() == 2
db.find([byte 255], grab2).get() == 1
db.find([byte 255, 255], grab2).get() == 1
db.find([byte 255, 255, 0], grab2).get() == 0
db.find([byte 255, 255, 255], grab2).get() == 0
db.find([byte 255, 0], grab2).get() == 0
suite "MemoryStoreRef":
test "KvStore interface":
testKvStore(kvStore MemStoreRef.init(), true)