From 7a7daf8d8663eb6330fabeaded6e414b8a4f6092 Mon Sep 17 00:00:00 2001 From: lambda-0x <0xlambda@protonmail.com> Date: Sun, 14 Jan 2024 11:59:29 +0530 Subject: [PATCH] fix: retry on `TransactionHashNotFound` error (#1435) --- crates/dojo-world/src/utils.rs | 8 ++++++-- crates/sozo/src/ops/migration/mod.rs | 2 +- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/crates/dojo-world/src/utils.rs b/crates/dojo-world/src/utils.rs index fce459d9bf..2e067f055e 100644 --- a/crates/dojo-world/src/utils.rs +++ b/crates/dojo-world/src/utils.rs @@ -65,12 +65,12 @@ pub struct TransactionWaiter<'a, P: Provider> { /// be considered when waiting for the transaction, meaning `REVERTED` transaction will not /// return an error. must_succeed: bool, - /// Poll the transaction every `interval` miliseconds. Miliseconds are used so that + /// Poll the transaction every `interval` milliseconds. Milliseconds are used so that /// we can be more precise with the polling interval. Defaults to 2.5 seconds. interval: Interval, /// The maximum amount of time to wait for the transaction to achieve the desired status. An /// error will be returned if it is unable to finish within the `timeout` duration. Defaults to - /// 60 seconds. + /// 300 seconds. timeout: Duration, /// The provider to use for polling the transaction. provider: &'a P, @@ -240,6 +240,10 @@ where } Poll::Ready(res) => match res { + Err(ProviderError::StarknetError( + StarknetError::TransactionHashNotFound, + )) => {} + Err(e) => { return Poll::Ready(Err(TransactionWaitingError::Provider(e))); } diff --git a/crates/sozo/src/ops/migration/mod.rs b/crates/sozo/src/ops/migration/mod.rs index 1fbfb96b29..85ff2f9166 100644 --- a/crates/sozo/src/ops/migration/mod.rs +++ b/crates/sozo/src/ops/migration/mod.rs @@ -475,7 +475,7 @@ where .execute(calls) .send() .await - .map_err(|e| anyhow!("Failed to register models to World: {e}"))?; + .map_err(|e| anyhow!("Failed to register models to World: {e:?}"))?; TransactionWaiter::new(transaction_hash, migrator.provider()).await?;