nim-datastore/tests/datastore/testthreadproxyds.nim

118 lines
2.8 KiB
Nim
Raw Normal View History

2023-08-24 19:51:04 -07:00
import std/options
import std/sequtils
import std/os
2023-08-28 21:45:55 -07:00
import std/algorithm
2023-08-24 19:51:04 -07:00
2023-09-11 16:57:23 -07:00
import pkg/asynctest
2023-08-24 19:51:04 -07:00
import pkg/chronos
import pkg/stew/results
import pkg/stew/byteutils
2023-08-28 21:45:55 -07:00
import pkg/datastore/memoryds
2023-08-29 12:50:36 -07:00
import pkg/datastore/threadproxyds
2023-08-24 19:51:04 -07:00
import ./dscommontests
import ./querycommontests
2023-09-13 12:26:29 -07:00
import pretty
2023-08-24 22:20:49 -07:00
2023-09-14 22:17:20 -07:00
proc testThreadProxy() =
suite "Test Basic ThreadProxyDatastore":
var
2023-09-19 20:44:06 -07:00
mem: Datastore2[MemoryDatastore]
2023-09-19 20:16:27 -07:00
sds: ThreadProxyDatastore[MemoryDatastore]
2023-09-14 22:17:20 -07:00
key1: Key
data: seq[byte]
setupAll:
2023-09-19 20:16:27 -07:00
mem = initMemoryDatastore()
2023-09-14 22:17:20 -07:00
sds = newThreadProxyDatastore(mem).expect("should work")
key1 = Key.init("/a").tryGet
data = "value for 1".toBytes()
2023-09-19 20:59:20 -07:00
teardownAll:
let res = await sds.close()
res.get()
echo "teardown done"
2023-09-14 22:17:20 -07:00
test "check put":
# echo "\n\n=== put ==="
let res1 = await sds.put(key1, data)
# echo "res1: ", res1.repr
check res1.isOk
test "check get":
# echo "\n\n=== get ==="
# echo "get send key: ", key1.repr
let res2 = await sds.get(key1)
# echo "get key post: ", key1.repr
# echo "get res2: ", res2.repr
# echo res2.get() == data
var val = ""
for c in res2.get():
val &= char(c)
# print "get res2: ", $val
2023-09-19 20:48:59 -07:00
GC_fullCollect()
2023-09-14 22:17:20 -07:00
proc testThreadProxyBasics() =
suite "Test Basics":
var
2023-09-19 20:44:06 -07:00
mem = initMemoryDatastore()
2023-09-14 22:17:20 -07:00
sds = newThreadProxyDatastore(mem).expect("should work")
let
key = Key.init("/a/b").tryGet()
bytes = "some bytes".toBytes
otherBytes = "some other bytes".toBytes
# echo "\n\n=== put cancel ==="
# # let res1 = await sds.put(key1, "value for 1".toBytes())
# let res3 = sds.put(key1, "value for 1".toBytes())
# res3.cancel()
# # print "res3: ", res3
basicStoreTests(sds, key, bytes, otherBytes)
2023-09-19 20:48:59 -07:00
GC_fullCollect()
2023-09-14 22:17:20 -07:00
2023-09-19 20:16:27 -07:00
# proc testThreadProxyQuery() =
# suite "Test Query":
# var
# mem: MemoryDatastore
# sds: ThreadProxyDatastore
2023-09-14 22:17:20 -07:00
2023-09-19 20:16:27 -07:00
# setup:
# mem = MemoryDatastore.new()
# sds = newThreadProxyDatastore(mem).expect("should work")
2023-09-14 22:17:20 -07:00
2023-09-19 20:16:27 -07:00
# queryTests(sds, false)
2023-09-14 22:17:20 -07:00
2023-09-19 20:16:27 -07:00
# test "query iter fails":
2023-09-14 22:17:20 -07:00
2023-09-19 20:16:27 -07:00
# expect FutureDefect:
# let q = Query.init(key1)
2023-09-14 22:17:20 -07:00
2023-09-19 20:16:27 -07:00
# (await sds.put(key1, val1)).tryGet
# (await sds.put(key2, val2)).tryGet
# (await sds.put(key3, val3)).tryGet
2023-09-14 22:17:20 -07:00
2023-09-19 20:16:27 -07:00
# let
# iter = (await sds.query(q)).tryGet
# res = (await allFinished(toSeq(iter)))
# .mapIt(it.read.tryGet)
# .filterIt(it.key.isSome)
2023-09-14 22:17:20 -07:00
2023-09-19 20:16:27 -07:00
# check res.len() > 0
2023-09-14 22:17:20 -07:00
when isMainModule:
2023-09-19 19:33:05 -07:00
for i in 1..100:
2023-09-14 22:17:20 -07:00
testThreadProxy()
testThreadProxyBasics()
2023-09-19 20:48:59 -07:00
GC_fullCollect()
2023-09-14 22:17:20 -07:00
# testThreadProxyQuery()
else:
testThreadProxy()
testThreadProxyBasics()
testThreadProxyQuery()
2023-09-14 19:11:39 -07:00
# GC_fullCollect() # this fails due to MemoryStore already being freed...