mirror of
https://github.com/status-im/nim-dagger.git
synced 2025-01-12 23:54:29 +00:00
fix(validation): asyncSpawns run (#1039)
- annotates run with raises: [] - asyncSpawns run, to ensure there are no escaping exceptions
This commit is contained in:
parent
b0cc27f563
commit
bef1160799
@ -109,7 +109,7 @@ proc markProofsAsMissing(validation: Validation) {.async.} =
|
|||||||
let previousPeriod = validation.getCurrentPeriod() - 1
|
let previousPeriod = validation.getCurrentPeriod() - 1
|
||||||
await validation.markProofAsMissing(slotId, previousPeriod)
|
await validation.markProofAsMissing(slotId, previousPeriod)
|
||||||
|
|
||||||
proc run(validation: Validation) {.async.} =
|
proc run(validation: Validation) {.async: (raises: []).} =
|
||||||
trace "Validation started"
|
trace "Validation started"
|
||||||
try:
|
try:
|
||||||
while true:
|
while true:
|
||||||
@ -118,7 +118,7 @@ proc run(validation: Validation) {.async.} =
|
|||||||
await validation.markProofsAsMissing()
|
await validation.markProofsAsMissing()
|
||||||
except CancelledError:
|
except CancelledError:
|
||||||
trace "Validation stopped"
|
trace "Validation stopped"
|
||||||
discard
|
discard # do not propagate as run is asyncSpawned
|
||||||
except CatchableError as e:
|
except CatchableError as e:
|
||||||
error "Validation failed", msg = e.msg
|
error "Validation failed", msg = e.msg
|
||||||
|
|
||||||
@ -149,9 +149,10 @@ proc start*(validation: Validation) {.async.} =
|
|||||||
await validation.subscribeSlotFilled()
|
await validation.subscribeSlotFilled()
|
||||||
await validation.restoreHistoricalState()
|
await validation.restoreHistoricalState()
|
||||||
validation.running = validation.run()
|
validation.running = validation.run()
|
||||||
|
asyncSpawn validation.running
|
||||||
|
|
||||||
proc stop*(validation: Validation) {.async.} =
|
proc stop*(validation: Validation) {.async.} =
|
||||||
if not isNil(validation.running):
|
if not validation.running.isNil and not validation.running.finished:
|
||||||
await validation.running.cancelAndWait()
|
await validation.running.cancelAndWait()
|
||||||
while validation.subscriptions.len > 0:
|
while validation.subscriptions.len > 0:
|
||||||
let subscription = validation.subscriptions.pop()
|
let subscription = validation.subscriptions.pop()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user