Skip to content
This repository has been archived by the owner on Aug 21, 2024. It is now read-only.

Commit

Permalink
Added test for the scenario when a non deployed user invokes a transa…
Browse files Browse the repository at this point in the history
…ction
  • Loading branch information
nimrod-starkware committed Oct 5, 2023
1 parent d93b237 commit 30abc37
Showing 1 changed file with 56 additions and 0 deletions.
56 changes: 56 additions & 0 deletions crates/blockifier/src/transaction/account_transactions_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ use crate::abi::abi_utils::{get_storage_var_address, selector_from_name};
use crate::block_context::BlockContext;
use crate::execution::contract_class::{ContractClass, ContractClassV0, ContractClassV1};
use crate::execution::entry_point::EntryPointExecutionContext;
use crate::execution::errors::EntryPointExecutionError;
use crate::invoke_tx_args;
use crate::state::cached_state::CachedState;
use crate::state::state_api::{State, StateReader};
Expand All @@ -30,6 +31,7 @@ use crate::test_utils::{
TEST_FAULTY_ACCOUNT_CONTRACT_ADDRESS,
};
use crate::transaction::account_transaction::AccountTransaction;
use crate::transaction::errors::TransactionExecutionError;
use crate::transaction::objects::{FeeType, HasRelatedFeeType, TransactionExecutionInfo};
use crate::transaction::test_utils::{
account_invoke_tx, create_account_tx_for_validate_test,
Expand Down Expand Up @@ -227,6 +229,60 @@ fn test_account_flow_test(
.unwrap();
}

#[rstest]
#[case(TransactionVersion::ZERO)]
#[case(TransactionVersion::ONE)]
// TODO(Nimrod, 10/10/2023): Add V3 case once `get_account_tx_context` is supported for V3.
fn test_invoke_tx_from_non_deployed_account(
max_fee: Fee,
#[from(create_test_init_data)] init_data: TestInitData,
#[case] tx_version: TransactionVersion,
) {
let TestInitData {
mut state,
account_address,
contract_address: _,
mut nonce_manager,
block_context,
} = init_data;
// Invoke a function from the newly deployed contract.
let entry_point_selector = selector_from_name("return_result");

let non_deployed_contract_address = StarkHash::TWO;

let tx_result = run_invoke_tx(
&mut state,
&block_context,
invoke_tx_args! {
max_fee,
sender_address: account_address,
calldata: calldata![
non_deployed_contract_address, // Contract address.
entry_point_selector.0, // EP selector.
stark_felt!(1_u8), // Calldata length.
stark_felt!(2_u8) // Calldata: num.
],
version: tx_version,
nonce: nonce_manager.next(account_address),
},
);
match tx_result {
Ok(info) => {
// Make sure the error is because the account wasn't deployed.
assert!(info.revert_error.is_some_and(|err_str| err_str.contains("is not deployed.")));
}
Err(err) => {
// Make sure the error is because the account wasn't deployed.
assert!(matches!(err, TransactionExecutionError::ExecutionError(
EntryPointExecutionError::VirtualMachineExecutionErrorWithTrace { trace, .. })
if trace.contains("is not deployed.")
));
// We excpect to get an error only when tx_version is 0, on other versions to revert.
assert!(matches!(tx_version, TransactionVersion::ZERO));
}
}
}

#[rstest]
// Try two runs for each recursion type: one short run (success), and one that reverts due to step
// limit.
Expand Down

0 comments on commit 30abc37

Please sign in to comment.