From 7e6588fd6243451200aba73cff047ffa8cea27b0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bastian=20K=C3=B6cher?= Date: Fri, 22 Dec 2023 21:01:40 +0100 Subject: [PATCH 1/5] Do not depend on `node-executor` `node-executor` is pulling in `kitchensink-runtime` and that is not really required by `try-runtime-cli`. `node-executor` is also build for the test `Substrate` node and should not be used outside of the repo. --- Cargo.lock | 2 -- cli/Cargo.toml | 3 --- cli/main.rs | 11 +++-------- 3 files changed, 3 insertions(+), 13 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 536d22a2666..6c50b322546 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -11673,12 +11673,10 @@ dependencies = [ "frame-support", "node-primitives", "parity-scale-codec", - "sc-executor", "sp-io", "sp-runtime", "sp-state-machine", "sp-storage 13.0.0 (git+https://github.com/paritytech/polkadot-sdk?branch=master)", - "staging-node-executor", "tokio", "try-runtime-core", ] diff --git a/cli/Cargo.toml b/cli/Cargo.toml index 8b65252d7e7..e9c74d60a8c 100644 --- a/cli/Cargo.toml +++ b/cli/Cargo.toml @@ -21,14 +21,11 @@ env_logger = { workspace = true } parity-scale-codec = { workspace = true, features = ["derive"] } tokio = { workspace = true, features = ["full"] } -sc-executor = { workspace = true } - sp-io = { workspace = true } sp-runtime = { workspace = true } sp-state-machine = { workspace = true } sp-storage = { workspace = true } -node-executor = { workspace = true } node-primitives = { workspace = true } try-runtime-core = { workspace = true } diff --git a/cli/main.rs b/cli/main.rs index 23e08b21c1c..1367a628e56 100644 --- a/cli/main.rs +++ b/cli/main.rs @@ -300,7 +300,6 @@ use std::env; use clap::Parser; -use node_executor::ExecutorDispatch; use node_primitives::Block; use try_runtime_core::commands::TryRuntime; @@ -315,12 +314,8 @@ fn init_env() { async fn main() { init_env(); - use sc_executor::{sp_wasm_interface::ExtendedHostFunctions, NativeExecutionDispatch}; let cmd = TryRuntime::parse(); - cmd.run::::ExtendHostFunctions, - >>() - .await - .unwrap(); + cmd.run::() + .await + .unwrap(); } From f2ebe3adf345bed844212ad4742b1bc6a874c238 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bastian=20K=C3=B6cher?= Date: Fri, 22 Dec 2023 21:02:51 +0100 Subject: [PATCH 2/5] Make `snapshot_path` an alias Otherwise you can pass `--path` and `--snapshot-path` together and get confused. --- core/src/state.rs | 23 ++++------------------- 1 file changed, 4 insertions(+), 19 deletions(-) diff --git a/core/src/state.rs b/core/src/state.rs index d087c9c3934..516c6936342 100644 --- a/core/src/state.rs +++ b/core/src/state.rs @@ -127,11 +127,7 @@ impl LiveState { pub enum State { /// Use a state snapshot as the source of runtime state. Snap { - /// DEPRECATED: use `--path` instead. - #[arg(short, long)] - snapshot_path: Option, - - #[clap(short = 'p', long = "path")] + #[clap(short = 'p', long = "path", alias = "snapshot-path")] path: Option, }, @@ -168,22 +164,11 @@ impl State { ::Err: Debug, { let builder = match self { - State::Snap { - snapshot_path, - path, - } => { - // we allow both `--snapshot-path` and `--path` for now, but `--snapshot-path` is - // deprecated. - if snapshot_path.is_some() { - log::warn!( - target: LOG_TARGET, - "`--snapshot-path` is deprecated and will be removed some time after Jan 2024. Use `--path` instead." - ); - } - let path = snapshot_path + State::Snap { path } => { + let path = path .as_ref() - .or(path.as_ref()) .ok_or_else(|| "no snapshot path provided".to_string())?; + Builder::::new().mode(Mode::Offline(OfflineConfig { state_snapshot: SnapshotConfig::new(path), })) From 9fd1ca304ad06237d4f7c5a39ff4b8650623c40a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bastian=20K=C3=B6cher?= Date: Thu, 18 Jan 2024 15:22:47 +0100 Subject: [PATCH 3/5] Allow missing host functions --- core/src/lib.rs | 3 +++ 1 file changed, 3 insertions(+) diff --git a/core/src/lib.rs b/core/src/lib.rs index ebb9858f654..f43ecabbda8 100644 --- a/core/src/lib.rs +++ b/core/src/lib.rs @@ -74,6 +74,9 @@ pub(crate) fn build_executor(shared: &SharedParams) -> WasmExe )) .with_onchain_heap_alloc_strategy(heap_pages) .with_offchain_heap_alloc_strategy(heap_pages) + // There is not that much we can do if someone is using unknown host functions. + // They would need to fork the `cli` to add their custom host functions. + .with_allow_missing_host_functions(true) .build() } From 5b23fbe34edbe290d0427b1607c6bf9fc68b705a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bastian=20K=C3=B6cher?= Date: Thu, 18 Jan 2024 23:09:32 +0100 Subject: [PATCH 4/5] Update nightly and use `--locked` --- .github/workflows/rust-checks.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/rust-checks.yaml b/.github/workflows/rust-checks.yaml index de2ea9cc053..b5489b5b55f 100644 --- a/.github/workflows/rust-checks.yaml +++ b/.github/workflows/rust-checks.yaml @@ -13,7 +13,7 @@ concurrency: env: RUST_BACKTRACE: 1 # pin nightly to avoid constantly throwing out cache - TOOLCHAIN_LINT: nightly-2023-11-13 + TOOLCHAIN_LINT: nightly-2024-01-16 jobs: doc: @@ -32,7 +32,7 @@ jobs: with: version: "3.6.1" - name: cargo doc - run: RUSTFLAGS="-D warnings" cargo doc + run: RUSTFLAGS="-D warnings" cargo doc --locked lint: runs-on: ubuntu-latest From ff595c38aff5b146472e903c7b26a04acbd05d2d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bastian=20K=C3=B6cher?= Date: Fri, 19 Jan 2024 21:09:32 +0100 Subject: [PATCH 5/5] Fix it --- .github/workflows/rust-checks.yaml | 2 +- Cargo.lock | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/rust-checks.yaml b/.github/workflows/rust-checks.yaml index b5489b5b55f..bdac22a413a 100644 --- a/.github/workflows/rust-checks.yaml +++ b/.github/workflows/rust-checks.yaml @@ -13,7 +13,7 @@ concurrency: env: RUST_BACKTRACE: 1 # pin nightly to avoid constantly throwing out cache - TOOLCHAIN_LINT: nightly-2024-01-16 + TOOLCHAIN_LINT: nightly-2023-11-13 jobs: doc: diff --git a/Cargo.lock b/Cargo.lock index 6c50b322546..38d8276c9cb 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -9705,9 +9705,9 @@ checksum = "826167069c09b99d56f31e9ae5c99049e932a98c9dc2dac47645b08dbbf76ba7" [[package]] name = "smallvec" -version = "1.11.0" +version = "1.13.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "62bb4feee49fdd9f707ef802e22365a35de4b7b299de4763d44bfea899442ff9" +checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7" [[package]] name = "snap"