use `closureScope` with `{.raises.}` in `test_peer_pool` (#5992)

`test_peer_pool` is a bit different from the other tests as it uses
`closureScope` which doesn't play well with `{.push raises: [].}`.
Define an overload instead that allows passing `{.raises.}` to the
`template`. This allows using `unittest2`'s exception handler without
having to refactor the test.
This commit is contained in:
Etan Kissling 2024-02-29 01:57:19 +01:00 committed by GitHub
parent 078f4ac347
commit 794ec9ed19
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 8 additions and 4 deletions

View File

@ -1,10 +1,11 @@
# beacon_chain # beacon_chain
# Copyright (c) 2019-2021 Status Research & Development GmbH # Copyright (c) 2019-2024 Status Research & Development GmbH
# Licensed and distributed under either of # Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT). # * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
# at your option. This file may not be copied, modified, or distributed except according to those terms. # at your option. This file may not be copied, modified, or distributed except according to those terms.
{.push raises: [].}
{.used.} {.used.}
import std/[random, heapqueue, tables] import std/[random, heapqueue, tables]
@ -12,6 +13,9 @@ import chronos
import ../beacon_chain/networking/peer_pool import ../beacon_chain/networking/peer_pool
import ./testutil import ./testutil
template closureScope(raisesAnnotation: untyped, body: untyped): untyped =
(proc() {.raises: raisesAnnotation} = body)()
type type
PeerTestID = string PeerTestID = string
PeerTest = object PeerTest = object
@ -237,7 +241,7 @@ suite "PeerPool testing suite":
itemFut23.finished == false itemFut23.finished == false
itemFut24.finished == false itemFut24.finished == false
test "Acquire/Sorting and consistency test": closureScope: test "Acquire/Sorting and consistency test": closureScope([CatchableError]):
const const
TestsCount = 1000 TestsCount = 1000
MaxNumber = 1_000_000 MaxNumber = 1_000_000
@ -411,7 +415,7 @@ suite "PeerPool testing suite":
check waitFor(testPeerLifetime()) == true check waitFor(testPeerLifetime()) == true
test "Safe/Clear test": closureScope: test "Safe/Clear test": closureScope([CatchableError]):
var pool = newPeerPool[PeerTest, PeerTestID]() var pool = newPeerPool[PeerTest, PeerTestID]()
var peer1 = PeerTest.init("peer1", 10) var peer1 = PeerTest.init("peer1", 10)
var peer2 = PeerTest.init("peer2", 9) var peer2 = PeerTest.init("peer2", 9)
@ -458,7 +462,7 @@ suite "PeerPool testing suite":
asyncSpawn testConsumer() asyncSpawn testConsumer()
check waitFor(testClose()) == true check waitFor(testClose()) == true
test "Access peers by key test": closureScope: test "Access peers by key test": closureScope([CatchableError]):
var pool = newPeerPool[PeerTest, PeerTestID]() var pool = newPeerPool[PeerTest, PeerTestID]()
var peer1 = PeerTest.init("peer1", 10) var peer1 = PeerTest.init("peer1", 10)
var peer2 = PeerTest.init("peer2", 9) var peer2 = PeerTest.init("peer2", 9)