From 5c5c34bf1999ec16ede537c93bcff701b1657732 Mon Sep 17 00:00:00 2001 From: Gilad Chase Date: Fri, 20 Dec 2024 23:30:44 +0200 Subject: [PATCH] chore(starknet_l1_provider): add fake l1 provider client --- crates/starknet_l1_provider/src/test_utils.rs | 48 ++++++++++++++++++- 1 file changed, 47 insertions(+), 1 deletion(-) diff --git a/crates/starknet_l1_provider/src/test_utils.rs b/crates/starknet_l1_provider/src/test_utils.rs index a987fe7eeee..b99daea4358 100644 --- a/crates/starknet_l1_provider/src/test_utils.rs +++ b/crates/starknet_l1_provider/src/test_utils.rs @@ -1,6 +1,20 @@ +use std::sync::Mutex; + +use async_trait::async_trait; use indexmap::{IndexMap, IndexSet}; -use starknet_api::executable_transaction::L1HandlerTransaction; +use itertools::Itertools; +use pretty_assertions::assert_eq; +use starknet_api::executable_transaction::{ + L1HandlerTransaction as ExecutableL1HandlerTransaction, + L1HandlerTransaction, +}; use starknet_api::transaction::TransactionHash; +use starknet_l1_provider_types::{ + Event, + L1ProviderClient, + L1ProviderClientResult, + ValidationStatus, +}; use crate::{L1Provider, ProviderState, TransactionManager}; @@ -119,3 +133,35 @@ impl TransactionManagerContentBuilder { self.txs.is_none() && self.on_l2_awaiting_l1_consumption.is_none() } } + +#[derive(Default)] +pub struct FakeL1ProviderClient { + pub events_received: Mutex>, +} + +impl FakeL1ProviderClient { + #[track_caller] + pub fn assert_add_events_received_with(&self, expected: &[Event]) { + assert_eq!(self.events_received.lock().unwrap().drain(..).collect_vec(), expected); + } +} + +#[async_trait] +impl L1ProviderClient for FakeL1ProviderClient { + async fn get_txs( + &self, + _n_txs: usize, + ) -> L1ProviderClientResult> { + todo!() + } + async fn add_events(&self, events: Vec) -> L1ProviderClientResult<()> { + self.events_received.lock().unwrap().extend(events); + Ok(()) + } + async fn validate( + &self, + _tx_hash: TransactionHash, + ) -> L1ProviderClientResult { + todo!() + } +}