Skip to content

Commit

Permalink
feat: add strategy objects (#781)
Browse files Browse the repository at this point in the history
* add strategy objects

* use Box instead of Arc<Mutex<T>>
  • Loading branch information
nbaztec authored Dec 20, 2024
1 parent 1781234 commit 5353a10
Show file tree
Hide file tree
Showing 54 changed files with 3,393 additions and 1,878 deletions.
34 changes: 32 additions & 2 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ members = [
"crates/script-sequence/",
"crates/macros/",
"crates/test-utils/",
"crates/strategy/zksync/",
]
resolver = "2"

Expand Down Expand Up @@ -173,6 +174,7 @@ foundry-linking = { path = "crates/linking" }
foundry-zksync-core = { path = "crates/zksync/core" }
foundry-zksync-compiler = { path = "crates/zksync/compiler" }
foundry-zksync-inspectors = { path = "crates/zksync/inspectors" }
foundry-strategy-zksync = { path = "crates/strategy/zksync" }

# solc & compilation utilities
# foundry-block-explorers = { version = "0.9.0", default-features = false }
Expand Down
12 changes: 10 additions & 2 deletions crates/cast/bin/cmd/call.rs
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,7 @@ impl CallArgs {
let figment = Into::<Figment>::into(&self.eth).merge(&self);
let evm_opts = figment.extract::<EvmOpts>()?;
let mut config = Config::try_from(figment)?.sanitized();
let strategy = utils::get_executor_strategy(&config);

let Self {
to,
Expand Down Expand Up @@ -177,8 +178,15 @@ impl CallArgs {
env.cfg.disable_block_gas_limit = true;
env.block.gas_limit = U256::MAX;

let mut executor =
TracingExecutor::new(env, fork, evm_version, debug, decode_internal, alphanet);
let mut executor = TracingExecutor::new(
env,
fork,
evm_version,
debug,
decode_internal,
alphanet,
strategy,
);

let value = tx.value.unwrap_or_default();
let input = tx.inner.input.into_input().unwrap_or_default();
Expand Down
4 changes: 3 additions & 1 deletion crates/cast/bin/cmd/run.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use clap::Parser;
use eyre::{Result, WrapErr};
use foundry_cli::{
opts::{EtherscanOpts, RpcOpts},
utils::{handle_traces, init_progress, TraceResult},
utils::{self, handle_traces, init_progress, TraceResult},
};
use foundry_common::{is_known_system_sender, shell, SYSTEM_TRANSACTION_TYPE};
use foundry_compilers::artifacts::EvmVersion;
Expand Down Expand Up @@ -99,6 +99,7 @@ impl RunArgs {
let figment = Into::<Figment>::into(&self.rpc).merge(&self);
let evm_opts = figment.extract::<EvmOpts>()?;
let mut config = Config::try_from(figment)?.sanitized();
let strategy = utils::get_executor_strategy(&config);

let compute_units_per_second =
if self.no_rate_limit { Some(u64::MAX) } else { self.compute_units_per_second };
Expand Down Expand Up @@ -166,6 +167,7 @@ impl RunArgs {
self.debug,
self.decode_internal,
alphanet,
strategy,
);
let mut env =
EnvWithHandlerCfg::new_with_spec_id(Box::new(env.clone()), executor.spec_id());
Expand Down
3 changes: 0 additions & 3 deletions crates/cheatcodes/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,8 @@ foundry-evm-traces.workspace = true
foundry-wallets.workspace = true
forge-script-sequence.workspace = true
foundry-zksync-core.workspace = true
foundry-zksync-compiler.workspace = true
foundry-zksync-inspectors.workspace = true

zksync_types.workspace = true

alloy-dyn-abi.workspace = true
alloy-json-abi.workspace = true
alloy-primitives.workspace = true
Expand Down
31 changes: 10 additions & 21 deletions crates/cheatcodes/src/config.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
use super::Result;
use crate::Vm::Rpc;
use crate::{
strategy::{CheatcodeInspectorStrategy, EvmCheatcodeInspectorStrategy},
Vm::Rpc,
};
use alloy_primitives::{map::AddressHashMap, U256};
use foundry_common::{fs::normalize_path, ContractsByArtifact};
use foundry_compilers::{utils::canonicalize, ProjectPathsConfig};
Expand All @@ -8,8 +11,6 @@ use foundry_config::{
ResolvedRpcEndpoints,
};
use foundry_evm_core::opts::EvmOpts;
use foundry_zksync_compiler::DualCompiledContracts;
use foundry_zksync_core::vm::ZkEnv;
use semver::Version;
use std::{
path::{Path, PathBuf},
Expand Down Expand Up @@ -55,16 +56,12 @@ pub struct CheatsConfig {
pub running_contract: Option<String>,
/// Version of the script/test contract which is currently running.
pub running_version: Option<Version>,
/// ZKSolc -> Solc Contract codes
pub dual_compiled_contracts: DualCompiledContracts,
/// Use ZK-VM on startup
pub use_zk: bool,
/// The behavior strategy.
pub strategy: Box<dyn CheatcodeInspectorStrategy>,
/// Whether to enable legacy (non-reverting) assertions.
pub assertions_revert: bool,
/// Optional seed for the RNG algorithm.
pub seed: Option<U256>,
/// Era Vm environment
pub zk_env: Option<ZkEnv>,
}

impl CheatsConfig {
Expand All @@ -76,9 +73,7 @@ impl CheatsConfig {
available_artifacts: Option<ContractsByArtifact>,
running_contract: Option<String>,
running_version: Option<Version>,
dual_compiled_contracts: DualCompiledContracts,
use_zk: bool,
zk_env: Option<ZkEnv>,
strategy: Box<dyn CheatcodeInspectorStrategy>,
) -> Self {
let mut allowed_paths = vec![config.root.0.clone()];
allowed_paths.extend(config.libs.clone());
Expand Down Expand Up @@ -108,11 +103,9 @@ impl CheatsConfig {
available_artifacts,
running_contract,
running_version,
dual_compiled_contracts,
use_zk,
strategy,
assertions_revert: config.assertions_revert,
seed: config.fuzz.seed,
zk_env,
}
}

Expand Down Expand Up @@ -241,11 +234,9 @@ impl Default for CheatsConfig {
available_artifacts: Default::default(),
running_contract: Default::default(),
running_version: Default::default(),
dual_compiled_contracts: Default::default(),
use_zk: false,
strategy: Box::new(EvmCheatcodeInspectorStrategy::default()),
assertions_revert: true,
seed: None,
zk_env: Default::default(),
}
}
}
Expand All @@ -262,9 +253,7 @@ mod tests {
None,
None,
None,
Default::default(),
false,
None,
Box::new(EvmCheatcodeInspectorStrategy::default()),
)
}

Expand Down
Loading

0 comments on commit 5353a10

Please sign in to comment.