Update engine state in broadcast (#3071)

## Issue Addressed

N/A

## Proposed Changes

Set the engine state to `EngineState::Offline` if the engine api call fails during broadcast. This caused issues while pausing sync when the execution engine is offline because `EngineState` always returned `Synced`.
This commit is contained in:
Pawan Dhananjay 2022-03-28 23:32:11 +00:00
parent 20e32f5812
commit a42cb69f6e

View File

@ -399,18 +399,22 @@ impl<T: EngineApi> Engines<T> {
let futures = self.engines.iter().map(|engine| async move { let futures = self.engines.iter().map(|engine| async move {
let is_offline = *engine.state.read().await == EngineState::Offline; let is_offline = *engine.state.read().await == EngineState::Offline;
if !is_offline { if !is_offline {
func(engine).await.map_err(|error| { match func(engine).await {
Ok(res) => Ok(res),
Err(error) => {
debug!( debug!(
self.log, self.log,
"Execution engine call failed"; "Execution engine call failed";
"error" => ?error, "error" => ?error,
"id" => &engine.id "id" => &engine.id
); );
EngineError::Api { *engine.state.write().await = EngineState::Offline;
Err(EngineError::Api {
id: engine.id.clone(), id: engine.id.clone(),
error, error,
}
}) })
}
}
} else { } else {
Err(EngineError::Offline { Err(EngineError::Offline {
id: engine.id.clone(), id: engine.id.clone(),