diff --git a/node/src/command.rs b/node/src/command.rs index ce6f6d500010db2507c03a40802a029c8b5330d3..a7a594f9423bb2038c3a62afc579647bd2cf82e1 100644 --- a/node/src/command.rs +++ b/node/src/command.rs @@ -42,6 +42,20 @@ lazy_static! { }; }*/ +//Currently, only `gdev-benchmark` supports the benchmark of all the extrinsics. Storage and overhead are equivalent with `gdev-benchmark` and `gdev`, so we enforce `gdev-benchmark` for all benchmark-related commands. +#[cfg(feature = "runtime-benchmarks")] +fn ensure_dev(spec: &Box<dyn sc_service::ChainSpec>) -> std::result::Result<(), String> { + if spec.id() == "gdev-benchmark" { + Ok(()) + } else { + Err(format!( + "{}{}", + "can only use subcommand with --chain [gdev-benchmark], got ", + spec.id() + )) + } +} + /// Unwraps a [`crate::client::Client`] into the concrete runtime client. #[cfg(feature = "runtime-benchmarks")] macro_rules! unwrap_client { @@ -263,6 +277,7 @@ pub fn run() -> sc_cli::Result<()> { Some(Subcommand::Benchmark(cmd)) => { let runner = cli.create_runner(cmd)?; let chain_spec = &runner.config().chain_spec; + ensure_dev(chain_spec)?; match cmd { BenchmarkCmd::Storage(cmd) => runner.sync_run(|mut config| {