apatheia/tests/tjobs.nim

78 lines
2.1 KiB
Nim
Raw Normal View History

import std/os
import chronicles
import chronos
import chronos/threadsync
import chronos/unittest2/asynctests
import taskpools
import apatheia/queues
import apatheia/jobs
import apatheia/memretainers
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,))
proc addNumsIncorrect(jobResult: JobResult[float], vals: openArray[float]): float =
discard
proc addNumValues(jobResult: JobResult[float], base: float, vals: OpenArrayHolder[float]) =
os.sleep(100)
var res = base
for x in vals.toOpenArray():
res += x
discard jobResult.queue.send((jobResult.id, res,))
proc strCompute(jobResult: JobResult[int], vals: OpenArrayHolder[char]) =
discard jobResult.queue.send((jobResult.id, vals.size,))
proc addStrings(jobResult: JobResult[float], vals: OpenArrayHolder[string]) =
discard
suite "async tests":
var tp = Taskpool.new(num_threads = 2) # Default to the number of hardware threads.
asyncTest "cannot return value":
check not compiles(await jobs.submit(addNums(1.0, 2.0,)))
asyncTest "test":
var jobs = newJobQueue[float](taskpool = tp)
let res = await jobs.submit(addNums(1.0, 2.0,))
check res == 3.0
asyncTest "testing seq":
var jobs = newJobQueue[float](taskpool = tp)
let res = await jobs.submit(addNumValues(10.0, @[1.0.float, 2.0]))
check res == 13.0
asyncTest "testing string":
var jobs = newJobQueue[int](taskpool = tp)
let res = await jobs.submit(strCompute("hello world!"))
check res == 12
asyncTest "testing arrays":
var jobs = newJobQueue[float](taskpool = tp)
let fut1 = jobs.submit(addNumValues(10.0, @[1.0.float, 2.0]))
let fut2 = jobs.submit(addNumValues(20.0, @[3.0.float, 4.0]))
check retainedMemoryCount() == 2
let res1 = await fut1
let res2 = await fut2
check res1 == 13.0
check res2 == 27.0
check retainedMemoryCount() == 0
asyncTest "don't compile":
check not compiles(
block:
var jobs = newJobQueue[float](taskpool = tp)
let job = jobs.submit(addStrings(@["a", "b", "c"]))
)