SimulationDB

Struct SimulationDB 

Source
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>

Source

pub fn new( client: Arc<P>, runtime: Option<Arc<Runtime>>, block: Option<BlockHeader>, ) -> Self

Source

pub fn set_block(&mut self, block: Option<BlockHeader>)

Set the block that will be used when querying a node

Source

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 accounts
  • block - The newest block

Returns a state update struct to revert this update.

Source

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>

Source§

fn clone(&self) -> SimulationDB<P>

Returns a duplicate of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<P> DatabaseRef for SimulationDB<P>
where P: Provider + Debug + Send + Sync + 'static,

Source§

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>

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>

If block header is set, returns the hash. Otherwise returns a zero hash instead of querying a node.

Source§

type Error = SimulationDBError

The database error type.
Source§

fn code_by_hash_ref(&self, _code_hash: B256) -> Result<Bytecode, Self::Error>

Gets account code by its hash.
Source§

impl<P: Debug + Provider + Debug> Debug for SimulationDB<P>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<P> EngineDatabaseInterface for SimulationDB<P>
where P: Provider + Send + Sync + 'static + Debug,

Source§

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 account
  • account - The account information
  • permanent_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>

Clears temp storage

It is recommended to call this after a new block is received, to avoid stored state leading to wrong results.

Source§

type Error = SimulationDBError

Source§

fn get_current_block(&self) -> Option<BlockHeader>

Gets the block header that this database is operating at. Read more

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> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
Source§

impl<T> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows 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
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows 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
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .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
where Self: BorrowMut<B>, B: ?Sized,

Calls .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
where Self: AsRef<R>, R: ?Sized,

Calls .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
where Self: AsMut<R>, R: ?Sized,

Calls .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
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,