From b4733dc65c26e47a60c71cc61113d5b2040e4959 Mon Sep 17 00:00:00 2001 From: meship-starkware Date: Thu, 8 Aug 2024 12:25:29 +0300 Subject: [PATCH] chore(blockifier): add resource bounds to faulty account transaction creator --- .../src/blockifier/stateful_validator_test.rs | 10 +++++++--- crates/blockifier/src/test_utils.rs | 4 ++-- crates/blockifier/src/transaction/test_utils.rs | 7 +++++++ crates/blockifier/src/transaction/transactions_test.rs | 9 +++++++++ 4 files changed, 25 insertions(+), 5 deletions(-) diff --git a/crates/blockifier/src/blockifier/stateful_validator_test.rs b/crates/blockifier/src/blockifier/stateful_validator_test.rs index de72c664e51..581891159d1 100644 --- a/crates/blockifier/src/blockifier/stateful_validator_test.rs +++ b/crates/blockifier/src/blockifier/stateful_validator_test.rs @@ -1,6 +1,6 @@ use assert_matches::assert_matches; use rstest::rstest; -use starknet_api::transaction::{Fee, TransactionVersion}; +use starknet_api::transaction::{DeprecatedResourceBoundsMapping, Fee, TransactionVersion}; use crate::blockifier::stateful_validator::StatefulValidator; use crate::context::BlockContext; @@ -11,6 +11,7 @@ use crate::transaction::account_transaction::AccountTransaction; use crate::transaction::test_utils::{ block_context, create_account_tx_for_validate_test_nonce_0, + max_resource_bounds, FaultyAccountTxCreatorArgs, INVALID, VALID, @@ -32,6 +33,7 @@ fn test_transaction_validator( #[case] validate_constructor: bool, #[case] tx_version: TransactionVersion, block_context: BlockContext, + max_resource_bounds: DeprecatedResourceBoundsMapping, #[values(CairoVersion::Cairo0, CairoVersion::Cairo1)] cairo_version: CairoVersion, ) { let chain_info = &block_context.chain_info; @@ -54,6 +56,7 @@ fn test_transaction_validator( validate_constructor, // TODO(Arni, 1/5/2024): Add test for insufficient max fee. max_fee: Fee(BALANCE), + resource_bounds: max_resource_bounds, ..Default::default() }; @@ -73,8 +76,8 @@ fn test_transaction_validator( assert!(result.is_ok(), "Validation failed: {:?}", result.unwrap_err()); } -#[test] -fn test_transaction_validator_skip_validate() { +#[rstest] +fn test_transaction_validator_skip_validate(max_resource_bounds: DeprecatedResourceBoundsMapping) { let block_context = BlockContext::create_for_testing(); let faulty_account = FeatureContract::FaultyAccount(CairoVersion::Cairo1); let state = test_state(&block_context.chain_info, BALANCE, &[(faulty_account, 1)]); @@ -87,6 +90,7 @@ fn test_transaction_validator_skip_validate() { sender_address: faulty_account.get_instance_address(0), class_hash: faulty_account.get_class_hash(), max_fee: Fee(BALANCE), + resource_bounds: max_resource_bounds, ..Default::default() }); diff --git a/crates/blockifier/src/test_utils.rs b/crates/blockifier/src/test_utils.rs index b2afd89626a..891e64f615f 100644 --- a/crates/blockifier/src/test_utils.rs +++ b/crates/blockifier/src/test_utils.rs @@ -211,8 +211,8 @@ pub fn trivial_external_entry_point_with_address( } } -fn default_testing_resource_bounds() -> DeprecatedResourceBoundsMapping { - DeprecatedResourceBoundsMapping::try_from(vec![ +pub fn default_testing_resource_bounds() -> ResourceBoundsMapping { + ResourceBoundsMapping::try_from(vec![ (Resource::L1Gas, ResourceBounds { max_amount: 0, max_price_per_unit: 1 }), // TODO(Dori, 1/2/2024): When fee market is developed, change the default price of // L2 gas. diff --git a/crates/blockifier/src/transaction/test_utils.rs b/crates/blockifier/src/transaction/test_utils.rs index 621a69052ca..8b1582e3acc 100644 --- a/crates/blockifier/src/transaction/test_utils.rs +++ b/crates/blockifier/src/transaction/test_utils.rs @@ -31,6 +31,7 @@ use crate::test_utils::initial_test_state::test_state; use crate::test_utils::invoke::{invoke_tx, InvokeTxArgs}; use crate::test_utils::{ create_calldata, + default_testing_resource_bounds, CairoVersion, NonceManager, BALANCE, @@ -145,6 +146,7 @@ pub struct FaultyAccountTxCreatorArgs { pub tx_version: TransactionVersion, pub scenario: u64, pub max_fee: Fee, + pub resource_bounds: ResourceBoundsMapping, // Should be None unless scenario is CALL_CONTRACT. pub additional_data: Option>, // Should be use with tx_type Declare or InvokeFunction. @@ -171,6 +173,7 @@ impl Default for FaultyAccountTxCreatorArgs { contract_address_salt: ContractAddressSalt::default(), validate_constructor: false, max_fee: Fee::default(), + resource_bounds: default_testing_resource_bounds(), declared_contract: None, } } @@ -206,6 +209,7 @@ pub fn create_account_tx_for_validate_test( contract_address_salt, validate_constructor, max_fee, + resource_bounds, declared_contract, } = faulty_account_tx_creator_args; @@ -231,6 +235,7 @@ pub fn create_account_tx_for_validate_test( declare_tx( declare_tx_args! { max_fee, + resource_bounds: resource_bounds.clone(), signature, sender_address, version: tx_version, @@ -251,6 +256,7 @@ pub fn create_account_tx_for_validate_test( let deploy_account_tx = deploy_account_tx( deploy_account_tx_args! { max_fee, + resource_bounds: resource_bounds.clone(), signature, version: tx_version, class_hash, @@ -265,6 +271,7 @@ pub fn create_account_tx_for_validate_test( let execute_calldata = create_calldata(sender_address, "foo", &[]); let invoke_tx = invoke_tx(invoke_tx_args! { max_fee, + resource_bounds, signature, sender_address, calldata: execute_calldata, diff --git a/crates/blockifier/src/transaction/transactions_test.rs b/crates/blockifier/src/transaction/transactions_test.rs index 78ff6726511..5e670f08abd 100644 --- a/crates/blockifier/src/transaction/transactions_test.rs +++ b/crates/blockifier/src/transaction/transactions_test.rs @@ -66,6 +66,7 @@ use crate::test_utils::prices::Prices; use crate::test_utils::{ create_calldata, create_trivial_calldata, + default_testing_resource_bounds, get_syscall_resources, get_tx_resources, test_erc20_sequencer_balance_key, @@ -1556,6 +1557,7 @@ fn test_validate_accounts_tx( * the address of * faulty_account. */ contract_address_salt: salt_manager.next_salt(), + resource_bounds: default_testing_resource_bounds(), ..default_args }); let error = account_tx.execute(state, block_context, true, true).unwrap_err(); @@ -1571,6 +1573,7 @@ fn test_validate_accounts_tx( scenario: GET_BLOCK_HASH, contract_address_salt: salt_manager.next_salt(), additional_data: None, + resource_bounds: default_testing_resource_bounds(), ..default_args }); let error = account_tx.execute(state, block_context, true, true).unwrap_err(); @@ -1585,6 +1588,7 @@ fn test_validate_accounts_tx( let account_tx = create_account_tx_for_validate_test_nonce_0(FaultyAccountTxCreatorArgs { scenario: GET_SEQUENCER_ADDRESS, contract_address_salt: salt_manager.next_salt(), + resource_bounds: default_testing_resource_bounds(), ..default_args }); let error = account_tx.execute(state, block_context, true, true).unwrap_err(); @@ -1607,6 +1611,7 @@ fn test_validate_accounts_tx( contract_address_salt: salt_manager.next_salt(), additional_data: None, declared_contract: Some(FeatureContract::TestContract(declared_contract_cairo_version)), + resource_bounds: default_testing_resource_bounds(), ..default_args }, ); @@ -1623,6 +1628,7 @@ fn test_validate_accounts_tx( declared_contract: Some(FeatureContract::AccountWithLongValidate( declared_contract_cairo_version, )), + resource_bounds: default_testing_resource_bounds(), ..default_args }, ); @@ -1642,6 +1648,7 @@ fn test_validate_accounts_tx( declared_contract: Some(FeatureContract::AccountWithoutValidations( declared_contract_cairo_version, )), + resource_bounds: default_testing_resource_bounds(), ..default_args }, ); @@ -1657,6 +1664,7 @@ fn test_validate_accounts_tx( contract_address_salt: salt_manager.next_salt(), additional_data: Some(vec![Felt::from(CURRENT_BLOCK_TIMESTAMP_FOR_VALIDATE)]), declared_contract: Some(FeatureContract::Empty(declared_contract_cairo_version)), + resource_bounds: default_testing_resource_bounds(), ..default_args }, ); @@ -1678,6 +1686,7 @@ fn test_validate_accounts_tx( Felt::from(0_u64), // Sequencer address for validate. ]), declared_contract: Some(FeatureContract::Empty(declared_contract_cairo_version)), + resource_bounds: default_testing_resource_bounds(), ..default_args }, );