diff --git a/crates/blockifier/src/execution/deprecated_syscalls/deprecated_syscalls_test.rs b/crates/blockifier/src/execution/deprecated_syscalls/deprecated_syscalls_test.rs index 33aad71bbe..7f04bb9abd 100644 --- a/crates/blockifier/src/execution/deprecated_syscalls/deprecated_syscalls_test.rs +++ b/crates/blockifier/src/execution/deprecated_syscalls/deprecated_syscalls_test.rs @@ -12,11 +12,10 @@ use starknet_api::transaction::{ EventContent, EventData, EventKey, - TransactionHash, TransactionVersion, QUERY_VERSION_BASE, }; -use starknet_api::{calldata, felt, nonce, storage_key}; +use starknet_api::{calldata, felt, nonce, storage_key, tx_hash}; use starknet_types_core::felt::Felt; use test_case::test_case; @@ -467,7 +466,7 @@ fn test_tx_info(#[values(false, true)] only_query: bool) { let simulate_version_base = *QUERY_VERSION_BASE; version += simulate_version_base; } - let tx_hash = TransactionHash(felt!(1991_u16)); + let tx_hash = tx_hash!(1991); let max_fee = Fee(0); let nonce = nonce!(3_u16); let sender_address = test_contract.get_instance_address(0); diff --git a/crates/blockifier/src/execution/syscalls/syscall_tests/get_execution_info.rs b/crates/blockifier/src/execution/syscalls/syscall_tests/get_execution_info.rs index 834ca9c530..c7657beaec 100644 --- a/crates/blockifier/src/execution/syscalls/syscall_tests/get_execution_info.rs +++ b/crates/blockifier/src/execution/syscalls/syscall_tests/get_execution_info.rs @@ -13,8 +13,8 @@ use starknet_api::transaction::fields::{ Tip, ValidResourceBounds, }; -use starknet_api::transaction::{TransactionHash, TransactionVersion, QUERY_VERSION_BASE}; -use starknet_api::{felt, nonce}; +use starknet_api::transaction::{TransactionVersion, QUERY_VERSION_BASE}; +use starknet_api::{felt, nonce, tx_hash}; use starknet_types_core::felt::Felt; use test_case::test_case; @@ -200,7 +200,7 @@ fn test_get_execution_info( version = TransactionVersion(query_version); } - let tx_hash = TransactionHash(felt!(1991_u16)); + let tx_hash = tx_hash!(1991); let max_fee = Fee(42); let nonce = nonce!(3_u16); let sender_address = test_contract_address; diff --git a/crates/papyrus_protobuf/src/converters/transaction_test.rs b/crates/papyrus_protobuf/src/converters/transaction_test.rs index ce5d02eabe..6f03abf290 100644 --- a/crates/papyrus_protobuf/src/converters/transaction_test.rs +++ b/crates/papyrus_protobuf/src/converters/transaction_test.rs @@ -15,10 +15,9 @@ use starknet_api::transaction::{ InvokeTransactionOutput, L1HandlerTransactionOutput, Transaction as StarknetApiTransaction, - TransactionHash, TransactionOutput, }; -use starknet_types_core::felt::Felt; +use starknet_api::tx_hash; use crate::sync::DataOrFin; @@ -167,7 +166,7 @@ fn assert_transaction_to_vec_u8_and_back( transaction: StarknetApiTransaction, transaction_output: TransactionOutput, ) { - let random_transaction_hash = TransactionHash(Felt::from(random::())); + let random_transaction_hash = tx_hash!(random::()); let data = DataOrFin(Some(FullTransaction { transaction, transaction_output, diff --git a/crates/papyrus_rpc/src/v0_8/api/test.rs b/crates/papyrus_rpc/src/v0_8/api/test.rs index 5bfb5c6c8e..fe2b144322 100644 --- a/crates/papyrus_rpc/src/v0_8/api/test.rs +++ b/crates/papyrus_rpc/src/v0_8/api/test.rs @@ -68,7 +68,6 @@ use starknet_api::deprecated_contract_class::{ FunctionAbiEntry, FunctionStateMutability, }; -use starknet_api::hash::StarkHash; use starknet_api::state::{SierraContractClass as StarknetApiContractClass, StateDiff}; use starknet_api::transaction::{ Event as StarknetApiEvent, @@ -81,7 +80,7 @@ use starknet_api::transaction::{ TransactionOffsetInBlock, TransactionOutput as StarknetApiTransactionOutput, }; -use starknet_api::{class_hash, contract_address, felt, storage_key}; +use starknet_api::{class_hash, contract_address, felt, storage_key, tx_hash}; use starknet_client::reader::objects::pending_data::{ DeprecatedPendingBlock, PendingBlockOrDeprecated, @@ -1350,7 +1349,7 @@ async fn get_transaction_status() { call_api_then_assert_and_validate_schema_for_err::<_, TransactionStatus>( &module, method_name, - vec![Box::new(TransactionHash(StarkHash::from(1_u8)))], + vec![Box::new(tx_hash!(1))], &VERSION, SpecFile::StarknetApiOpenrpc, &TRANSACTION_HASH_NOT_FOUND.into(), @@ -1474,7 +1473,7 @@ async fn get_transaction_receipt() { call_api_then_assert_and_validate_schema_for_err::<_, TransactionReceipt>( &module, method_name, - vec![Box::new(TransactionHash(StarkHash::from(1_u8)))], + vec![Box::new(tx_hash!(1))], &VERSION, SpecFile::StarknetApiOpenrpc, &TRANSACTION_HASH_NOT_FOUND.into(), @@ -2202,7 +2201,7 @@ async fn get_storage_at() { fn generate_client_transaction_client_receipt_rpc_transaction_and_rpc_receipt( rng: &mut ChaCha8Rng, ) -> (ClientTransaction, ClientTransactionReceipt, Transaction, PendingTransactionReceipt) { - let pending_transaction_hash = TransactionHash(StarkHash::from(rng.next_u64())); + let pending_transaction_hash = tx_hash!(rng.next_u64()); let mut client_transaction_receipt = ClientTransactionReceipt::get_test_instance(rng); client_transaction_receipt.transaction_hash = pending_transaction_hash; client_transaction_receipt.execution_resources.n_memory_holes = 1; @@ -2279,7 +2278,7 @@ async fn get_transaction_by_hash() { let mut block = get_test_block(1, None, None, None); // Change the transaction hash from 0 to a random value, so that later on we can add a // transaction with 0 hash to the pending block. - block.body.transaction_hashes[0] = TransactionHash(StarkHash::from(random::())); + block.body.transaction_hashes[0] = tx_hash!(random::()); storage_writer .begin_rw_txn() .unwrap() @@ -2333,7 +2332,7 @@ async fn get_transaction_by_hash() { call_api_then_assert_and_validate_schema_for_err::<_, TransactionWithHash>( &module, method_name, - vec![Box::new(TransactionHash(StarkHash::from(1_u8)))], + vec![Box::new(tx_hash!(1))], &VERSION, SpecFile::StarknetApiOpenrpc, &TRANSACTION_HASH_NOT_FOUND.into(), @@ -2344,7 +2343,7 @@ async fn get_transaction_by_hash() { #[tokio::test] async fn get_transaction_by_hash_state_only() { let method_name = "starknet_V0_8_getTransactionByHash"; - let params = [TransactionHash(StarkHash::from(1_u8))]; + let params = [tx_hash!(1)]; let (module, _) = get_test_rpc_server_and_storage_writer_from_params::( None, None, @@ -2736,7 +2735,7 @@ impl BlockMetadata { block.header.block_hash = BlockHash(rng.next_u64().into()); // Randomize the transaction hashes because get_test_block returns constant hashes for transaction_hash in &mut block.body.transaction_hashes { - *transaction_hash = TransactionHash(rng.next_u64().into()); + *transaction_hash = tx_hash!(rng.next_u64()); } for (output, event_metadatas_of_tx) in @@ -2761,9 +2760,8 @@ impl BlockMetadata { rng: &mut ChaCha8Rng, parent_hash: BlockHash, ) -> PendingBlockOrDeprecated { - let transaction_hashes = iter::repeat_with(|| TransactionHash(rng.next_u64().into())) - .take(self.0.len()) - .collect::>(); + let transaction_hashes = + iter::repeat_with(|| tx_hash!(rng.next_u64())).take(self.0.len()).collect::>(); PendingBlockOrDeprecated::Deprecated(DeprecatedPendingBlock { parent_block_hash: parent_hash, transactions: transaction_hashes diff --git a/crates/papyrus_rpc/src/v0_8/execution_test.rs b/crates/papyrus_rpc/src/v0_8/execution_test.rs index 6566ba0ad3..732525a62f 100644 --- a/crates/papyrus_rpc/src/v0_8/execution_test.rs +++ b/crates/papyrus_rpc/src/v0_8/execution_test.rs @@ -71,7 +71,7 @@ use starknet_api::transaction::{ TransactionOffsetInBlock, TransactionVersion, }; -use starknet_api::{calldata, class_hash, contract_address, felt, nonce}; +use starknet_api::{calldata, class_hash, contract_address, felt, nonce, tx_hash}; use starknet_client::reader::objects::pending_data::{ PendingBlock, PendingBlockOrDeprecated, @@ -302,7 +302,7 @@ async fn execution_call() { *BLOCK_TIMESTAMP, *SEQUENCER_ADDRESS, &InvokeTransactionV1::default(), - TransactionHash(StarkHash::ZERO), + tx_hash!(0), Some(Felt::ZERO), ); // Calling the contract directly and not through the account contract. @@ -363,7 +363,7 @@ async fn pending_execution_call() { *BLOCK_TIMESTAMP, *SEQUENCER_ADDRESS, &InvokeTransactionV1::default(), - TransactionHash(StarkHash::ZERO), + tx_hash!(0), Some(Felt::ZERO), ); // Calling the contract directly and not through the account contract. @@ -630,7 +630,7 @@ async fn test_call_simulate( // Because the transaction hash depends on the calldata and the calldata needs to contain // the transaction hash, there's no way to put the correct hash here. Instead, we'll check // that the function `test_get_execution_info` fails on the transaction hash validation. - TransactionHash(StarkHash::ZERO), + tx_hash!(0), None, ); invoke_v1.calldata = calldata; @@ -763,8 +763,8 @@ async fn trace_block_transactions_regular_and_pending() { let mut writer = prepare_storage_for_execution(storage_writer); - let tx_hash1 = TransactionHash(felt!("0x1234")); - let tx_hash2 = TransactionHash(felt!("0x5678")); + let tx_hash1 = tx_hash!(0x1234); + let tx_hash2 = tx_hash!(0x5678); let client_tx1 = ClientTransaction::Invoke(ClientInvokeTransaction { max_fee: Some(*MAX_FEE), @@ -945,8 +945,8 @@ async fn trace_block_transactions_regular_and_pending() { #[tokio::test] async fn trace_block_transactions_and_trace_transaction_execution_context() { - let tx_hash1 = TransactionHash(felt!("0x1234")); - let tx_hash2 = TransactionHash(felt!("0x5678")); + let tx_hash1 = tx_hash!(0x1234); + let tx_hash2 = tx_hash!(0x5678); let mut invoke_tx1 = starknet_api::transaction::InvokeTransactionV1 { max_fee: *MAX_FEE, @@ -1084,8 +1084,8 @@ async fn trace_block_transactions_and_trace_transaction_execution_context() { #[tokio::test] async fn pending_trace_block_transactions_and_trace_transaction_execution_context() { - let tx_hash1 = TransactionHash(felt!("0x1234")); - let tx_hash2 = TransactionHash(felt!("0x5678")); + let tx_hash1 = tx_hash!(0x1234); + let tx_hash2 = tx_hash!(0x5678); let mut client_invoke_tx1 = ClientInvokeTransaction { max_fee: Some(*MAX_FEE), diff --git a/crates/papyrus_rpc/src/v0_8/write_api_result_test.rs b/crates/papyrus_rpc/src/v0_8/write_api_result_test.rs index d4d0bbfeb0..7be59678c2 100644 --- a/crates/papyrus_rpc/src/v0_8/write_api_result_test.rs +++ b/crates/papyrus_rpc/src/v0_8/write_api_result_test.rs @@ -2,7 +2,7 @@ use papyrus_test_utils::{auto_impl_get_test_instance, get_rng, GetTestInstance}; use serde::Serialize; use starknet_api::core::{ClassHash, ContractAddress, PatriciaKey}; use starknet_api::transaction::TransactionHash; -use starknet_api::{class_hash, felt}; +use starknet_api::{class_hash, felt, tx_hash}; use starknet_client::writer::objects::response::{ DeclareResponse, DeployAccountResponse, @@ -54,7 +54,7 @@ fn add_deploy_account_ok_result_fits_rpc() { #[test] fn add_invoke_ok_result_from_response() { - let transaction_hash = TransactionHash(felt!("0x12345")); + let transaction_hash = tx_hash!(0x12345); let ok_result = AddInvokeOkResult::from(InvokeResponse { code: SuccessfulStarknetErrorCode::default(), transaction_hash, @@ -65,7 +65,7 @@ fn add_invoke_ok_result_from_response() { #[test] fn add_declare_ok_result_from_response() { - let transaction_hash = TransactionHash(felt!("0x12345")); + let transaction_hash = tx_hash!(0x12345); let class_hash = class_hash!("0xabcde"); let ok_result = AddDeclareOkResult::from(DeclareResponse { code: SuccessfulStarknetErrorCode::default(), @@ -78,7 +78,7 @@ fn add_declare_ok_result_from_response() { #[test] fn add_deploy_account_ok_result_from_response() { - let transaction_hash = TransactionHash(felt!("0x12345")); + let transaction_hash = tx_hash!(0x12345); let contract_address = ContractAddress(PatriciaKey::try_from(felt!("0xabcde")).unwrap()); let ok_result = AddDeployAccountOkResult::from(DeployAccountResponse { code: SuccessfulStarknetErrorCode::default(), diff --git a/crates/papyrus_test_utils/src/lib.rs b/crates/papyrus_test_utils/src/lib.rs index 2dbf884e80..9f6937a73c 100644 --- a/crates/papyrus_test_utils/src/lib.rs +++ b/crates/papyrus_test_utils/src/lib.rs @@ -49,7 +49,6 @@ use starknet_api::block::{ GasPricePerToken, StarknetVersion, }; -use starknet_api::class_hash; use starknet_api::contract_class::EntryPointType; use starknet_api::core::{ ClassHash, @@ -156,6 +155,7 @@ use starknet_api::transaction::{ TransactionOutput, TransactionVersion, }; +use starknet_api::{class_hash, tx_hash}; use starknet_types_core::felt::Felt; ////////////////////////////////////////////////////////////////////////// @@ -280,7 +280,7 @@ fn get_rand_test_body_with_events( while is_v3_transaction(&transaction) { transaction = Transaction::get_test_instance(rng); } - transaction_hashes.push(TransactionHash(StarkHash::from(u128::try_from(i).unwrap()))); + transaction_hashes.push(tx_hash!(i)); let transaction_output = get_test_transaction_output(&transaction); transactions.push(transaction); transaction_outputs.push(transaction_output); diff --git a/crates/starknet_api/src/block_hash/block_hash_calculator_test.rs b/crates/starknet_api/src/block_hash/block_hash_calculator_test.rs index 7adb1ad094..396273ddae 100644 --- a/crates/starknet_api/src/block_hash/block_hash_calculator_test.rs +++ b/crates/starknet_api/src/block_hash/block_hash_calculator_test.rs @@ -28,10 +28,9 @@ use crate::core::{ TransactionCommitment, }; use crate::data_availability::L1DataAvailabilityMode; -use crate::felt; use crate::hash::PoseidonHash; use crate::transaction::fields::TransactionSignature; -use crate::transaction::TransactionHash; +use crate::{felt, tx_hash}; /// Macro to test if changing any field in the header or commitments /// results a change in the block hash. @@ -95,7 +94,7 @@ fn test_block_hash_regression( let transactions_data = vec![TransactionHashingData { transaction_signature: TransactionSignature(vec![Felt::TWO, Felt::THREE]), transaction_output: get_transaction_output(), - transaction_hash: TransactionHash(Felt::ONE), + transaction_hash: tx_hash!(1), }]; let state_diff = get_state_diff(); diff --git a/crates/starknet_api/src/block_hash/event_commitment_test.rs b/crates/starknet_api/src/block_hash/event_commitment_test.rs index 5c48384268..7fc0752bfb 100644 --- a/crates/starknet_api/src/block_hash/event_commitment_test.rs +++ b/crates/starknet_api/src/block_hash/event_commitment_test.rs @@ -3,8 +3,8 @@ use starknet_types_core::hash::Poseidon; use super::{calculate_event_commitment, calculate_event_hash, EventLeafElement}; use crate::core::EventCommitment; -use crate::transaction::{Event, EventContent, EventData, EventKey, TransactionHash}; -use crate::{contract_address, felt}; +use crate::transaction::{Event, EventContent, EventData, EventKey}; +use crate::{contract_address, felt, tx_hash}; #[test] fn test_event_commitment_regression() { @@ -39,6 +39,6 @@ fn get_event_leaf_element(seed: u8) -> EventLeafElement { ), }, }, - transaction_hash: TransactionHash(felt!("0x1234")), + transaction_hash: tx_hash!(0x1234), } } diff --git a/crates/starknet_api/src/block_hash/receipt_commitment_test.rs b/crates/starknet_api/src/block_hash/receipt_commitment_test.rs index 53dc119f78..3d9c5c5720 100644 --- a/crates/starknet_api/src/block_hash/receipt_commitment_test.rs +++ b/crates/starknet_api/src/block_hash/receipt_commitment_test.rs @@ -10,17 +10,13 @@ use crate::block_hash::receipt_commitment::{ }; use crate::block_hash::test_utils::{generate_message_to_l1, get_transaction_output}; use crate::core::ReceiptCommitment; -use crate::felt; -use crate::transaction::{ - RevertedTransactionExecutionStatus, - TransactionExecutionStatus, - TransactionHash, -}; +use crate::transaction::{RevertedTransactionExecutionStatus, TransactionExecutionStatus}; +use crate::{felt, tx_hash}; #[test] fn test_receipt_hash_regression() { let transaction_receipt = ReceiptElement { - transaction_hash: TransactionHash(Felt::from(1234_u16)), + transaction_hash: tx_hash!(1234), transaction_output: get_transaction_output(), }; diff --git a/crates/starknet_api/src/block_hash/transaction_commitment_test.rs b/crates/starknet_api/src/block_hash/transaction_commitment_test.rs index a8287d28c1..df48e36013 100644 --- a/crates/starknet_api/src/block_hash/transaction_commitment_test.rs +++ b/crates/starknet_api/src/block_hash/transaction_commitment_test.rs @@ -7,9 +7,8 @@ use crate::block_hash::transaction_commitment::{ calculate_transaction_leaf, }; use crate::core::TransactionCommitment; -use crate::felt; use crate::transaction::fields::TransactionSignature; -use crate::transaction::TransactionHash; +use crate::{felt, tx_hash}; #[test] fn test_transaction_leaf_regression() { @@ -22,7 +21,7 @@ fn test_transaction_leaf_regression() { #[test] fn test_transaction_leaf_without_signature_regression() { let transaction_leaf_elements = TransactionLeafElement { - transaction_hash: TransactionHash(Felt::ONE), + transaction_hash: tx_hash!(1), transaction_signature: TransactionSignature(vec![]), }; let expected_leaf = felt!("0x579e8877c7755365d5ec1ec7d3a94a457eff5d1f40482bbe9729c064cdead2"); @@ -45,7 +44,7 @@ fn test_transaction_commitment_regression() { } fn get_transaction_leaf_element() -> TransactionLeafElement { - let transaction_hash = TransactionHash(Felt::ONE); + let transaction_hash = tx_hash!(1); let transaction_signature = TransactionSignature(vec![Felt::TWO, Felt::THREE]); TransactionLeafElement { transaction_hash, transaction_signature } } diff --git a/crates/starknet_api/src/transaction.rs b/crates/starknet_api/src/transaction.rs index 77eb7da72b..e964e225e0 100644 --- a/crates/starknet_api/src/transaction.rs +++ b/crates/starknet_api/src/transaction.rs @@ -807,6 +807,15 @@ impl From> for TransactionHash { } } +/// A utility macro to create a [`TransactionHash`] from an unsigned integer representation. +#[cfg(any(feature = "testing", test))] +#[macro_export] +macro_rules! tx_hash { + ($tx_hash:expr) => { + $crate::transaction::TransactionHash($crate::hash::StarkHash::from($tx_hash)) + }; +} + /// A transaction version. #[derive( Debug, diff --git a/crates/starknet_batcher/src/batcher_test.rs b/crates/starknet_batcher/src/batcher_test.rs index 3f6e2feb81..36f9baebe7 100644 --- a/crates/starknet_batcher/src/batcher_test.rs +++ b/crates/starknet_batcher/src/batcher_test.rs @@ -16,7 +16,7 @@ use starknet_api::executable_transaction::Transaction; use starknet_api::hash::PoseidonHash; use starknet_api::state::ThinStateDiff; use starknet_api::transaction::TransactionHash; -use starknet_api::{contract_address, felt, nonce}; +use starknet_api::{contract_address, felt, nonce, tx_hash}; use starknet_batcher_types::batcher_types::{ DecisionReachedInput, GetProposalContent, @@ -647,7 +647,7 @@ impl ProposalManagerTrait for T { } fn test_tx_hashes(range: std::ops::Range) -> HashSet { - range.map(|i| TransactionHash(felt!(i))).collect() + range.map(|i| tx_hash!(i)).collect() } fn test_contract_nonces(range: std::ops::Range) -> HashMap { diff --git a/crates/starknet_batcher/src/block_builder_test.rs b/crates/starknet_batcher/src/block_builder_test.rs index ea73200169..4176173770 100644 --- a/crates/starknet_batcher/src/block_builder_test.rs +++ b/crates/starknet_batcher/src/block_builder_test.rs @@ -10,9 +10,9 @@ use mockall::predicate::eq; use mockall::Sequence; use rstest::rstest; use starknet_api::executable_transaction::Transaction; -use starknet_api::felt; use starknet_api::transaction::fields::Fee; use starknet_api::transaction::TransactionHash; +use starknet_api::tx_hash; use tokio::sync::mpsc::{UnboundedReceiver, UnboundedSender}; use crate::block_builder::{ @@ -247,8 +247,8 @@ fn transaction_failed_test_expectations() -> TestExpectations { }); let execution_infos_mapping = indexmap![ - TransactionHash(felt!(u8::try_from(0).unwrap()))=> execution_info(), - TransactionHash(felt!(u8::try_from(2).unwrap()))=> execution_info(), + tx_hash!(0)=> execution_info(), + tx_hash!(2)=> execution_info(), ]; let expected_block_artifacts = block_execution_artifacts(execution_infos_mapping); let expected_block_artifacts_copy = expected_block_artifacts.clone(); @@ -275,7 +275,7 @@ fn transaction_failed_test_expectations() -> TestExpectations { fn block_builder_expected_output(execution_info_len: usize) -> BlockExecutionArtifacts { let execution_info_len_u8 = u8::try_from(execution_info_len).unwrap(); let execution_infos_mapping = - (0..execution_info_len_u8).map(|i| (TransactionHash(felt!(i)), execution_info())).collect(); + (0..execution_info_len_u8).map(|i| (tx_hash!(i), execution_info())).collect(); block_execution_artifacts(execution_infos_mapping) } diff --git a/crates/starknet_batcher/src/test_utils.rs b/crates/starknet_batcher/src/test_utils.rs index e6b8183638..b7243cc6dd 100644 --- a/crates/starknet_batcher/src/test_utils.rs +++ b/crates/starknet_batcher/src/test_utils.rs @@ -5,9 +5,8 @@ use blockifier::bouncer::BouncerWeights; use blockifier::state::cached_state::CommitmentStateDiff; use indexmap::IndexMap; use starknet_api::executable_transaction::{AccountTransaction, Transaction}; -use starknet_api::felt; use starknet_api::test_utils::invoke::{executable_invoke_tx, InvokeTxArgs}; -use starknet_api::transaction::TransactionHash; +use starknet_api::tx_hash; use crate::block_builder::BlockExecutionArtifacts; @@ -15,7 +14,7 @@ pub fn test_txs(tx_hash_range: Range) -> Vec { tx_hash_range .map(|i| { Transaction::Account(AccountTransaction::Invoke(executable_invoke_tx(InvokeTxArgs { - tx_hash: TransactionHash(felt!(u128::try_from(i).unwrap())), + tx_hash: tx_hash!(i), ..Default::default() }))) }) diff --git a/crates/starknet_batcher/src/transaction_provider_test.rs b/crates/starknet_batcher/src/transaction_provider_test.rs index 0e806a7248..5cfc69564b 100644 --- a/crates/starknet_batcher/src/transaction_provider_test.rs +++ b/crates/starknet_batcher/src/transaction_provider_test.rs @@ -5,9 +5,8 @@ use mockall::predicate::eq; use rstest::{fixture, rstest}; use starknet_api::executable_transaction::{AccountTransaction, L1HandlerTransaction, Transaction}; use starknet_api::test_utils::invoke::{executable_invoke_tx, InvokeTxArgs}; -use starknet_api::transaction::TransactionHash; +use starknet_api::tx_hash; use starknet_mempool_types::communication::MockMempoolClient; -use starknet_types_core::felt::Felt; use crate::transaction_provider::{ MockL1ProviderClient, @@ -95,7 +94,7 @@ fn tx_channel() -> (tokio::sync::mpsc::Sender, tokio::sync::mpsc::R } fn test_l1handler_tx() -> L1HandlerTransaction { - L1HandlerTransaction { tx_hash: TransactionHash(Felt::ONE), ..Default::default() } + L1HandlerTransaction { tx_hash: tx_hash!(1), ..Default::default() } } #[rstest] diff --git a/crates/starknet_client/src/reader/objects/block_test.rs b/crates/starknet_client/src/reader/objects/block_test.rs index 58325afc42..8e0657252a 100644 --- a/crates/starknet_client/src/reader/objects/block_test.rs +++ b/crates/starknet_client/src/reader/objects/block_test.rs @@ -4,8 +4,8 @@ use pretty_assertions::assert_eq; use starknet_api::block::BlockHash; use starknet_api::core::{CompiledClassHash, Nonce}; use starknet_api::hash::StarkHash; -use starknet_api::transaction::{TransactionHash, TransactionOffsetInBlock}; -use starknet_api::{class_hash, contract_address, felt, storage_key}; +use starknet_api::transaction::TransactionOffsetInBlock; +use starknet_api::{class_hash, contract_address, felt, storage_key, tx_hash}; use super::{Block, GlobalRoot, TransactionReceiptsError}; use crate::reader::objects::block::BlockPostV0_13_1; @@ -135,7 +135,7 @@ async fn to_starknet_api_block_and_version() { ); let mut err_block: BlockPostV0_13_1 = serde_json::from_str(&raw_block).unwrap(); - err_block.transaction_receipts[0].transaction_hash = TransactionHash(felt!("0x4")); + err_block.transaction_receipts[0].transaction_hash = tx_hash!(0x4); let err = err_block.to_starknet_api_block_and_version().unwrap_err(); assert_matches!( err, diff --git a/crates/starknet_l1_provider/src/l1_provider_tests.rs b/crates/starknet_l1_provider/src/l1_provider_tests.rs index 09bf6ce569..03c5f068be 100644 --- a/crates/starknet_l1_provider/src/l1_provider_tests.rs +++ b/crates/starknet_l1_provider/src/l1_provider_tests.rs @@ -1,9 +1,7 @@ use assert_matches::assert_matches; use pretty_assertions::assert_eq; -use starknet_api::hash::StarkHash; -use starknet_api::l1_handler_tx_args; use starknet_api::test_utils::l1_handler::executable_l1_handler_tx; -use starknet_api::transaction::TransactionHash; +use starknet_api::{l1_handler_tx_args, tx_hash}; use crate::errors::L1ProviderError; use crate::test_utils::L1ProviderContentBuilder; @@ -14,18 +12,12 @@ macro_rules! tx { (tx_hash: $tx_hash:expr) => {{ executable_l1_handler_tx( l1_handler_tx_args!( - tx_hash: TransactionHash(StarkHash::from($tx_hash)) , ..Default::default() + tx_hash: tx_hash!($tx_hash) , ..Default::default() ) ) }}; } -macro_rules! tx_hash { - ($tx_hash:expr) => { - TransactionHash(StarkHash::from($tx_hash)) - }; -} - #[test] fn get_txs_happy_flow() { // Setup. diff --git a/crates/starknet_mempool/src/test_utils.rs b/crates/starknet_mempool/src/test_utils.rs index 472b4ae91d..58bcbfc6f4 100644 --- a/crates/starknet_mempool/src/test_utils.rs +++ b/crates/starknet_mempool/src/test_utils.rs @@ -2,8 +2,7 @@ use std::collections::{HashMap, HashSet}; use pretty_assertions::assert_eq; use starknet_api::executable_transaction::AccountTransaction; -use starknet_api::transaction::TransactionHash; -use starknet_api::{contract_address, felt, nonce}; +use starknet_api::{contract_address, nonce, tx_hash}; use starknet_mempool_types::errors::MempoolError; use starknet_mempool_types::mempool_types::{AddTransactionArgs, CommitBlockArgs}; @@ -22,8 +21,7 @@ macro_rules! tx { ) => {{ use starknet_api::block::GasPrice; use starknet_api::executable_transaction::AccountTransaction; - use starknet_api::hash::StarkHash; - use starknet_api::invoke_tx_args; + use starknet_api::{invoke_tx_args, tx_hash}; use starknet_api::test_utils::invoke::executable_invoke_tx; use starknet_api::transaction::fields::{ AllResourceBounds, @@ -31,7 +29,6 @@ macro_rules! tx { Tip, ValidResourceBounds, }; - use starknet_api::transaction::TransactionHash; let resource_bounds = ValidResourceBounds::AllResources(AllResourceBounds { l2_gas: ResourceBounds { @@ -42,7 +39,7 @@ macro_rules! tx { }); AccountTransaction::Invoke(executable_invoke_tx(invoke_tx_args!{ - tx_hash: TransactionHash(StarkHash::from($tx_hash)), + tx_hash: tx_hash!($tx_hash), sender_address: contract_address!($address), nonce: nonce!($tx_nonce), tip: Tip($tip), @@ -242,8 +239,7 @@ pub fn commit_block( let nonces = HashMap::from_iter( nonces.into_iter().map(|(address, nonce)| (contract_address!(address), nonce!(nonce))), ); - let tx_hashes = - HashSet::from_iter(tx_hashes.into_iter().map(|tx_hash| TransactionHash(felt!(tx_hash)))); + let tx_hashes = HashSet::from_iter(tx_hashes.into_iter().map(|tx_hash| tx_hash!(tx_hash))); let args = CommitBlockArgs { address_to_nonce: nonces, tx_hashes }; assert_eq!(mempool.commit_block(args), Ok(()));