nim-datastore/tests/datastore/testthreadproxyds.nim

88 lines
1.9 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-07 17:33:33 -06:00
import pkg/asynctest
2023-08-24 19:51:04 -07:00
import pkg/chronos
import pkg/stew/results
import pkg/stew/byteutils
2023-09-08 15:09:15 -06:00
import pkg/taskpools
2023-08-24 19:51:04 -07:00
2023-08-28 21:45:55 -07:00
import pkg/datastore/memoryds
2023-09-08 15:09:15 -06:00
import pkg/datastore/threads/threadproxyds
2023-08-24 19:51:04 -07:00
import ./dscommontests
2023-09-08 15:09:15 -06:00
# import ./querycommontests
2023-08-24 19:51:04 -07:00
2023-08-24 22:20:49 -07:00
import pretty
2023-08-29 14:40:44 -07:00
2023-09-08 15:09:15 -06:00
# suite "Test Basic ThreadProxyDatastore":
# var
# sds: ThreadDatastore
# mem: MemoryDatastore
# key1: Key
# data: seq[byte]
# taskPool: Taskpool
# setupAll:
# mem = MemoryDatastore.new()
# taskPool = TaskPool.new(3)
# sds = ThreadDatastore.new(mem, taskPool).expect("should work")
# key1 = Key.init("/a").tryGet
# data = "value for 1".toBytes()
# test "check put":
# echo "\n\n=== put ==="
# let res1 = await sds.put(key1, data)
# print "res1: ", res1
# test "check get":
# echo "\n\n=== get ==="
# let res2 = await sds.get(key1)
# check res2.get() == data
# var val = ""
# for c in res2.get():
# val &= char(c)
# print "get res2: ", $val
# # 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
2023-08-25 15:00:18 -07:00
2023-08-29 12:50:36 -07:00
suite "Test Basic ThreadProxyDatastore":
2023-08-24 19:51:04 -07:00
2023-08-28 21:56:29 -07:00
var
memStore: MemoryDatastore
2023-09-08 15:09:15 -06:00
ds: ThreadDatastore
2023-08-28 21:56:29 -07:00
key = Key.init("/a/b").tryGet()
bytes = "some bytes".toBytes
otherBytes = "some other bytes".toBytes
2023-09-11 14:48:53 -06:00
taskPool: Taskpool
2023-08-24 19:51:04 -07:00
2023-08-28 21:56:29 -07:00
setupAll:
memStore = MemoryDatastore.new()
2023-09-11 14:48:53 -06:00
taskPool = Taskpool.new(2)
ds = ThreadDatastore.new(memStore, taskPool).tryGet()
2023-08-24 19:51:04 -07:00
2023-08-28 21:56:29 -07:00
teardownAll:
(await memStore.close()).get()
2023-08-24 19:51:04 -07:00
2023-08-28 22:18:08 -07:00
basicStoreTests(ds, key, bytes, otherBytes)
2023-08-24 19:51:04 -07:00
2023-09-08 15:09:15 -06:00
# suite "Test Query":
# var
# mem: MemoryDatastore
# sds: ThreadProxyDatastore
2023-08-24 19:51:04 -07:00
2023-09-08 15:09:15 -06:00
# setup:
# mem = MemoryDatastore.new()
# sds = newThreadProxyDatastore(mem).expect("should work")
2023-08-24 19:51:04 -07:00
2023-09-08 15:09:15 -06:00
# queryTests(sds, false)
2023-08-29 17:00:11 -07:00