pub struct SimulationDB<P: Provider + Debug> {
pub runtime: Option<Arc<Runtime>>,
/* private fields */
}Expand description
A wrapper over an Alloy Provider with local storage cache and overrides.
Fields§
§runtime: Option<Arc<Runtime>>Tokio runtime to execute async code
Implementations§
Source§impl<P: Provider + Debug + 'static> SimulationDB<P>
impl<P: Provider + Debug + 'static> SimulationDB<P>
pub fn new( client: Arc<P>, runtime: Option<Arc<Runtime>>, block: Option<BlockHeader>, ) -> Self
Sourcepub fn set_block(&mut self, block: Option<BlockHeader>)
pub fn set_block(&mut self, block: Option<BlockHeader>)
Set the block that will be used when querying a node
Sourcepub fn update_state(
&mut self,
updates: &HashMap<Address, StateUpdate>,
block: BlockHeader,
) -> Result<HashMap<Address, StateUpdate>, SimulationDBError>
pub fn update_state( &mut self, updates: &HashMap<Address, StateUpdate>, block: BlockHeader, ) -> Result<HashMap<Address, StateUpdate>, SimulationDBError>
Update the simulation state.
Updates the underlying smart contract storage. Any previously missed account, which was queried and whose state now is in the account_storage will be cleared.
§Arguments
updates- Values for the updates that should be applied to the accountsblock- The newest block
Returns a state update struct to revert this update.
Sourcepub fn query_storage(
&self,
address: Address,
index: U256,
) -> Result<StorageValue, <SimulationDB<P> as DatabaseRef>::Error>
pub fn query_storage( &self, address: Address, index: U256, ) -> Result<StorageValue, <SimulationDB<P> as DatabaseRef>::Error>
Queries a value from storage at the specified index for a given Ethereum account.
§Arguments
address- The Ethereum address of the account.index- The index of the storage value to query.
§Returns
Returns a Result containing the value from storage at the specified index as an U256,
or an error of type SimulationDB<M>::Error if the query fails.
Trait Implementations§
Source§impl<P: Clone + Provider + Debug> Clone for SimulationDB<P>
impl<P: Clone + Provider + Debug> Clone for SimulationDB<P>
Source§fn clone(&self) -> SimulationDB<P>
fn clone(&self) -> SimulationDB<P>
1.0.0§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<P> DatabaseRef for SimulationDB<P>
impl<P> DatabaseRef for SimulationDB<P>
Source§fn basic_ref(
&self,
address: Address,
) -> Result<Option<AccountInfo>, Self::Error>
fn basic_ref( &self, address: Address, ) -> Result<Option<AccountInfo>, Self::Error>
Retrieves basic information about an account.
This function retrieves the basic account information for the specified address. If the account is present in the storage, the stored account information is returned. If the account is not present in the storage, the function queries the account information from the contract and initializes the account in the storage with the retrieved information.
§Arguments
address: The address of the account to retrieve the information for.
§Returns
Returns a Result containing an Option that holds the account information if it exists.
If the account is not found, None is returned.
§Errors
Returns an error if there was an issue querying the account information from the contract or accessing the storage.
§Notes
-
If the account is present in the storage, the function returns a clone of the stored account information.
-
If the account is not present in the storage, the function queries the account information from the contract, initializes the account in the storage with the retrieved information, and returns a clone of the account information.
Source§fn storage_ref(
&self,
address: Address,
index: U256,
) -> Result<U256, Self::Error>
fn storage_ref( &self, address: Address, index: U256, ) -> Result<U256, Self::Error>
Retrieves the storage value at the specified address and index.
If we don’t know the value, and the accessed contract is mocked, the function returns an empty slot instead of querying a node, to avoid potentially returning garbage values.
§Arguments
address: The address of the contract to retrieve the storage value from.index: The index of the storage value to retrieve.
§Returns
Returns a Result containing the storage value if it exists. If the contract is mocked
and the storage value is not found locally, an empty slot is returned as U256::ZERO.
§Errors
Returns an error if there was an issue querying the storage value from the contract or accessing the storage.
§Notes
-
If the contract is present locally and is mocked, the function first checks if the storage value exists locally. If found, it returns the stored value. If not found, it returns an empty slot. Mocked contracts are not expected to have valid storage values, so the function does not query a node in this case.
-
If the contract is present locally and is not mocked, the function checks if the storage value exists locally. If found, it returns the stored value. If not found, it queries the storage value from a node, stores it locally, and returns it.
-
If the contract is not present locally, the function queries the account info and storage value from a node, initializes the account locally with the retrieved information, and returns the storage value.
Source§fn block_hash_ref(&self, _number: u64) -> Result<B256, Self::Error>
fn block_hash_ref(&self, _number: u64) -> Result<B256, Self::Error>
If block header is set, returns the hash. Otherwise returns a zero hash instead of querying a node.
Source§type Error = SimulationDBError
type Error = SimulationDBError
Source§impl<P> EngineDatabaseInterface for SimulationDB<P>
impl<P> EngineDatabaseInterface for SimulationDB<P>
Source§fn init_account(
&self,
address: Address,
account: AccountInfo,
permanent_storage: Option<HashMap<U256, U256>>,
mocked: bool,
) -> Result<(), <Self as EngineDatabaseInterface>::Error>
fn init_account( &self, address: Address, account: AccountInfo, permanent_storage: Option<HashMap<U256, U256>>, mocked: bool, ) -> Result<(), <Self as EngineDatabaseInterface>::Error>
Sets up a single account
Full control over setting up an accounts. Allows to set up EOAs as well as smart contracts.
§Arguments
address- Address of the accountaccount- The account informationpermanent_storage- Storage to init the account with this storage can only be updated manually.mocked- Whether this account should be considered mocked. For mocked accounts, nothing is downloaded from a node; all data must be inserted manually.
Source§fn clear_temp_storage(
&mut self,
) -> Result<(), <Self as EngineDatabaseInterface>::Error>
fn clear_temp_storage( &mut self, ) -> Result<(), <Self as EngineDatabaseInterface>::Error>
Clears temp storage
It is recommended to call this after a new block is received, to avoid stored state leading to wrong results.
type Error = SimulationDBError
Source§fn get_current_block(&self) -> Option<BlockHeader>
fn get_current_block(&self) -> Option<BlockHeader>
Auto Trait Implementations§
impl<P> !Freeze for SimulationDB<P>
impl<P> RefUnwindSafe for SimulationDB<P>where
P: RefUnwindSafe,
impl<P> Send for SimulationDB<P>
impl<P> Sync for SimulationDB<P>
impl<P> Unpin for SimulationDB<P>
impl<P> UnwindSafe for SimulationDB<P>where
P: RefUnwindSafe,
Blanket Implementations§
§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§unsafe fn clone_to_uninit(&self, dest: *mut u8)
unsafe fn clone_to_uninit(&self, dest: *mut u8)
clone_to_uninit)Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.