From 9b22f28104ec5fd606e4bb39442a7600b38bb671 Mon Sep 17 00:00:00 2001 From: Pankaj Garg Date: Fri, 8 Mar 2024 16:23:03 -0800 Subject: [PATCH] v1.17: Remove unnecessary unwrap from `simulate_transaction_unchecked()` (backport of #35375) (#65) Remove unnecessary unwrap from `simulate_transaction_unchecked()` (#35375) Remove unnecessary unwrap from simulate_transaction_unchecked() (cherry picked from commit cb260f10d1b05743391b9b442bf175c19d894931) Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> --- runtime/src/bank.rs | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/runtime/src/bank.rs b/runtime/src/bank.rs index 4f2260f72ea17c..9a3c25b4b8ee85 100644 --- a/runtime/src/bank.rs +++ b/runtime/src/bank.rs @@ -4384,9 +4384,7 @@ impl Bank { let post_simulation_accounts = loaded_transactions .into_iter() .next() - .unwrap() - .0 - .ok() + .and_then(|(loaded_transactions_res, _)| loaded_transactions_res.ok()) .map(|loaded_transaction| { loaded_transaction .accounts @@ -4406,7 +4404,12 @@ impl Bank { debug!("simulate_transaction: {:?}", timings); - let execution_result = execution_results.pop().unwrap(); + let execution_result = + execution_results + .pop() + .unwrap_or(TransactionExecutionResult::NotExecuted( + TransactionError::InvalidProgramForExecution, + )); let flattened_result = execution_result.flattened_result(); let (logs, return_data) = match execution_result { TransactionExecutionResult::Executed { details, .. } => {