From 6a38c2eaa2ba8979a8dcd16b7c517f8071e3586c Mon Sep 17 00:00:00 2001 From: Sergio Chouhy Date: Tue, 29 Jul 2025 15:41:57 -0300 Subject: [PATCH] ad test --- sequencer_core/src/lib.rs | 47 +++++++++++++++++++++++++++++++++++- sequencer_rpc/src/process.rs | 1 - 2 files changed, 46 insertions(+), 2 deletions(-) diff --git a/sequencer_core/src/lib.rs b/sequencer_core/src/lib.rs index efa09a8..14ced81 100644 --- a/sequencer_core/src/lib.rs +++ b/sequencer_core/src/lib.rs @@ -765,7 +765,52 @@ mod tests { } #[test] - fn test_replay_transactions_are_rejected() { + fn test_replay_transactions_are_rejected_in_the_same_block() { + let config = setup_sequencer_config(); + let mut sequencer = SequencerCore::start_from_config(config); + + common_setup(&mut sequencer); + + let acc1 = hex::decode(sequencer.sequencer_config.initial_accounts[0].addr.clone()) + .unwrap() + .try_into() + .unwrap(); + let acc2 = hex::decode(sequencer.sequencer_config.initial_accounts[1].addr.clone()) + .unwrap() + .try_into() + .unwrap(); + + let sign_key1 = create_signing_key_for_account1(); + + let tx = create_dummy_transaction_native_token_transfer(acc1, 0, acc2, 100, sign_key1); + + let tx_mempool_original = MempoolTransaction { + auth_tx: tx.clone().into_authenticated().unwrap(), + }; + let tx_mempool_replay = MempoolTransaction { + auth_tx: tx.clone().into_authenticated().unwrap(), + }; + + // Pushing two copies of the same tx to the mempool + sequencer.mempool.push_item(tx_mempool_original); + sequencer.mempool.push_item(tx_mempool_replay); + + // Create block + let current_height = sequencer + .produce_new_block_with_mempool_transactions() + .unwrap(); + let block = sequencer + .store + .block_store + .get_block_at_id(current_height) + .unwrap(); + + // Only one should be included in the block + assert_eq!(block.transactions, vec![tx.clone()]); + } + + #[test] + fn test_replay_transactions_are_rejected_in_different_blocks() { let config = setup_sequencer_config(); let mut sequencer = SequencerCore::start_from_config(config); diff --git a/sequencer_rpc/src/process.rs b/sequencer_rpc/src/process.rs index 3149608..fa89558 100644 --- a/sequencer_rpc/src/process.rs +++ b/sequencer_rpc/src/process.rs @@ -291,7 +291,6 @@ mod tests { nonce: 0, }; let tx = Transaction::new(tx_body, SignaturePrivateKey::from_slice(&[1; 32]).unwrap()); - println!("{:?}", tx.body().hash()); sequencer_core .push_tx_into_mempool_pre_check(tx, [[0; 32]; 2])