2023-03-08 16:04:54 +01:00
|
|
|
## Nim-Codex
|
|
|
|
## 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 pkg/chronos
|
|
|
|
|
|
|
|
import codex/utils/timer
|
|
|
|
|
|
|
|
type
|
|
|
|
MockTimer* = ref object of Timer
|
|
|
|
startCalled*: int
|
|
|
|
stopCalled*: int
|
|
|
|
mockInterval*: Duration
|
|
|
|
mockCallback: timer.TimerCallback
|
|
|
|
|
2023-06-22 08:11:18 -07:00
|
|
|
proc new*(T: type MockTimer): MockTimer =
|
|
|
|
## Create a mocked Timer instance
|
|
|
|
MockTimer(
|
2023-03-08 16:04:54 +01:00
|
|
|
startCalled: 0,
|
|
|
|
stopCalled: 0
|
|
|
|
)
|
|
|
|
|
2023-06-22 08:11:18 -07:00
|
|
|
method start*(
|
|
|
|
mockTimer: MockTimer,
|
|
|
|
callback: timer.TimerCallback,
|
|
|
|
interval: Duration
|
|
|
|
) =
|
2023-03-08 16:04:54 +01:00
|
|
|
mockTimer.mockCallback = callback
|
|
|
|
mockTimer.mockInterval = interval
|
|
|
|
inc mockTimer.startCalled
|
|
|
|
|
|
|
|
method stop*(mockTimer: MockTimer) {.async.} =
|
|
|
|
inc mockTimer.stopCalled
|
|
|
|
|
|
|
|
method invokeCallback*(mockTimer: MockTimer) {.async, base.} =
|
|
|
|
await mockTimer.mockCallback()
|