nim-datastore/tests/datastore/sql/testsqliteds.nim

99 lines
2.0 KiB
Nim
Raw Normal View History

2022-09-16 21:15:08 -06:00
import std/options
import std/os
import std/sequtils
from std/algorithm import sort, reversed
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
import pkg/unittest2
2022-09-16 21:15:08 -06:00
import pkg/chronos
import pkg/stew/results
import pkg/stew/byteutils
import pkg/datastore/sql/sqliteds
2023-09-20 22:12:53 -07:00
import pkg/datastore/key
2022-09-16 21:15:08 -06:00
import ../dscommontests
import ../querycommontests
2022-09-19 15:53:38 -06:00
2023-09-20 23:07:52 -07:00
proc testBasic[K, V](
2023-09-20 22:49:11 -07:00
ds: SQLiteDatastore,
2023-09-20 23:07:52 -07:00
key: K,
bytes: V,
otherBytes: V,
2023-09-20 22:49:11 -07:00
) =
2022-09-19 15:53:38 -06:00
2023-09-20 22:12:53 -07:00
test "put":
ds.put(key, bytes).tryGet()
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
test "get":
check:
ds.get(key).tryGet() == bytes
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
test "put update":
ds.put(key, otherBytes).tryGet()
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
test "get updated":
check:
ds.get(key).tryGet() == otherBytes
2022-09-20 09:21:41 -06:00
2023-09-20 22:12:53 -07:00
test "delete":
ds.delete(key).tryGet()
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
test "contains":
2023-09-20 22:23:18 -07:00
check key notin ds
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
test "put batch":
var
2023-09-20 22:23:18 -07:00
batch: seq[tuple[key: string, data: seq[byte]]]
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
for k in 0..<100:
2023-09-20 22:23:18 -07:00
let kk = Key.init(key, $k).tryGet().id()
batch.add((kk, @[k.byte]))
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
ds.put(batch).tryGet
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
for k in batch:
check: ds.has(k.key).tryGet
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
test "delete batch":
var
2023-09-20 22:43:56 -07:00
batch: seq[string]
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
for k in 0..<100:
2023-09-20 22:43:56 -07:00
batch.add(Key.init(key, $k).tryGet().id())
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
ds.delete(batch).tryGet
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
for k in batch:
check: not ds.has(k).tryGet
test "handle missing key":
2023-09-20 22:43:56 -07:00
let key = Key.init("/missing/key").tryGet().id()
2022-09-16 21:15:08 -06:00
2023-09-20 22:12:53 -07:00
expect(DatastoreKeyNotFound):
discard ds.get(key).tryGet() # non existing key
2023-09-20 22:49:11 -07:00
suite "Test Basic SQLiteDatastore":
let
ds = SQLiteDatastore.new(Memory).tryGet()
keyFull = Key.init("a:b/c/d:e").tryGet()
key = keyFull.id()
bytes = "some bytes".toBytes
otherBytes = "some other bytes".toBytes
suiteTeardown:
ds.close().tryGet()
testBasic(ds, key, bytes, otherBytes)
2023-09-20 23:07:52 -07:00
suite "Test DataBuffer SQLiteDatastore":
let
ds = SQLiteDatastore.new(Memory).tryGet()
key = KeyId.new Key.init("a:b/c/d:e").tryGet().id()
bytes = DataBuffer.new "some bytes"
otherBytes = DataBuffer.new "some other bytes"
suiteTeardown:
ds.close().tryGet()
testBasic(ds, key, bytes, otherBytes)