Skip to content

Commit

Permalink
feat(mempool_test_utils): util to generate deploy account txs
Browse files Browse the repository at this point in the history
  • Loading branch information
yair-starkware committed Dec 30, 2024
1 parent 0b4bd72 commit 97fe2f0
Showing 1 changed file with 20 additions and 0 deletions.
20 changes: 20 additions & 0 deletions crates/mempool_test_utils/src/starknet_api_test_utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,8 @@ type SharedNonceManager = Rc<RefCell<NonceManager>>;
/// let undeployed_account = tx_generator.account_with_id(2).account;
/// // Generate a transfer to fund the undeployed account.
/// let transfer_tx = tx_generator.account_with_id_mut(0).generate_transfer(&undeployed_account);
/// // Generate a deploy account transaction for the undeployed account.
/// let deploy_account_tx = tx_generator.account_with_id_mut(2).generate_deploy_account();
/// ```
// Note: when moving this to starknet api crate, see if blockifier's
// [blockifier::transaction::test_utils::FaultyAccountTxCreatorArgs] can be made to use this.
Expand Down Expand Up @@ -271,6 +273,7 @@ impl MultiAccountTransactionGenerator {
pub struct AccountTransactionGenerator {
pub account: Contract,
nonce_manager: SharedNonceManager,
contract_address_salt: ContractAddressSalt,
}

impl AccountTransactionGenerator {
Expand Down Expand Up @@ -351,6 +354,22 @@ impl AccountTransactionGenerator {
rpc_invoke_tx(invoke_args)
}

pub fn generate_deploy_account(&mut self) -> RpcTransaction {
assert!(
!self.is_deployed(),
"Cannot deploy an already deployed account: the first transaction of every account \
must be a deploy account transaction."
);
let nonce = self.next_nonce();
assert_ne!(nonce, nonce!(0), "The deploy account tx should have nonce 0.");
let deploy_account_args = deploy_account_tx_args!(
class_hash: self.account.class_hash(),
resource_bounds: test_valid_resource_bounds(),
contract_address_salt: ContractAddressSalt(self.contract_address_salt.0)
);
rpc_deploy_account_tx(deploy_account_args)
}

pub fn sender_address(&self) -> ContractAddress {
self.account.sender_address
}
Expand Down Expand Up @@ -379,6 +398,7 @@ impl AccountTransactionGenerator {
let mut account_tx_generator = Self {
account: Contract::new_for_account(account, &default_deploy_account_tx),
nonce_manager,
contract_address_salt,
};
if is_deployed {
// Bump the account nonce after transaction creation.
Expand Down

0 comments on commit 97fe2f0

Please sign in to comment.