2023-08-22 04:04:47 +03:00
|
|
|
# nim-raft
|
|
|
|
# Copyright (c) 2023 Status Research & Development GmbH
|
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
|
|
|
|
# at your option.
|
|
|
|
# This file may not be copied, modified, or distributed except according to
|
|
|
|
# those terms.
|
|
|
|
|
|
|
|
import unittest2
|
|
|
|
import basic_timers
|
2023-08-25 12:00:40 +03:00
|
|
|
import random
|
2023-08-22 04:04:47 +03:00
|
|
|
|
2023-08-25 12:00:40 +03:00
|
|
|
const
|
|
|
|
MAX_TIMERS = 50
|
|
|
|
SLOW_TIMERS_MIN = 300
|
2023-08-25 12:33:31 +03:00
|
|
|
SLOW_TIMERS_MAX = 400
|
|
|
|
FAST_TIMERS_MIN = 10
|
|
|
|
FAST_TIMERS_MAX = 100
|
|
|
|
WAIT_FOR_SLOW_TIMERS = 200
|
|
|
|
FINAL_WAIT = 300
|
2023-08-22 04:04:47 +03:00
|
|
|
|
2023-08-31 17:05:41 +03:00
|
|
|
proc basicTimersMain*() =
|
2023-08-22 04:04:47 +03:00
|
|
|
var
|
2023-09-03 03:53:48 +03:00
|
|
|
slowTimers: array[0..MAX_TIMERS, Future[void]]
|
|
|
|
fastTimers: array[0..MAX_TIMERS, Future[void]]
|
2023-08-22 04:04:47 +03:00
|
|
|
|
2023-08-25 12:00:40 +03:00
|
|
|
var
|
2023-09-03 03:53:48 +03:00
|
|
|
slowCnt: ref int
|
|
|
|
RaftDummyTimerCallback = proc () {.nimcall, gcsafe.} = discard
|
|
|
|
RaftTimerCallbackCnt = proc (cnt: ref int): RaftTimerCallback =
|
|
|
|
proc () {.gcsafe.} = cnt[].inc
|
|
|
|
|
|
|
|
slowCnt = new(int)
|
|
|
|
slowCnt[] = 0
|
2023-08-22 04:04:47 +03:00
|
|
|
|
|
|
|
suite "Create and test basic timers":
|
2023-08-25 12:33:31 +03:00
|
|
|
|
|
|
|
test "Create 'slow' and 'fast' timers":
|
2023-08-25 12:00:40 +03:00
|
|
|
for i in 0..MAX_TIMERS:
|
2023-10-13 07:24:35 +03:00
|
|
|
slowTimers[i] = raftTimerCreateCustomImpl(max(SLOW_TIMERS_MIN, rand(SLOW_TIMERS_MAX)), RaftTimerCallbackCnt(slowCnt))
|
2023-08-25 12:33:31 +03:00
|
|
|
|
2023-08-25 12:00:40 +03:00
|
|
|
for i in 0..MAX_TIMERS:
|
2023-10-13 07:24:35 +03:00
|
|
|
fastTimers[i] = raftTimerCreateCustomImpl(max(FAST_TIMERS_MIN, rand(FAST_TIMERS_MAX)), RaftDummyTimerCallback)
|
2023-08-25 12:33:31 +03:00
|
|
|
|
2023-08-25 12:00:40 +03:00
|
|
|
test "Wait for and cancel 'slow' timers":
|
2023-11-05 01:22:33 +02:00
|
|
|
waitFor sleepAsync(milliseconds(WAIT_FOR_SLOW_TIMERS))
|
2023-08-25 12:00:40 +03:00
|
|
|
for i in 0..MAX_TIMERS:
|
2023-09-03 03:53:48 +03:00
|
|
|
if not slowTimers[i].finished:
|
2023-09-06 19:18:02 +03:00
|
|
|
asyncSpawn cancelAndWait(slowTimers[i])
|
2023-08-25 12:33:31 +03:00
|
|
|
|
2023-11-05 01:22:33 +02:00
|
|
|
test "Final wait timers and check consistency":
|
2023-08-25 12:33:31 +03:00
|
|
|
var
|
|
|
|
pass = true
|
|
|
|
|
2023-11-05 01:22:33 +02:00
|
|
|
waitFor sleepAsync(milliseconds(FINAL_WAIT))
|
|
|
|
|
2023-08-25 12:00:40 +03:00
|
|
|
for i in 0..MAX_TIMERS:
|
2023-09-03 03:53:48 +03:00
|
|
|
if not fastTimers[i].finished:
|
|
|
|
debugEcho repr(fastTimers[i])
|
2023-08-25 12:33:31 +03:00
|
|
|
pass = false
|
|
|
|
break
|
|
|
|
|
|
|
|
check pass
|
2023-09-03 03:53:48 +03:00
|
|
|
check slowCnt[] == 0
|
2023-08-22 04:04:47 +03:00
|
|
|
|
|
|
|
if isMainModule:
|
2023-08-31 17:05:41 +03:00
|
|
|
basicTimersMain()
|