nim-raft/tests/test_basic_timers.nim

66 lines
1.7 KiB
Nim
Raw Normal View History

# 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 ../raft/types
import std/locks
import basic_timers
2023-08-25 12:00:40 +03:00
import random
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-31 17:05:41 +03:00
proc basicTimersMain*() =
var
slowTimers: array[0..MAX_TIMERS, RaftTimer]
fastTimers: array[0..MAX_TIMERS, RaftTimer]
2023-08-25 12:00:40 +03:00
var
RaftDummyTimerCallback = proc (timer: RaftTimer) {.nimcall, gcsafe.} =
discard
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:
slowTimers[i] = RaftTimerCreateCustomImpl(max(SLOW_TIMERS_MIN, rand(SLOW_TIMERS_MAX)), true, RaftDummyTimerCallback)
2023-08-25 12:33:31 +03:00
2023-08-25 12:00:40 +03:00
for i in 0..MAX_TIMERS:
fastTimers[i] = RaftTimerCreateCustomImpl(max(FAST_TIMERS_MIN, rand(FAST_TIMERS_MAX)), true, 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-08-31 17:05:41 +03:00
waitFor sleepAsync(WAIT_FOR_SLOW_TIMERS)
2023-08-25 12:00:40 +03:00
for i in 0..MAX_TIMERS:
RaftTimerCancelCustomImpl(slowTimers[i])
2023-08-25 12:33:31 +03:00
2023-08-31 17:05:41 +03:00
test "Final wait timers":
2023-08-25 12:00:40 +03:00
waitFor sleepAsync(FINAL_WAIT)
2023-08-25 12:33:31 +03:00
test "Check timers consistency":
2023-08-25 12:33:31 +03:00
var
pass = true
2023-08-25 12:00:40 +03:00
for i in 0..MAX_TIMERS:
2023-08-25 12:33:31 +03:00
if not fastTimers[i].expired:
pass = false
break
if not slowTimers[i].canceled:
pass = false
break
check pass
if isMainModule:
2023-08-31 17:05:41 +03:00
basicTimersMain()