mirror of
https://github.com/logos-storage/apatheia.git
synced 2026-01-02 13:03:11 +00:00
54 lines
1.1 KiB
Nim
54 lines
1.1 KiB
Nim
import std/os
|
|
import std/sequtils
|
|
|
|
import chronos
|
|
import chronos/threadsync
|
|
import chronos/unittest2/asynctests
|
|
import taskpools
|
|
|
|
import apatheia/queues
|
|
import apatheia/jobs
|
|
|
|
type
|
|
DataObj = ref object
|
|
data: seq[char]
|
|
|
|
proc worker(data: OpenArrayHolder[char], queue: SignalQueue[int]) =
|
|
os.sleep(1_000)
|
|
echo "worker: ", data.toOpenArray()
|
|
discard queue.send(data.toOpenArray().len())
|
|
|
|
proc finalizer(obj: DataObj) =
|
|
echo "FINALIZE!!"
|
|
|
|
proc runTest(tp: TaskPool, queue: SignalQueue[int]) {.async.} =
|
|
## init
|
|
var obj: DataObj
|
|
new(obj, finalizer)
|
|
obj.data = "hello world!".toSeq
|
|
|
|
echo "spawn worker"
|
|
tp.spawn worker(toArrayHolder(obj.data), queue)
|
|
|
|
let res =
|
|
await wait(queue).wait(100.milliseconds)
|
|
check res.get() == 12
|
|
|
|
suite "async tests":
|
|
|
|
var tp = Taskpool.new(num_threads = 2) # Default to the number of hardware threads.
|
|
var queue = newSignalQueue[int]()
|
|
|
|
asyncTest "test":
|
|
|
|
try:
|
|
await runTest(tp, queue)
|
|
except AsyncTimeoutError as err:
|
|
echo "Run GC"
|
|
GC_fullCollect()
|
|
os.sleep(2_000)
|
|
echo "Done"
|
|
|
|
|
|
|