mirror of
https://github.com/logos-storage/apatheia.git
synced 2026-01-02 13:03:11 +00:00
* asyncTaskMacro * checks * taskpools examples * setup examples * queues * example workers future complete * fire signal * setup jobs * logging * cleanup * docs
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
|
|
|