2023-08-24 19:51:04 -07:00
|
|
|
import std/options
|
|
|
|
|
import std/sequtils
|
|
|
|
|
import std/os
|
2023-09-13 14:43:25 -06:00
|
|
|
import std/cpuinfo
|
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-09-13 14:43:25 -06:00
|
|
|
import pkg/datastore/sql
|
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-13 14:43:25 -06:00
|
|
|
import ./querycommontests
|
2023-08-24 19:51:04 -07:00
|
|
|
|
2023-09-13 14:43:25 -06:00
|
|
|
suite "Test Basic ThreadDatastore":
|
2023-08-24 19:51:04 -07:00
|
|
|
|
2023-08-28 21:56:29 -07:00
|
|
|
var
|
2023-09-13 14:43:25 -06:00
|
|
|
memStore: Datastore
|
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:
|
2023-09-13 14:43:25 -06:00
|
|
|
memStore = SQLiteDatastore.new(Memory).tryGet()
|
|
|
|
|
taskPool = Taskpool.new(countProcessors() * 2)
|
2023-09-11 14:48:53 -06:00
|
|
|
ds = ThreadDatastore.new(memStore, taskPool).tryGet()
|
2023-08-24 19:51:04 -07:00
|
|
|
|
2023-08-28 21:56:29 -07:00
|
|
|
teardownAll:
|
2023-09-13 14:43:25 -06:00
|
|
|
(await ds.close()).tryGet()
|
|
|
|
|
taskPool.shutdown()
|
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-13 14:43:25 -06:00
|
|
|
suite "Test Query ThreadDatastore":
|
|
|
|
|
var
|
|
|
|
|
mem: Datastore
|
|
|
|
|
ds: ThreadDatastore
|
|
|
|
|
taskPool: Taskpool
|
2023-08-24 19:51:04 -07:00
|
|
|
|
2023-09-13 14:43:25 -06:00
|
|
|
setup:
|
|
|
|
|
taskPool = Taskpool.new(countProcessors() * 2)
|
|
|
|
|
mem = SQLiteDatastore.new(Memory).tryGet()
|
|
|
|
|
ds = ThreadDatastore.new(mem, taskPool).tryGet()
|
2023-08-24 19:51:04 -07:00
|
|
|
|
2023-09-13 14:43:25 -06:00
|
|
|
teardown:
|
|
|
|
|
(await ds.close()).tryGet()
|
|
|
|
|
taskPool.shutdown()
|
2023-08-29 17:00:11 -07:00
|
|
|
|
2023-09-13 14:43:25 -06:00
|
|
|
queryTests(ds, false)
|