Skip to content

Commit

Permalink
chore(blockifier): add resource bounds to faulty account transaction …
Browse files Browse the repository at this point in the history
…creator
  • Loading branch information
meship-starkware committed Aug 26, 2024
1 parent cd9fcf5 commit b4733dc
Show file tree
Hide file tree
Showing 4 changed files with 25 additions and 5 deletions.
10 changes: 7 additions & 3 deletions crates/blockifier/src/blockifier/stateful_validator_test.rs
Original file line number Diff line number Diff line change
@@ -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;
Expand All @@ -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,
Expand All @@ -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;
Expand All @@ -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()
};

Expand All @@ -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)]);
Expand All @@ -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()
});

Expand Down
4 changes: 2 additions & 2 deletions crates/blockifier/src/test_utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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.
Expand Down
7 changes: 7 additions & 0 deletions crates/blockifier/src/transaction/test_utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down Expand Up @@ -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<Vec<Felt>>,
// Should be use with tx_type Declare or InvokeFunction.
Expand All @@ -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,
}
}
Expand Down Expand Up @@ -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;

Expand All @@ -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,
Expand All @@ -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,
Expand All @@ -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,
Expand Down
9 changes: 9 additions & 0 deletions crates/blockifier/src/transaction/transactions_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down Expand Up @@ -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();
Expand All @@ -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();
Expand All @@ -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();
Expand All @@ -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
},
);
Expand All @@ -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
},
);
Expand All @@ -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
},
);
Expand All @@ -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
},
);
Expand All @@ -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
},
);
Expand Down

0 comments on commit b4733dc

Please sign in to comment.