Skip to content

Commit

Permalink
feat(mempool): replenishing queue in get_txs
Browse files Browse the repository at this point in the history
  • Loading branch information
ayeletstarkware committed Jul 24, 2024
1 parent df1cff6 commit a6a8a25
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 5 deletions.
16 changes: 16 additions & 0 deletions crates/mempool/src/mempool.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ impl Mempool {
let tx = self.tx_pool.remove(tx_hash)?;
eligible_txs.push(tx);
}
self.enqueue_next_eligible_txs(&eligible_txs)?;

Ok(eligible_txs)
}
Expand Down Expand Up @@ -100,6 +101,21 @@ impl Mempool {
Ok(())
}

fn enqueue_next_eligible_txs(&mut self, txs: &[ThinTransaction]) -> MempoolResult<()> {
for tx in txs {
let current_account_state = Account {
sender_address: tx.sender_address,
state: AccountState { nonce: tx.nonce },
};
if let Some(next_tx_reference) =
self.tx_pool.get_next_eligible_tx(current_account_state)?
{
self.tx_queue.insert(*next_tx_reference);
}
}
Ok(())
}

#[cfg(test)]
pub(crate) fn _tx_pool(&self) -> &TransactionPool {
&self.tx_pool
Expand Down
9 changes: 5 additions & 4 deletions crates/mempool/src/mempool_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -175,8 +175,6 @@ fn test_get_txs(#[case] requested_txs: usize) {
}

#[rstest]
// TODO(Ayelet): remove ignore once replenishing is merged.
#[ignore]
fn test_get_txs_multi_nonce() {
// Setup.
let tx_address_0_nonce_0 =
Expand All @@ -192,8 +190,11 @@ fn test_get_txs_multi_nonce() {
let txs = mempool.get_txs(2).unwrap();

// Assert that the account's next tx was added the queue.
assert_eq!(txs, &[tx_address_0_nonce_0, tx_address_0_nonce_1]);
let expected_mempool_state = MempoolState::new([], []);
// TODO(Ayelet): all transactions should be returned after replenishing.
assert_eq!(txs, &[tx_address_0_nonce_0]);
let expected_queue_txs = [TransactionReference::new(&tx_address_0_nonce_1)];
let expected_pool_txs = [tx_address_0_nonce_1];
let expected_mempool_state = MempoolState::new(expected_pool_txs, expected_queue_txs);
expected_mempool_state.assert_eq_mempool_state(&mempool);
}

Expand Down
13 changes: 12 additions & 1 deletion crates/mempool/src/transaction_pool.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,9 @@ use std::collections::{hash_map, BTreeMap, HashMap};
use starknet_api::core::{ContractAddress, Nonce};
use starknet_api::transaction::TransactionHash;
use starknet_mempool_types::errors::MempoolError;
use starknet_mempool_types::mempool_types::{MempoolResult, ThinTransaction};
use starknet_mempool_types::mempool_types::{
Account, AccountState, MempoolResult, ThinTransaction,
};

use crate::mempool::TransactionReference;

Expand Down Expand Up @@ -73,6 +75,15 @@ impl TransactionPool {
self.txs_by_account.get(address, nonce)
}

pub fn get_next_eligible_tx(
&self,
current_account_state: Account,
) -> MempoolResult<Option<&TransactionReference>> {
let Account { sender_address, state: AccountState { nonce } } = current_account_state;
let next_nonce = nonce.try_increment().map_err(|_| MempoolError::FeltOutOfRange)?;
Ok(self.get_by_address_and_nonce(sender_address, next_nonce))
}

#[cfg(test)]
pub(crate) fn _tx_pool(&self) -> &HashToTransaction {
&self.tx_pool
Expand Down
2 changes: 2 additions & 0 deletions crates/mempool_types/src/errors.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,6 @@ pub enum MempoolError {
DuplicateTransaction { tx_hash: TransactionHash },
#[error("Transaction with hash: {tx_hash} not found")]
TransactionNotFound { tx_hash: TransactionHash },
#[error("Transaction nonce is out of range")]
FeltOutOfRange
}

0 comments on commit a6a8a25

Please sign in to comment.