Skip to content

Commit

Permalink
Reviewed the Engine API calls for missing error handling (#4004)
Browse files Browse the repository at this point in the history
  • Loading branch information
zah authored Aug 20, 2022
1 parent b1ac9c9 commit 09de83a
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 12 deletions.
1 change: 0 additions & 1 deletion beacon_chain/eth1/eth1_monitor.nim
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,6 @@ type
cfg: RuntimeConfig
finalizedBlockHash: Eth2Digest
finalizedDepositsMerkleizer: DepositsMerkleizer

## The latest block that reached a 50% majority vote from
## the Eth2 validators according to the follow distance and
## the ETH1_VOTING_PERIOD
Expand Down
37 changes: 26 additions & 11 deletions beacon_chain/validators/validator_duties.nim
Original file line number Diff line number Diff line change
Expand Up @@ -317,17 +317,26 @@ proc forkchoice_updated(state: bellatrix.BeaconState,
fee_recipient: ethtypes.Address,
execution_engine: Eth1Monitor):
Future[Option[bellatrix.PayloadID]] {.async.} =
logScope:
head_block_hash
finalized_block_hash

let
timestamp = compute_timestamp_at_slot(state, state.slot)
random = get_randao_mix(state, get_current_epoch(state))
forkchoiceResponse =
awaitWithTimeout(
execution_engine.forkchoiceUpdated(
head_block_hash, finalized_block_hash, timestamp, random.data,
fee_recipient),
FORKCHOICEUPDATED_TIMEOUT):
info "forkchoice_updated: forkchoiceUpdated timed out"
default(ForkchoiceUpdatedResponse)
try:
awaitWithTimeout(
execution_engine.forkchoiceUpdated(
head_block_hash, finalized_block_hash, timestamp, random.data,
fee_recipient),
FORKCHOICEUPDATED_TIMEOUT):
error "Engine API fork-choice update timed out"
default(ForkchoiceUpdatedResponse)
except CatchableError as err:
error "Engine API fork-choice update failed", err = err.msg
default(ForkchoiceUpdatedResponse)

payloadId = forkchoiceResponse.payloadId

return if payloadId.isSome:
Expand Down Expand Up @@ -401,11 +410,17 @@ proc getExecutionPayload(
proposalState.bellatrixData.data, latestHead, latestFinalized,
feeRecipient,
node.consensusManager.eth1Monitor))
payload = awaitWithTimeout(
get_execution_payload(payload_id, node.consensusManager.eth1Monitor),
GETPAYLOAD_TIMEOUT):
info "getExecutionPayload: getPayload timed out; using empty execution payload"
payload = try:
awaitWithTimeout(
get_execution_payload(payload_id, node.consensusManager.eth1Monitor),
GETPAYLOAD_TIMEOUT):
warn "Getting execution payload from Engine API timed out", payload_id
empty_execution_payload
except CatchableError as err:
warn "Getting execution payload from Engine API failed",
payload_id, err = err.msg
empty_execution_payload

executionPayloadStatus =
awaitWithTimeout(
node.consensusManager.eth1Monitor.newExecutionPayload(payload),
Expand Down

0 comments on commit 09de83a

Please sign in to comment.