handle Exception during EraFile.verify (#5900)

`Taskpool.new()` is marked as `{.raises: [Exception].}`. Catch this.
This commit is contained in:
Etan Kissling 2024-02-17 18:19:30 +01:00 committed by GitHub
parent 3b5056db92
commit 30b7c6153f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 12 additions and 6 deletions

View File

@ -221,6 +221,7 @@ jobs:
- name: Build files with isMainModule
run: |
source env.sh
nim c beacon_chain/era_db
nim c beacon_chain/trusted_node_sync
lint:

View File

@ -1,9 +1,12 @@
# beacon_chain
# Copyright (c) 2018-2024 Status Research & Development GmbH
# Licensed and distributed under either of
# * 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).
# at your option. This file may not be copied, modified, or distributed except according to those terms.
{.push raises: [].}
import
std/os,
chronicles,
@ -186,15 +189,19 @@ proc verify*(f: EraFile, cfg: RuntimeConfig): Result[Eth2Digest, string] =
# We'll load the full state and compute its root - then we'll load the blocks
# and make sure that they match the state and that their signatures check out
let
startSlot = f.stateIdx.startSlot
era = startSlot.era
slot = f.stateIdx.startSlot
era = slot.era
rng = HmacDrbgContext.new()
taskpool = Taskpool.new()
taskpool =
try:
Taskpool.new()
except Exception as exc:
return err("Failed to initialize Taskpool: " & exc.msg)
var verifier = BatchVerifier.init(rng, taskpool)
var tmp: seq[byte]
? f.getStateSSZ(startSlot, tmp)
? f.getStateSSZ(slot, tmp)
let
state =
@ -464,8 +471,6 @@ when isMainModule:
# Testing EraDB gets messy because of the large amounts of data involved:
# this snippet contains some sanity checks for mainnet at least
import stew/arrayops
let
dbPath =
if os.paramCount() == 1: os.paramStr(1)