2024-02-13 10:18:02 +05:30
|
|
|
{.used.}
|
|
|
|
|
|
|
|
import
|
|
|
|
testutils/unittests,
|
|
|
|
chronos,
|
|
|
|
os
|
|
|
|
import
|
|
|
|
../../../waku/waku_rln_relay/nonce_manager
|
|
|
|
|
|
|
|
|
|
|
|
suite "Nonce manager":
|
|
|
|
test "should initialize successfully":
|
|
|
|
let nm = NonceManager.init(nonceLimit = 100.uint)
|
|
|
|
|
|
|
|
check:
|
|
|
|
nm.nonceLimit == 100.uint
|
|
|
|
nm.nextNonce == 0.uint
|
|
|
|
|
|
|
|
test "should generate a new nonce":
|
|
|
|
let nm = NonceManager.init(nonceLimit = 100.uint)
|
2024-03-12 16:20:30 +05:30
|
|
|
let nonce = nm.getNonce().valueOr:
|
|
|
|
raiseAssert $error
|
2024-02-13 10:18:02 +05:30
|
|
|
|
|
|
|
check:
|
2024-03-12 16:20:30 +05:30
|
|
|
nonce == 0.uint
|
2024-02-13 10:18:02 +05:30
|
|
|
nm.nextNonce == 1.uint
|
|
|
|
|
|
|
|
test "should fail to generate a new nonce if limit is reached":
|
|
|
|
let nm = NonceManager.init(nonceLimit = 1.uint)
|
2024-03-12 16:20:30 +05:30
|
|
|
let nonce = nm.getNonce().valueOr:
|
|
|
|
raiseAssert $error
|
|
|
|
let failedNonceRes = nm.getNonce()
|
2024-02-13 10:18:02 +05:30
|
|
|
|
|
|
|
check:
|
2024-03-12 16:20:30 +05:30
|
|
|
failedNonceRes.isErr()
|
|
|
|
failedNonceRes.error.kind == NonceManagerErrorKind.NonceLimitReached
|
2024-02-13 10:18:02 +05:30
|
|
|
|
|
|
|
test "should generate a new nonce if epoch is crossed":
|
|
|
|
let nm = NonceManager.init(nonceLimit = 1.uint, epoch = float(0.000001))
|
2024-03-12 16:20:30 +05:30
|
|
|
let nonce = nm.getNonce().valueOr:
|
|
|
|
raiseAssert $error
|
2024-02-13 10:18:02 +05:30
|
|
|
sleep(1)
|
2024-03-12 16:20:30 +05:30
|
|
|
let nonce2 = nm.getNonce().valueOr:
|
|
|
|
raiseAssert $error
|
2024-02-13 10:18:02 +05:30
|
|
|
|
|
|
|
check:
|
2024-03-12 16:20:30 +05:30
|
|
|
nonce == 0.uint
|
|
|
|
nonce2 == 0.uint
|