# Chronos Test Suite # (c) Copyright 2018-Present # Status Research & Development GmbH # # Licensed under either of # Apache License, version 2.0, (LICENSE-APACHEv2) # MIT license (LICENSE-MIT) import os, unittest import ../chronos, ../chronos/timer suite "Asynchronous timers test suite": const TimersCount = 10 proc timeWorker(time: Duration): Future[Duration] {.async.} = var st = Moment.now() await sleepAsync(time) var et = Moment.now() result = et - st proc waitAll[T](futs: seq[Future[T]]): Future[void] = var counter = len(futs) var retFuture = newFuture[void]("waitAll") proc cb(udata: pointer) = dec(counter) if counter == 0: retFuture.complete() for fut in futs: fut.addCallback(cb) return retFuture proc test(timeout: Duration): Future[Duration] {.async.} = var workers = newSeq[Future[Duration]](TimersCount) for i in 0..= 1000.milliseconds) and (d <= 3000.milliseconds) if not result: echo d test "Timer reliability test [" & asyncTimer & "]": check testTimer() == true test $TimersCount & " timers with 10ms timeout": var res = waitFor(test(10.milliseconds)) check (res >= 10.milliseconds) and (res <= 100.milliseconds) test $TimersCount & " timers with 100ms timeout": var res = waitFor(test(100.milliseconds)) check (res >= 100.milliseconds) and (res <= 1000.milliseconds) test $TimersCount & " timers with 1000ms timeout": var res = waitFor(test(1000.milliseconds)) check (res >= 1000.milliseconds) and (res <= 5000.milliseconds)