mirror of
https://github.com/logos-storage/apatheia.git
synced 2026-01-05 22:43:10 +00:00
31 lines
636 B
Nim
31 lines
636 B
Nim
|
|
import std/os
|
||
|
|
|
||
|
|
import chronicles
|
||
|
|
import chronos
|
||
|
|
import chronos/threadsync
|
||
|
|
import chronos/unittest2/asynctests
|
||
|
|
import taskpools
|
||
|
|
|
||
|
|
import apatheia/queues
|
||
|
|
import apatheia/jobs
|
||
|
|
|
||
|
|
proc addNumsRaw(a, b: float): float =
|
||
|
|
os.sleep(50)
|
||
|
|
return a + b
|
||
|
|
|
||
|
|
proc addNums(jobResult: JobResult[float], a, b: float) =
|
||
|
|
let res = addNumsRaw(a, b)
|
||
|
|
discard jobResult.queue.send((jobResult.id, res,))
|
||
|
|
|
||
|
|
suite "async tests":
|
||
|
|
|
||
|
|
var tp = Taskpool.new(num_threads = 2) # Default to the number of hardware threads.
|
||
|
|
|
||
|
|
asyncTest "test":
|
||
|
|
var jobs = newJobQueue[float](taskpool = tp)
|
||
|
|
|
||
|
|
let res = await jobs.submit(addNums(1.0, 2.0,))
|
||
|
|
|
||
|
|
check res == 3.0
|
||
|
|
|