From 3168ed4d6a305f22aef096e4fbf5a3622286ee61 Mon Sep 17 00:00:00 2001
From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com>
Date: Mon, 19 Feb 2024 09:29:57 +0000
Subject: [PATCH 01/10] Bump the known_good_semver group with 1 update (#3379)
Bumps the known_good_semver group with 1 update:
[clap](https://github.com/clap-rs/clap).
Updates `clap` from 4.5.0 to 4.5.1
Release notes
Sourced from clap's
releases.
v4.5.1
[4.5.1] - 2024-02-16
Fixes
- (error) Include suggestion to add
--
even if
there is a "did you mean" so long as last
or
trailing_var_arg
is used
Changelog
Sourced from clap's
changelog.
[4.5.1] - 2024-02-16
Fixes
- (error) Include suggestion to add
--
even if
there is a "did you mean" so long as last
or
trailing_var_arg
is used
Commits
0c01b55
chore: Release
08e0b5b
docs: Update changelog
f2c4e6e
Merge pull request #5359
from poliorcetics/ab/push-szymvyzpmnqx
e782775
fix(complete): Handle newlines in command/arg descriptions
fba7c85
test(complete): Show newline issue
8a7a13a
chore: Release
7b3a3e1
docs: Update changelog
7b624ca
Merge pull request #5356
from epage/escape
446328a
fix(error): Include -- in more cases
7de6df8
test(error): Show existing last behavior
- Additional commits viewable in compare
view
[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=clap&package-manager=cargo&previous-version=4.5.0&new-version=4.5.1)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)
Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.
[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)
---
Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore major version` will close this
group update PR and stop Dependabot creating any more for the specific
dependency's major version (unless you unignore this specific
dependency's major version or upgrade to it yourself)
- `@dependabot ignore minor version` will close this
group update PR and stop Dependabot creating any more for the specific
dependency's minor version (unless you unignore this specific
dependency's minor version or upgrade to it yourself)
- `@dependabot ignore ` will close this group update PR
and stop Dependabot creating any more for the specific dependency
(unless you unignore this specific dependency or upgrade to it yourself)
- `@dependabot unignore ` will remove all of the ignore
conditions of the specified dependency
- `@dependabot unignore ` will
remove the ignore condition of the specified dependency and ignore
conditions
Signed-off-by: dependabot[bot]
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
---
Cargo.lock | 66 +++++++++----------
cumulus/client/cli/Cargo.toml | 2 +-
cumulus/parachain-template/node/Cargo.toml | 2 +-
cumulus/polkadot-parachain/Cargo.toml | 2 +-
cumulus/test/service/Cargo.toml | 2 +-
polkadot/cli/Cargo.toml | 2 +-
polkadot/node/malus/Cargo.toml | 2 +-
polkadot/node/subsystem-bench/Cargo.toml | 2 +-
.../test-parachains/adder/collator/Cargo.toml | 2 +-
.../undying/collator/Cargo.toml | 2 +-
polkadot/utils/generate-bags/Cargo.toml | 2 +-
.../remote-ext-tests/bags-list/Cargo.toml | 2 +-
substrate/bin/minimal/node/Cargo.toml | 2 +-
substrate/bin/node-template/node/Cargo.toml | 2 +-
substrate/bin/node/bench/Cargo.toml | 2 +-
substrate/bin/node/cli/Cargo.toml | 4 +-
substrate/bin/node/inspect/Cargo.toml | 2 +-
.../bin/utils/chain-spec-builder/Cargo.toml | 2 +-
substrate/bin/utils/subkey/Cargo.toml | 2 +-
substrate/client/cli/Cargo.toml | 2 +-
substrate/client/storage-monitor/Cargo.toml | 2 +-
.../solution-type/fuzzer/Cargo.toml | 2 +-
.../npos-elections/fuzzer/Cargo.toml | 2 +-
.../ci/node-template-release/Cargo.toml | 2 +-
.../utils/frame/benchmarking-cli/Cargo.toml | 2 +-
.../frame/frame-utilities-cli/Cargo.toml | 2 +-
.../generate-bags/node-runtime/Cargo.toml | 2 +-
.../utils/frame/try-runtime/cli/Cargo.toml | 2 +-
28 files changed, 61 insertions(+), 61 deletions(-)
diff --git a/Cargo.lock b/Cargo.lock
index 70600b1a35cd7..aea00abb8f036 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -2609,9 +2609,9 @@ dependencies = [
[[package]]
name = "clap"
-version = "4.5.0"
+version = "4.5.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "80c21025abd42669a92efc996ef13cfb2c5c627858421ea58d5c3b331a6c134f"
+checksum = "c918d541ef2913577a0f9566e9ce27cb35b6df072075769e0b26cb5a554520da"
dependencies = [
"clap_builder",
"clap_derive 4.5.0",
@@ -2628,9 +2628,9 @@ dependencies = [
[[package]]
name = "clap_builder"
-version = "4.5.0"
+version = "4.5.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "458bf1f341769dfcf849846f65dffdf9146daa56bcd2a47cb4e1de9915567c99"
+checksum = "9f3e7391dad68afb0c2ede1bf619f579a3dc9c2ec67f089baa397123a2f3d1eb"
dependencies = [
"anstream",
"anstyle",
@@ -2645,7 +2645,7 @@ version = "4.4.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "586a385f7ef2f8b4d86bddaa0c094794e7ccbfe5ffef1f434fe928143fc783a5"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
]
[[package]]
@@ -3380,7 +3380,7 @@ dependencies = [
"anes",
"cast",
"ciborium",
- "clap 4.5.0",
+ "clap 4.5.1",
"criterion-plot",
"futures",
"is-terminal",
@@ -3543,7 +3543,7 @@ dependencies = [
name = "cumulus-client-cli"
version = "0.7.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"parity-scale-codec",
"sc-chain-spec",
"sc-cli",
@@ -4284,7 +4284,7 @@ name = "cumulus-test-service"
version = "0.1.0"
dependencies = [
"async-trait",
- "clap 4.5.0",
+ "clap 4.5.1",
"criterion 0.5.1",
"cumulus-client-cli",
"cumulus-client-consensus-common",
@@ -5486,7 +5486,7 @@ dependencies = [
"Inflector",
"array-bytes 6.1.0",
"chrono",
- "clap 4.5.0",
+ "clap 4.5.1",
"comfy-table",
"frame-benchmarking",
"frame-support",
@@ -5578,7 +5578,7 @@ dependencies = [
name = "frame-election-solution-type-fuzzer"
version = "2.0.0-alpha.5"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"frame-election-provider-solution-type",
"frame-election-provider-support",
"frame-support",
@@ -8106,7 +8106,7 @@ checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a"
name = "minimal-node"
version = "4.0.0-dev"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"frame",
"futures",
"futures-timer",
@@ -8575,7 +8575,7 @@ name = "node-bench"
version = "0.9.0-dev"
dependencies = [
"array-bytes 6.1.0",
- "clap 4.5.0",
+ "clap 4.5.1",
"derive_more",
"fs_extra",
"futures",
@@ -8652,7 +8652,7 @@ dependencies = [
name = "node-runtime-generate-bags"
version = "3.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"generate-bags",
"kitchensink-runtime",
]
@@ -8661,7 +8661,7 @@ dependencies = [
name = "node-template"
version = "4.0.0-dev"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"frame-benchmarking",
"frame-benchmarking-cli",
"frame-system",
@@ -8705,7 +8705,7 @@ dependencies = [
name = "node-template-release"
version = "3.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"flate2",
"fs_extra",
"glob",
@@ -11275,7 +11275,7 @@ dependencies = [
name = "parachain-template-node"
version = "0.1.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"color-print",
"cumulus-client-cli",
"cumulus-client-collator",
@@ -12203,7 +12203,7 @@ name = "polkadot-cli"
version = "7.0.0"
dependencies = [
"cfg-if",
- "clap 4.5.0",
+ "clap 4.5.1",
"frame-benchmarking-cli",
"futures",
"log",
@@ -13047,7 +13047,7 @@ dependencies = [
"async-trait",
"bridge-hub-rococo-runtime",
"bridge-hub-westend-runtime",
- "clap 4.5.0",
+ "clap 4.5.1",
"collectives-westend-runtime",
"color-print",
"contracts-rococo-runtime",
@@ -13563,7 +13563,7 @@ dependencies = [
"async-trait",
"bincode",
"bitvec",
- "clap 4.5.0",
+ "clap 4.5.1",
"clap-num",
"color-eyre",
"colored",
@@ -13657,7 +13657,7 @@ version = "1.0.0"
dependencies = [
"assert_matches",
"async-trait",
- "clap 4.5.0",
+ "clap 4.5.1",
"color-eyre",
"futures",
"futures-timer",
@@ -13804,7 +13804,7 @@ dependencies = [
name = "polkadot-voter-bags"
version = "7.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"generate-bags",
"sp-io",
"westend-runtime",
@@ -14765,7 +14765,7 @@ checksum = "c08c74e62047bb2de4ff487b251e4a92e24f48745648451635cec7d591162d9f"
name = "remote-ext-tests-bags-list"
version = "1.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"frame-system",
"log",
"pallet-bags-list-remote-tests",
@@ -15603,7 +15603,7 @@ dependencies = [
"array-bytes 6.1.0",
"bip39",
"chrono",
- "clap 4.5.0",
+ "clap 4.5.1",
"fdlimit",
"futures",
"futures-timer",
@@ -16761,7 +16761,7 @@ dependencies = [
name = "sc-storage-monitor"
version = "0.16.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"fs4",
"log",
"sp-core",
@@ -18788,7 +18788,7 @@ dependencies = [
name = "sp-npos-elections-fuzzer"
version = "2.0.0-alpha.5"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"honggfuzz",
"rand",
"sp-npos-elections",
@@ -19311,7 +19311,7 @@ checksum = "a8f112729512f8e442d81f95a8a7ddf2b7c6b8a1a6f509a95864142b30cab2d3"
name = "staging-chain-spec-builder"
version = "2.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"log",
"sc-chain-spec",
"serde_json",
@@ -19324,7 +19324,7 @@ version = "3.0.0-dev"
dependencies = [
"array-bytes 6.1.0",
"assert_cmd",
- "clap 4.5.0",
+ "clap 4.5.1",
"clap_complete",
"criterion 0.4.0",
"frame-benchmarking",
@@ -19434,7 +19434,7 @@ dependencies = [
name = "staging-node-inspect"
version = "0.12.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"parity-scale-codec",
"sc-cli",
"sc-client-api",
@@ -19639,7 +19639,7 @@ dependencies = [
name = "subkey"
version = "9.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"sc-cli",
]
@@ -19681,7 +19681,7 @@ dependencies = [
name = "substrate-frame-cli"
version = "32.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"frame-support",
"frame-system",
"sc-cli",
@@ -20162,7 +20162,7 @@ dependencies = [
name = "test-parachain-adder-collator"
version = "1.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"futures",
"futures-timer",
"log",
@@ -20210,7 +20210,7 @@ dependencies = [
name = "test-parachain-undying-collator"
version = "1.0.0"
dependencies = [
- "clap 4.5.0",
+ "clap 4.5.1",
"futures",
"futures-timer",
"log",
@@ -20905,7 +20905,7 @@ version = "0.38.0"
dependencies = [
"assert_cmd",
"async-trait",
- "clap 4.5.0",
+ "clap 4.5.1",
"frame-remote-externalities",
"frame-try-runtime",
"hex",
diff --git a/cumulus/client/cli/Cargo.toml b/cumulus/client/cli/Cargo.toml
index b6d3e7a744252..eaf0d5d5d7f78 100644
--- a/cumulus/client/cli/Cargo.toml
+++ b/cumulus/client/cli/Cargo.toml
@@ -10,7 +10,7 @@ license = "GPL-3.0-or-later WITH Classpath-exception-2.0"
workspace = true
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
codec = { package = "parity-scale-codec", version = "3.0.0" }
url = "2.4.0"
diff --git a/cumulus/parachain-template/node/Cargo.toml b/cumulus/parachain-template/node/Cargo.toml
index 7ee0b4e81618a..77b484913b824 100644
--- a/cumulus/parachain-template/node/Cargo.toml
+++ b/cumulus/parachain-template/node/Cargo.toml
@@ -14,7 +14,7 @@ publish = false
workspace = true
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
log = { workspace = true, default-features = true }
codec = { package = "parity-scale-codec", version = "3.0.0" }
serde = { version = "1.0.196", features = ["derive"] }
diff --git a/cumulus/polkadot-parachain/Cargo.toml b/cumulus/polkadot-parachain/Cargo.toml
index bbd8f9d409e22..d5624941c037e 100644
--- a/cumulus/polkadot-parachain/Cargo.toml
+++ b/cumulus/polkadot-parachain/Cargo.toml
@@ -16,7 +16,7 @@ path = "src/main.rs"
[dependencies]
async-trait = "0.1.74"
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
codec = { package = "parity-scale-codec", version = "3.0.0" }
futures = "0.3.28"
hex-literal = "0.4.1"
diff --git a/cumulus/test/service/Cargo.toml b/cumulus/test/service/Cargo.toml
index 04119c4c9ee19..66bc9c6669785 100644
--- a/cumulus/test/service/Cargo.toml
+++ b/cumulus/test/service/Cargo.toml
@@ -14,7 +14,7 @@ path = "src/main.rs"
[dependencies]
async-trait = "0.1.74"
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
codec = { package = "parity-scale-codec", version = "3.0.0" }
criterion = { version = "0.5.1", features = ["async_tokio"] }
jsonrpsee = { version = "0.22", features = ["server"] }
diff --git a/polkadot/cli/Cargo.toml b/polkadot/cli/Cargo.toml
index 3f085e18765da..ee2673ac20ff3 100644
--- a/polkadot/cli/Cargo.toml
+++ b/polkadot/cli/Cargo.toml
@@ -19,7 +19,7 @@ crate-type = ["cdylib", "rlib"]
[dependencies]
cfg-if = "1.0"
-clap = { version = "4.5.0", features = ["derive"], optional = true }
+clap = { version = "4.5.1", features = ["derive"], optional = true }
log = { workspace = true, default-features = true }
thiserror = "1.0.48"
futures = "0.3.21"
diff --git a/polkadot/node/malus/Cargo.toml b/polkadot/node/malus/Cargo.toml
index 69a1ffac11137..ea25b9077f3a7 100644
--- a/polkadot/node/malus/Cargo.toml
+++ b/polkadot/node/malus/Cargo.toml
@@ -43,7 +43,7 @@ assert_matches = "1.5"
async-trait = "0.1.74"
sp-keystore = { path = "../../../substrate/primitives/keystore" }
sp-core = { path = "../../../substrate/primitives/core" }
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
futures = "0.3.21"
futures-timer = "3.0.2"
gum = { package = "tracing-gum", path = "../gum" }
diff --git a/polkadot/node/subsystem-bench/Cargo.toml b/polkadot/node/subsystem-bench/Cargo.toml
index fca88616ac47f..203cfe05db1b5 100644
--- a/polkadot/node/subsystem-bench/Cargo.toml
+++ b/polkadot/node/subsystem-bench/Cargo.toml
@@ -35,7 +35,7 @@ async-trait = "0.1.57"
sp-keystore = { path = "../../../substrate/primitives/keystore" }
sc-keystore = { path = "../../../substrate/client/keystore" }
sp-core = { path = "../../../substrate/primitives/core" }
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
futures = "0.3.21"
futures-timer = "3.0.2"
bincode = "1.3.3"
diff --git a/polkadot/parachain/test-parachains/adder/collator/Cargo.toml b/polkadot/parachain/test-parachains/adder/collator/Cargo.toml
index 268b96aa15338..8ce4ceb47c245 100644
--- a/polkadot/parachain/test-parachains/adder/collator/Cargo.toml
+++ b/polkadot/parachain/test-parachains/adder/collator/Cargo.toml
@@ -16,7 +16,7 @@ path = "src/main.rs"
[dependencies]
parity-scale-codec = { version = "3.6.1", default-features = false, features = ["derive"] }
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
futures = "0.3.21"
futures-timer = "3.0.2"
log = { workspace = true, default-features = true }
diff --git a/polkadot/parachain/test-parachains/undying/collator/Cargo.toml b/polkadot/parachain/test-parachains/undying/collator/Cargo.toml
index 805262fe02580..25fdbfa74ea08 100644
--- a/polkadot/parachain/test-parachains/undying/collator/Cargo.toml
+++ b/polkadot/parachain/test-parachains/undying/collator/Cargo.toml
@@ -16,7 +16,7 @@ path = "src/main.rs"
[dependencies]
parity-scale-codec = { version = "3.6.1", default-features = false, features = ["derive"] }
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
futures = "0.3.21"
futures-timer = "3.0.2"
log = { workspace = true, default-features = true }
diff --git a/polkadot/utils/generate-bags/Cargo.toml b/polkadot/utils/generate-bags/Cargo.toml
index 38f1ac561c520..c0e9bd332df7c 100644
--- a/polkadot/utils/generate-bags/Cargo.toml
+++ b/polkadot/utils/generate-bags/Cargo.toml
@@ -10,7 +10,7 @@ description = "CLI to generate voter bags for Polkadot runtimes"
workspace = true
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
generate-bags = { path = "../../../substrate/utils/frame/generate-bags" }
sp-io = { path = "../../../substrate/primitives/io" }
diff --git a/polkadot/utils/remote-ext-tests/bags-list/Cargo.toml b/polkadot/utils/remote-ext-tests/bags-list/Cargo.toml
index 79adfe3685205..ddc5af97a166a 100644
--- a/polkadot/utils/remote-ext-tests/bags-list/Cargo.toml
+++ b/polkadot/utils/remote-ext-tests/bags-list/Cargo.toml
@@ -18,6 +18,6 @@ sp-tracing = { path = "../../../../substrate/primitives/tracing" }
frame-system = { path = "../../../../substrate/frame/system" }
sp-core = { path = "../../../../substrate/primitives/core" }
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
log = { workspace = true, default-features = true }
tokio = { version = "1.24.2", features = ["macros"] }
diff --git a/substrate/bin/minimal/node/Cargo.toml b/substrate/bin/minimal/node/Cargo.toml
index fd10a3f37af35..02b3b0a735bfe 100644
--- a/substrate/bin/minimal/node/Cargo.toml
+++ b/substrate/bin/minimal/node/Cargo.toml
@@ -20,7 +20,7 @@ targets = ["x86_64-unknown-linux-gnu"]
name = "minimal-node"
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
futures = { version = "0.3.21", features = ["thread-pool"] }
futures-timer = "3.0.1"
jsonrpsee = { version = "0.22", features = ["server"] }
diff --git a/substrate/bin/node-template/node/Cargo.toml b/substrate/bin/node-template/node/Cargo.toml
index dbdb270b09c89..7a6955d2cec3d 100644
--- a/substrate/bin/node-template/node/Cargo.toml
+++ b/substrate/bin/node-template/node/Cargo.toml
@@ -20,7 +20,7 @@ targets = ["x86_64-unknown-linux-gnu"]
name = "node-template"
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
futures = { version = "0.3.21", features = ["thread-pool"] }
serde_json = "1.0.113"
diff --git a/substrate/bin/node/bench/Cargo.toml b/substrate/bin/node/bench/Cargo.toml
index 76b9c7a0ca600..ada58c79c77c7 100644
--- a/substrate/bin/node/bench/Cargo.toml
+++ b/substrate/bin/node/bench/Cargo.toml
@@ -16,7 +16,7 @@ workspace = true
[dependencies]
array-bytes = "6.1"
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
log = { workspace = true, default-features = true }
node-primitives = { path = "../primitives" }
node-testing = { path = "../testing" }
diff --git a/substrate/bin/node/cli/Cargo.toml b/substrate/bin/node/cli/Cargo.toml
index 42e977e74ece4..aed2101a3f592 100644
--- a/substrate/bin/node/cli/Cargo.toml
+++ b/substrate/bin/node/cli/Cargo.toml
@@ -41,7 +41,7 @@ crate-type = ["cdylib", "rlib"]
[dependencies]
# third-party dependencies
array-bytes = "6.1"
-clap = { version = "4.5.0", features = ["derive"], optional = true }
+clap = { version = "4.5.1", features = ["derive"], optional = true }
codec = { package = "parity-scale-codec", version = "3.6.1" }
serde = { version = "1.0.196", features = ["derive"] }
jsonrpsee = { version = "0.22", features = ["server"] }
@@ -165,7 +165,7 @@ sp-trie = { path = "../../../primitives/trie" }
sp-state-machine = { path = "../../../primitives/state-machine" }
[build-dependencies]
-clap = { version = "4.5.0", optional = true }
+clap = { version = "4.5.1", optional = true }
clap_complete = { version = "4.0.2", optional = true }
node-inspect = { package = "staging-node-inspect", path = "../inspect", optional = true }
frame-benchmarking-cli = { path = "../../../utils/frame/benchmarking-cli", optional = true }
diff --git a/substrate/bin/node/inspect/Cargo.toml b/substrate/bin/node/inspect/Cargo.toml
index 27bf190ce155a..6c9be0fe1acb7 100644
--- a/substrate/bin/node/inspect/Cargo.toml
+++ b/substrate/bin/node/inspect/Cargo.toml
@@ -15,7 +15,7 @@ workspace = true
targets = ["x86_64-unknown-linux-gnu"]
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
codec = { package = "parity-scale-codec", version = "3.6.1" }
thiserror = "1.0"
sc-cli = { path = "../../../client/cli" }
diff --git a/substrate/bin/utils/chain-spec-builder/Cargo.toml b/substrate/bin/utils/chain-spec-builder/Cargo.toml
index 2f4edeff49a7b..8b3180fbbcd15 100644
--- a/substrate/bin/utils/chain-spec-builder/Cargo.toml
+++ b/substrate/bin/utils/chain-spec-builder/Cargo.toml
@@ -23,7 +23,7 @@ name = "chain-spec-builder"
crate-type = ["rlib"]
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
log = { workspace = true, default-features = true }
sc-chain-spec = { path = "../../../client/chain-spec" }
serde_json = "1.0.113"
diff --git a/substrate/bin/utils/subkey/Cargo.toml b/substrate/bin/utils/subkey/Cargo.toml
index a79015238d647..93b1368ca757a 100644
--- a/substrate/bin/utils/subkey/Cargo.toml
+++ b/substrate/bin/utils/subkey/Cargo.toml
@@ -20,5 +20,5 @@ path = "src/main.rs"
name = "subkey"
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
sc-cli = { path = "../../../client/cli" }
diff --git a/substrate/client/cli/Cargo.toml b/substrate/client/cli/Cargo.toml
index f5e2be2319357..1b4d3733baa05 100644
--- a/substrate/client/cli/Cargo.toml
+++ b/substrate/client/cli/Cargo.toml
@@ -18,7 +18,7 @@ targets = ["x86_64-unknown-linux-gnu"]
[dependencies]
array-bytes = "6.1"
chrono = "0.4.31"
-clap = { version = "4.5.0", features = ["derive", "string", "wrap_help"] }
+clap = { version = "4.5.1", features = ["derive", "string", "wrap_help"] }
fdlimit = "0.3.0"
futures = "0.3.21"
itertools = "0.10.3"
diff --git a/substrate/client/storage-monitor/Cargo.toml b/substrate/client/storage-monitor/Cargo.toml
index 3916f56090972..b0f0464414216 100644
--- a/substrate/client/storage-monitor/Cargo.toml
+++ b/substrate/client/storage-monitor/Cargo.toml
@@ -12,7 +12,7 @@ homepage = "https://substrate.io"
workspace = true
[dependencies]
-clap = { version = "4.5.0", features = ["derive", "string"] }
+clap = { version = "4.5.1", features = ["derive", "string"] }
log = { workspace = true, default-features = true }
fs4 = "0.7.0"
sp-core = { path = "../../primitives/core" }
diff --git a/substrate/frame/election-provider-support/solution-type/fuzzer/Cargo.toml b/substrate/frame/election-provider-support/solution-type/fuzzer/Cargo.toml
index 5ed37033e816e..8a73dd38fa2df 100644
--- a/substrate/frame/election-provider-support/solution-type/fuzzer/Cargo.toml
+++ b/substrate/frame/election-provider-support/solution-type/fuzzer/Cargo.toml
@@ -16,7 +16,7 @@ workspace = true
targets = ["x86_64-unknown-linux-gnu"]
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
honggfuzz = "0.5"
rand = { version = "0.8", features = ["small_rng", "std"] }
diff --git a/substrate/primitives/npos-elections/fuzzer/Cargo.toml b/substrate/primitives/npos-elections/fuzzer/Cargo.toml
index fc231a535f281..bcd908b970508 100644
--- a/substrate/primitives/npos-elections/fuzzer/Cargo.toml
+++ b/substrate/primitives/npos-elections/fuzzer/Cargo.toml
@@ -17,7 +17,7 @@ workspace = true
targets = ["x86_64-unknown-linux-gnu"]
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
honggfuzz = "0.5"
rand = { version = "0.8", features = ["small_rng", "std"] }
sp-npos-elections = { path = ".." }
diff --git a/substrate/scripts/ci/node-template-release/Cargo.toml b/substrate/scripts/ci/node-template-release/Cargo.toml
index c96da2ed4263d..cc60d0a451013 100644
--- a/substrate/scripts/ci/node-template-release/Cargo.toml
+++ b/substrate/scripts/ci/node-template-release/Cargo.toml
@@ -14,7 +14,7 @@ workspace = true
targets = ["x86_64-unknown-linux-gnu"]
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
flate2 = "1.0"
fs_extra = "1.3"
glob = "0.3"
diff --git a/substrate/utils/frame/benchmarking-cli/Cargo.toml b/substrate/utils/frame/benchmarking-cli/Cargo.toml
index 68ecb0612ce8c..4f6cbc1d5d6a5 100644
--- a/substrate/utils/frame/benchmarking-cli/Cargo.toml
+++ b/substrate/utils/frame/benchmarking-cli/Cargo.toml
@@ -18,7 +18,7 @@ targets = ["x86_64-unknown-linux-gnu"]
[dependencies]
array-bytes = "6.1"
chrono = "0.4"
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
codec = { package = "parity-scale-codec", version = "3.6.1" }
comfy-table = { version = "7.1.0", default-features = false }
handlebars = "4.2.2"
diff --git a/substrate/utils/frame/frame-utilities-cli/Cargo.toml b/substrate/utils/frame/frame-utilities-cli/Cargo.toml
index 3f5e8e48e0f13..919016b2d8f09 100644
--- a/substrate/utils/frame/frame-utilities-cli/Cargo.toml
+++ b/substrate/utils/frame/frame-utilities-cli/Cargo.toml
@@ -14,7 +14,7 @@ readme = "README.md"
workspace = true
[dependencies]
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
frame-support = { path = "../../../frame/support" }
frame-system = { path = "../../../frame/system" }
sc-cli = { path = "../../../client/cli" }
diff --git a/substrate/utils/frame/generate-bags/node-runtime/Cargo.toml b/substrate/utils/frame/generate-bags/node-runtime/Cargo.toml
index 8604bab1ce54a..68d4733614c15 100644
--- a/substrate/utils/frame/generate-bags/node-runtime/Cargo.toml
+++ b/substrate/utils/frame/generate-bags/node-runtime/Cargo.toml
@@ -17,4 +17,4 @@ kitchensink-runtime = { path = "../../../../bin/node/runtime" }
generate-bags = { path = ".." }
# third-party
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
diff --git a/substrate/utils/frame/try-runtime/cli/Cargo.toml b/substrate/utils/frame/try-runtime/cli/Cargo.toml
index 998d0790490e9..63165f07e5c0f 100644
--- a/substrate/utils/frame/try-runtime/cli/Cargo.toml
+++ b/substrate/utils/frame/try-runtime/cli/Cargo.toml
@@ -38,7 +38,7 @@ frame-try-runtime = { path = "../../../../frame/try-runtime", optional = true }
substrate-rpc-client = { path = "../../rpc/client" }
async-trait = "0.1.74"
-clap = { version = "4.5.0", features = ["derive"] }
+clap = { version = "4.5.1", features = ["derive"] }
hex = { version = "0.4.3", default-features = false }
log = { workspace = true, default-features = true }
parity-scale-codec = "3.6.1"
From a5492dc6ba273f1bca8b5001bc10edd402ead382 Mon Sep 17 00:00:00 2001
From: s0me0ne-unkn0wn <48632512+s0me0ne-unkn0wn@users.noreply.github.com>
Date: Mon, 19 Feb 2024 10:39:34 +0100
Subject: [PATCH 02/10] `im-online` removal cleanup: remove off-chain storage
(#2290)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
This is a follow-up for `im-online` pallet removal that is cleaning up
its off-chain storage. Must be merged no earlier than #2265 is enacted.
Related: #1964
---------
Co-authored-by: Bastian Köcher
---
polkadot/runtime/rococo/src/lib.rs | 6 ++++++
polkadot/runtime/westend/src/lib.rs | 6 ++++++
prdoc/pr_2290.prdoc | 10 ++++++++++
substrate/frame/im-online/src/migration.rs | 15 +++++++++++++++
4 files changed, 37 insertions(+)
create mode 100644 prdoc/pr_2290.prdoc
diff --git a/polkadot/runtime/rococo/src/lib.rs b/polkadot/runtime/rococo/src/lib.rs
index 45f27312697ca..03e96ab388b72 100644
--- a/polkadot/runtime/rococo/src/lib.rs
+++ b/polkadot/runtime/rococo/src/lib.rs
@@ -1824,6 +1824,12 @@ sp_api::impl_runtime_apis! {
impl offchain_primitives::OffchainWorkerApi for Runtime {
fn offchain_worker(header: &::Header) {
+ use sp_runtime::{traits::Header, DigestItem};
+
+ if header.digest().logs().iter().any(|di| di == &DigestItem::RuntimeEnvironmentUpdated) {
+ pallet_im_online::migration::clear_offchain_storage(Session::validators().len() as u32);
+ }
+
Executive::offchain_worker(header)
}
}
diff --git a/polkadot/runtime/westend/src/lib.rs b/polkadot/runtime/westend/src/lib.rs
index 166c2d0d96e06..03bd5b18b5bed 100644
--- a/polkadot/runtime/westend/src/lib.rs
+++ b/polkadot/runtime/westend/src/lib.rs
@@ -1794,6 +1794,12 @@ sp_api::impl_runtime_apis! {
impl offchain_primitives::OffchainWorkerApi for Runtime {
fn offchain_worker(header: &::Header) {
+ use sp_runtime::{traits::Header, DigestItem};
+
+ if header.digest().logs().iter().any(|di| di == &DigestItem::RuntimeEnvironmentUpdated) {
+ pallet_im_online::migration::clear_offchain_storage(Session::validators().len() as u32);
+ }
+
Executive::offchain_worker(header)
}
}
diff --git a/prdoc/pr_2290.prdoc b/prdoc/pr_2290.prdoc
new file mode 100644
index 0000000000000..9f0476e915264
--- /dev/null
+++ b/prdoc/pr_2290.prdoc
@@ -0,0 +1,10 @@
+title: im-online pallet offcain storage cleanup
+
+doc:
+ - audience: Runtime Dev
+ description: |
+ Adds a function `clear_offchain_storage` to `pallet-im-online`. This function can be used
+ after the pallet was removed to clear its offchain storage.
+
+crates:
+ - name: pallet-im-online
diff --git a/substrate/frame/im-online/src/migration.rs b/substrate/frame/im-online/src/migration.rs
index 3860a7ca53295..0d2c0a055b6d8 100644
--- a/substrate/frame/im-online/src/migration.rs
+++ b/substrate/frame/im-online/src/migration.rs
@@ -116,6 +116,21 @@ pub mod v1 {
}
}
+/// Clears the pallet's offchain storage.
+///
+/// Must be put in `OffchainWorkerApi::offchain_worker` after
+/// the pallet was removed.
+pub fn clear_offchain_storage(validator_set_size: u32) {
+ (0..validator_set_size).for_each(|idx| {
+ let key = {
+ let mut key = DB_PREFIX.to_vec();
+ key.extend(idx.encode());
+ key
+ };
+ sp_runtime::offchain::storage::StorageValueRef::persistent(&key).clear();
+ });
+}
+
#[cfg(all(feature = "try-runtime", test))]
mod test {
use super::*;
From 2a32b5c9379e6daefd2061a8fb5b4d972d3460a1 Mon Sep 17 00:00:00 2001
From: Bulat Saifullin
Date: Mon, 19 Feb 2024 14:11:17 +0400
Subject: [PATCH 03/10] Update coretime-westend bootnodes (#3380)
Update coretime-westend bootnodes
---
cumulus/parachains/chain-specs/coretime-westend.json | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/cumulus/parachains/chain-specs/coretime-westend.json b/cumulus/parachains/chain-specs/coretime-westend.json
index 92e119b935ff1..c79fd582348b0 100644
--- a/cumulus/parachains/chain-specs/coretime-westend.json
+++ b/cumulus/parachains/chain-specs/coretime-westend.json
@@ -3,8 +3,8 @@
"id": "coretime-westend",
"chainType": "Live",
"bootNodes": [
- "/dns/westend-coretime-collator-0.parity-testnet.parity.io/tcp/30333/p2p/12D3KooWP93Dzk8T7GWxyWw9jhLcz8Pksokk3R9vL2eEH337bNkT",
- "/dns/westend-coretime-collator-1.parity-testnet.parity.io/tcp/30333/p2p/12D3KooWMh2imeAzsZKGQgm2cv6Uoep3GBYtwGfujt1bs5YfVzkH"
+ "/dns/westend-coretime-collator-node-0.parity-testnet.parity.io/tcp/30333/p2p/12D3KooWP93Dzk8T7GWxyWw9jhLcz8Pksokk3R9vL2eEH337bNkT",
+ "/dns/westend-coretime-collator-node-1.parity-testnet.parity.io/tcp/30333/p2p/12D3KooWMh2imeAzsZKGQgm2cv6Uoep3GBYtwGfujt1bs5YfVzkH"
],
"telemetryEndpoints": null,
"protocolId": null,
@@ -68,4 +68,4 @@
"childrenDefault": {}
}
}
-}
\ No newline at end of file
+}
From b78c72cf9c0e5d6772cd4a4a25239602ff2c5ad1 Mon Sep 17 00:00:00 2001
From: Gilt0 <82427864+Gilt0@users.noreply.github.com>
Date: Mon, 19 Feb 2024 21:07:10 +0900
Subject: [PATCH 04/10] [FRAME Core] remove unnecessary overrides while using
derive_impl for frame_system (#3317)
# Description
This PR removes redundant type definition from test definition config
implementations like
```
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
type A = A;
...
}
```
This changes avoid redundancies in the code as the macro `derive_impl`
defines the relevant types. To implement the changes, it was a simple
fact of running tests and making sure that the tests would still run
while the definition would be removed.
Closes #3237
As a note, here is a brief account of things done from the Issue's
description statement
```
alliance migrate alliance, fast-unstake and bags list to use derive-impl #1636
asset-conversion DONE
asset-rate DONE
assets DONE
atomic-swap DONE
aura DONE
authority-discovery DONE
authorship migrate babe and authorship to use derive-impl #1790
babe migrate babe and authorship to use derive-impl #1790
bags-list migrate alliance, fast-unstake and bags list to use derive-impl #1636
balances DONE
beefy NOTHING TO DO --- also noted this error without failing tests Feb 13 13:49:08.941 ERROR runtime::timestamp: `pallet_timestamp::UnixTime::now` is called at genesis, invalid value returned: 0
beefy-mmr NOTHING TO DO
bounties DONE
child-bounties DONE
collective DONE
contracts DONE
conviction-voting DONE
core-fellowship NOTHING TO DO
democracy DONE
election-provider-multi-phase NOTHING TO DO
elections-phragmen DONE
executive NOTHING TO DO
fast-unstake migrate alliance, fast-unstake and bags list to use derive-impl #1636
glutton DONE
grandpa DONE
identity DONE
im-online NOTHING TO DO
indices Refactor indices pallet #1789
insecure-randomness-collective-flip DONE
lottery DONE
membership DONE
merkle-mountain-range NOTHING TO DO
message-queue DONE
multisig add frame_system::DefaultConfig to individual pallet DefaultConfigs substrate#14453
nft-fractionalization DONE
nfts DONE
nicks Refactor pallet-state-trie-migration to fungible::* traits #1801 NOT IN REPO
nis DONE
node-authorization DONE
nomination-pools NOTHING TO DO -- ONLY impl for Runtime
offences DELETED EVERYTHING -- IS THAT CORRECT??
preimage DONE
proxy add frame_system::DefaultConfig to individual pallet DefaultConfigs substrate#14453
ranked-collective NOTHING TO DO
recovery DONE
referenda DONE
remark DONE
root-offences DONE
root-testing NOTHING TO DO
salary NOTHING TO DO
scheduler DONE
scored-pool DONE
session DONE -- substrate/frame/session/benchmarking/src/mock.rs untouched
society NOTHING TO DO
staking DONE
staking-bags-benchmarks NOT IN REPO
state-trie-migration NOTHING TO DO
statement DONE
sudo DONE
system DONE
timestamp DONE
tips DONE
transaction-payment NOTHING TO DO
transaction-storage NOTHING TO DO
treasury DONE
try-runtime NOTHING TO DO -- no specific mention of 'for Test'
uniques DONE
utility DONE
vesting DONE
whitelist DONE
```
---------
Co-authored-by: command-bot <>
Co-authored-by: gupnik
---
substrate/frame/asset-conversion/src/mock.rs | 24 ++-----------
substrate/frame/asset-rate/src/mock.rs | 32 ++---------------
substrate/frame/assets/src/mock.rs | 26 +-------------
substrate/frame/atomic-swap/src/tests.rs | 27 +-------------
substrate/frame/aura/src/mock.rs | 25 +------------
.../frame/authority-discovery/src/lib.rs | 27 ++------------
substrate/frame/balances/src/tests/mod.rs | 29 +++------------
substrate/frame/bounties/src/tests.rs | 22 +-----------
substrate/frame/child-bounties/src/tests.rs | 22 +-----------
substrate/frame/collective/src/tests.rs | 28 +--------------
substrate/frame/contracts/src/tests.rs | 19 ----------
.../frame/conviction-voting/src/tests.rs | 27 +-------------
substrate/frame/democracy/src/tests.rs | 23 +-----------
substrate/frame/elections-phragmen/src/lib.rs | 28 +--------------
substrate/frame/glutton/src/mock.rs | 33 ++---------------
substrate/frame/grandpa/src/mock.rs | 23 +-----------
substrate/frame/identity/src/tests.rs | 19 ----------
.../src/lib.rs | 29 ++-------------
substrate/frame/lottery/src/mock.rs | 27 +-------------
substrate/frame/membership/src/lib.rs | 31 ++--------------
.../message-queue/src/integration_test.rs | 29 +--------------
substrate/frame/message-queue/src/mock.rs | 33 ++---------------
.../frame/nft-fractionalization/src/mock.rs | 22 +-----------
substrate/frame/nfts/src/mock.rs | 22 +-----------
substrate/frame/nis/src/mock.rs | 33 ++---------------
.../frame/node-authorization/src/mock.rs | 33 ++---------------
substrate/frame/preimage/src/mock.rs | 26 ++------------
substrate/frame/recovery/src/mock.rs | 29 ++-------------
substrate/frame/referenda/src/mock.rs | 23 +-----------
substrate/frame/remark/src/mock.rs | 33 ++---------------
substrate/frame/root-offences/src/mock.rs | 29 +--------------
substrate/frame/scheduler/src/mock.rs | 32 ++---------------
substrate/frame/scored-pool/src/mock.rs | 28 +--------------
substrate/frame/session/src/mock.rs | 36 ++-----------------
substrate/frame/staking/src/mock.rs | 29 +--------------
substrate/frame/statement/src/mock.rs | 29 ++-------------
substrate/frame/sudo/src/mock.rs | 33 ++---------------
substrate/frame/system/src/mock.rs | 28 ++-------------
substrate/frame/timestamp/src/mock.rs | 33 ++---------------
substrate/frame/tips/src/tests.rs | 19 ----------
substrate/frame/treasury/src/tests.rs | 22 +-----------
substrate/frame/uniques/src/mock.rs | 27 +-------------
substrate/frame/utility/src/tests.rs | 24 ++-----------
substrate/frame/vesting/src/mock.rs | 29 ++-------------
substrate/frame/whitelist/src/mock.rs | 32 ++---------------
45 files changed, 69 insertions(+), 1165 deletions(-)
diff --git a/substrate/frame/asset-conversion/src/mock.rs b/substrate/frame/asset-conversion/src/mock.rs
index 6c19f834cb8ff..870538a68cc71 100644
--- a/substrate/frame/asset-conversion/src/mock.rs
+++ b/substrate/frame/asset-conversion/src/mock.rs
@@ -29,15 +29,14 @@ use frame_support::{
fungible::{NativeFromLeft, NativeOrWithId, UnionOf},
imbalance::ResolveAssetTo,
},
- AsEnsureOriginWithArg, ConstU128, ConstU32, ConstU64,
+ AsEnsureOriginWithArg, ConstU128, ConstU32,
},
PalletId,
};
use frame_system::{EnsureSigned, EnsureSignedBy};
use sp_arithmetic::Permill;
-use sp_core::H256;
use sp_runtime::{
- traits::{AccountIdConversion, BlakeTwo256, IdentityLookup},
+ traits::{AccountIdConversion, IdentityLookup},
BuildStorage,
};
@@ -56,29 +55,10 @@ construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type AccountId = u128;
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type DbWeight = ();
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/asset-rate/src/mock.rs b/substrate/frame/asset-rate/src/mock.rs
index d6044e09ccd1c..5981b05676414 100644
--- a/substrate/frame/asset-rate/src/mock.rs
+++ b/substrate/frame/asset-rate/src/mock.rs
@@ -18,15 +18,8 @@
//! The crate's mock.
use crate as pallet_asset_rate;
-use frame_support::{
- derive_impl,
- traits::{ConstU16, ConstU64},
-};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use frame_support::{derive_impl, traits::ConstU64};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -41,29 +34,8 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ConstU16<42>;
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/assets/src/mock.rs b/substrate/frame/assets/src/mock.rs
index 6dda08eaff8bb..e1722200c35d4 100644
--- a/substrate/frame/assets/src/mock.rs
+++ b/substrate/frame/assets/src/mock.rs
@@ -25,12 +25,8 @@ use frame_support::{
construct_runtime, derive_impl, parameter_types,
traits::{AsEnsureOriginWithArg, ConstU32, ConstU64},
};
-use sp_core::H256;
use sp_io::storage;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -48,28 +44,8 @@ type AssetId = u32;
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = AccountId;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type DbWeight = ();
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
type MaxConsumers = ConstU32<3>;
}
diff --git a/substrate/frame/atomic-swap/src/tests.rs b/substrate/frame/atomic-swap/src/tests.rs
index 4a4b96f7aae05..4b444d888ed5e 100644
--- a/substrate/frame/atomic-swap/src/tests.rs
+++ b/substrate/frame/atomic-swap/src/tests.rs
@@ -24,11 +24,7 @@ use frame_support::{
derive_impl,
traits::{ConstU32, ConstU64},
};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -43,29 +39,8 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/aura/src/mock.rs b/substrate/frame/aura/src/mock.rs
index d87fea8fc81eb..8bc3e40715831 100644
--- a/substrate/frame/aura/src/mock.rs
+++ b/substrate/frame/aura/src/mock.rs
@@ -25,8 +25,7 @@ use frame_support::{
traits::{ConstU32, ConstU64, DisabledValidators},
};
use sp_consensus_aura::{ed25519::AuthorityId, AuthorityIndex};
-use sp_core::H256;
-use sp_runtime::{testing::UintAuthorityId, traits::IdentityLookup, BuildStorage};
+use sp_runtime::{testing::UintAuthorityId, BuildStorage};
type Block = frame_system::mocking::MockBlock;
@@ -43,29 +42,7 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = ::sp_runtime::traits::BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
impl pallet_timestamp::Config for Test {
diff --git a/substrate/frame/authority-discovery/src/lib.rs b/substrate/frame/authority-discovery/src/lib.rs
index 640c0c8759ebe..2b4dfaf1aea8c 100644
--- a/substrate/frame/authority-discovery/src/lib.rs
+++ b/substrate/frame/authority-discovery/src/lib.rs
@@ -168,13 +168,10 @@ impl OneSessionHandler for Pallet {
mod tests {
use super::*;
use crate as pallet_authority_discovery;
- use frame_support::{
- derive_impl, parameter_types,
- traits::{ConstU32, ConstU64},
- };
+ use frame_support::{derive_impl, parameter_types, traits::ConstU32};
use sp_application_crypto::Pair;
use sp_authority_discovery::AuthorityPair;
- use sp_core::{crypto::key_types, H256};
+ use sp_core::crypto::key_types;
use sp_io::TestExternalities;
use sp_runtime::{
testing::UintAuthorityId,
@@ -227,29 +224,9 @@ mod tests {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = ::sp_runtime::traits::BlakeTwo256;
type AccountId = AuthorityId;
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
pub struct TestSessionHandler;
diff --git a/substrate/frame/balances/src/tests/mod.rs b/substrate/frame/balances/src/tests/mod.rs
index 91452b292b56f..599909fa94351 100644
--- a/substrate/frame/balances/src/tests/mod.rs
+++ b/substrate/frame/balances/src/tests/mod.rs
@@ -26,18 +26,18 @@ use frame_support::{
dispatch::{DispatchInfo, GetDispatchInfo},
parameter_types,
traits::{
- fungible, ConstU32, ConstU64, ConstU8, Imbalance as ImbalanceT, OnUnbalanced,
- StorageMapShim, StoredMap, VariantCount, WhitelistedStorageKeys,
+ fungible, ConstU32, ConstU8, Imbalance as ImbalanceT, OnUnbalanced, StorageMapShim,
+ StoredMap, VariantCount, WhitelistedStorageKeys,
},
weights::{IdentityFee, Weight},
};
use frame_system::{self as system, RawOrigin};
use pallet_transaction_payment::{ChargeTransactionPayment, CurrencyAdapter, Multiplier};
use scale_info::TypeInfo;
-use sp_core::{hexdisplay::HexDisplay, H256};
+use sp_core::hexdisplay::HexDisplay;
use sp_io;
use sp_runtime::{
- traits::{BadOrigin, IdentityLookup, SignedExtension, Zero},
+ traits::{BadOrigin, SignedExtension, Zero},
ArithmeticError, BuildStorage, DispatchError, DispatchResult, FixedPointNumber, RuntimeDebug,
TokenError,
};
@@ -92,29 +92,8 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = BlockWeights;
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = ::sp_runtime::traits::BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = super::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
impl pallet_transaction_payment::Config for Test {
diff --git a/substrate/frame/bounties/src/tests.rs b/substrate/frame/bounties/src/tests.rs
index b0e3c085e65df..da6596617dac4 100644
--- a/substrate/frame/bounties/src/tests.rs
+++ b/substrate/frame/bounties/src/tests.rs
@@ -31,9 +31,8 @@ use frame_support::{
PalletId,
};
-use sp_core::H256;
use sp_runtime::{
- traits::{BadOrigin, BlakeTwo256, IdentityLookup},
+ traits::{BadOrigin, IdentityLookup},
BuildStorage, Perbill, Storage,
};
@@ -61,29 +60,10 @@ type Balance = u64;
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type AccountId = u128; // u64 is not enough to hold bytes used to generate bounty account
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/child-bounties/src/tests.rs b/substrate/frame/child-bounties/src/tests.rs
index d663b8d9961de..276a90a3e29cf 100644
--- a/substrate/frame/child-bounties/src/tests.rs
+++ b/substrate/frame/child-bounties/src/tests.rs
@@ -32,9 +32,8 @@ use frame_support::{
PalletId,
};
-use sp_core::H256;
use sp_runtime::{
- traits::{BadOrigin, BlakeTwo256, IdentityLookup},
+ traits::{BadOrigin, IdentityLookup},
BuildStorage, Perbill, Permill, TokenError,
};
@@ -64,29 +63,10 @@ type Balance = u64;
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type AccountId = u128;
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/collective/src/tests.rs b/substrate/frame/collective/src/tests.rs
index dbc3fbe69b3bf..aae17b7ffc27b 100644
--- a/substrate/frame/collective/src/tests.rs
+++ b/substrate/frame/collective/src/tests.rs
@@ -26,11 +26,7 @@ use frame_support::{
};
use frame_system::{EnsureRoot, EventRecord, Phase};
use sp_core::H256;
-use sp_runtime::{
- testing::Header,
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::{testing::Header, traits::BlakeTwo256, BuildStorage};
pub type Block = sp_runtime::generic::Block;
pub type UncheckedExtrinsic = sp_runtime::generic::UncheckedExtrinsic;
@@ -93,29 +89,7 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = BlockWeights;
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = AccountId;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl Config for Test {
type RuntimeOrigin = RuntimeOrigin;
diff --git a/substrate/frame/contracts/src/tests.rs b/substrate/frame/contracts/src/tests.rs
index eba959e8d465c..a06b65b86b5a0 100644
--- a/substrate/frame/contracts/src/tests.rs
+++ b/substrate/frame/contracts/src/tests.rs
@@ -332,29 +332,10 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = BlockWeights;
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
type AccountId = AccountId32;
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
impl pallet_insecure_randomness_collective_flip::Config for Test {}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/conviction-voting/src/tests.rs b/substrate/frame/conviction-voting/src/tests.rs
index b67290e7fec59..dbcd643b60ff7 100644
--- a/substrate/frame/conviction-voting/src/tests.rs
+++ b/substrate/frame/conviction-voting/src/tests.rs
@@ -23,11 +23,7 @@ use frame_support::{
assert_noop, assert_ok, derive_impl, parameter_types,
traits::{ConstU32, ConstU64, Contains, Polling, VoteTally},
};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::BuildStorage;
use super::*;
use crate as pallet_conviction_voting;
@@ -53,29 +49,8 @@ impl Contains for BaseFilter {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = BaseFilter;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/democracy/src/tests.rs b/substrate/frame/democracy/src/tests.rs
index 8136fa5c4c97f..973e0c28eb2f7 100644
--- a/substrate/frame/democracy/src/tests.rs
+++ b/substrate/frame/democracy/src/tests.rs
@@ -29,9 +29,8 @@ use frame_support::{
};
use frame_system::{EnsureRoot, EnsureSigned, EnsureSignedBy};
use pallet_balances::{BalanceLock, Error as BalancesError};
-use sp_core::H256;
use sp_runtime::{
- traits::{BadOrigin, BlakeTwo256, Hash, IdentityLookup},
+ traits::{BadOrigin, BlakeTwo256, Hash},
BuildStorage, Perbill,
};
mod cancellation;
@@ -81,28 +80,8 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
type BaseCallFilter = BaseFilter;
- type BlockWeights = BlockWeights;
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
parameter_types! {
pub MaximumSchedulerWeight: Weight = Perbill::from_percent(80) * BlockWeights::get().max_block;
diff --git a/substrate/frame/elections-phragmen/src/lib.rs b/substrate/frame/elections-phragmen/src/lib.rs
index 5d20a3cfcee2e..a078361a5f713 100644
--- a/substrate/frame/elections-phragmen/src/lib.rs
+++ b/substrate/frame/elections-phragmen/src/lib.rs
@@ -1313,39 +1313,13 @@ mod tests {
traits::{ConstU32, ConstU64, OnInitialize},
};
use frame_system::ensure_signed;
- use sp_core::H256;
- use sp_runtime::{
- testing::Header,
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
- };
+ use sp_runtime::{testing::Header, BuildStorage};
use substrate_test_utils::assert_eq_uvec;
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/glutton/src/mock.rs b/substrate/frame/glutton/src/mock.rs
index 26863811e29a7..0049800d95298 100644
--- a/substrate/frame/glutton/src/mock.rs
+++ b/substrate/frame/glutton/src/mock.rs
@@ -18,15 +18,8 @@
use super::*;
use crate as pallet_glutton;
-use frame_support::{
- assert_ok, derive_impl,
- traits::{ConstU32, ConstU64},
-};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use frame_support::{assert_ok, derive_impl};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -40,29 +33,7 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl Config for Test {
diff --git a/substrate/frame/grandpa/src/mock.rs b/substrate/frame/grandpa/src/mock.rs
index 990a820d3a94a..5d48f974c3147 100644
--- a/substrate/frame/grandpa/src/mock.rs
+++ b/substrate/frame/grandpa/src/mock.rs
@@ -38,7 +38,7 @@ use sp_runtime::{
curve::PiecewiseLinear,
impl_opaque_keys,
testing::{TestXt, UintAuthorityId},
- traits::{IdentityLookup, OpaqueKeys},
+ traits::OpaqueKeys,
BuildStorage, DigestItem, Perbill,
};
use sp_staking::{EraIndex, SessionIndex};
@@ -68,29 +68,8 @@ impl_opaque_keys! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = sp_runtime::traits::BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
impl frame_system::offchain::SendTransactionTypes for Test
diff --git a/substrate/frame/identity/src/tests.rs b/substrate/frame/identity/src/tests.rs
index 5c9304ca8c13d..60866f12baa61 100644
--- a/substrate/frame/identity/src/tests.rs
+++ b/substrate/frame/identity/src/tests.rs
@@ -55,29 +55,10 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
type AccountId = AccountId;
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type DbWeight = ();
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/insecure-randomness-collective-flip/src/lib.rs b/substrate/frame/insecure-randomness-collective-flip/src/lib.rs
index 00f1055f6f271..04f8cda6541dd 100644
--- a/substrate/frame/insecure-randomness-collective-flip/src/lib.rs
+++ b/substrate/frame/insecure-randomness-collective-flip/src/lib.rs
@@ -163,14 +163,11 @@ mod tests {
use crate as pallet_insecure_randomness_collective_flip;
use sp_core::H256;
- use sp_runtime::{
- traits::{BlakeTwo256, Header as _, IdentityLookup},
- BuildStorage,
- };
+ use sp_runtime::{traits::Header as _, BuildStorage};
use frame_support::{
derive_impl, parameter_types,
- traits::{ConstU32, ConstU64, OnInitialize, Randomness},
+ traits::{OnInitialize, Randomness},
};
use frame_system::limits;
@@ -191,29 +188,7 @@ mod tests {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = BlockLength;
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_insecure_randomness_collective_flip::Config for Test {}
diff --git a/substrate/frame/lottery/src/mock.rs b/substrate/frame/lottery/src/mock.rs
index 0b73bba61355a..563ce7202ec39 100644
--- a/substrate/frame/lottery/src/mock.rs
+++ b/substrate/frame/lottery/src/mock.rs
@@ -26,11 +26,7 @@ use frame_support::{
};
use frame_support_test::TestRandomness;
use frame_system::EnsureRoot;
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage, Perbill,
-};
+use sp_runtime::{BuildStorage, Perbill};
type Block = frame_system::mocking::MockBlock;
@@ -49,29 +45,8 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/membership/src/lib.rs b/substrate/frame/membership/src/lib.rs
index 0e03c097d1233..19b5e54d308cb 100644
--- a/substrate/frame/membership/src/lib.rs
+++ b/substrate/frame/membership/src/lib.rs
@@ -523,16 +523,11 @@ mod tests {
use super::*;
use crate as pallet_membership;
- use sp_core::H256;
- use sp_runtime::{
- bounded_vec,
- traits::{BadOrigin, BlakeTwo256, IdentityLookup},
- BuildStorage,
- };
+ use sp_runtime::{bounded_vec, traits::BadOrigin, BuildStorage};
use frame_support::{
assert_noop, assert_ok, derive_impl, ord_parameter_types, parameter_types,
- traits::{ConstU32, ConstU64, StorageVersion},
+ traits::{ConstU32, StorageVersion},
};
use frame_system::EnsureSignedBy;
@@ -553,29 +548,7 @@ mod tests {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
ord_parameter_types! {
pub const One: u64 = 1;
diff --git a/substrate/frame/message-queue/src/integration_test.rs b/substrate/frame/message-queue/src/integration_test.rs
index aa6f019d650df..cc3da6ebdc669 100644
--- a/substrate/frame/message-queue/src/integration_test.rs
+++ b/substrate/frame/message-queue/src/integration_test.rs
@@ -37,14 +37,9 @@ use crate::{
};
use crate as pallet_message_queue;
-use frame_support::{
- derive_impl, parameter_types,
- traits::{ConstU32, ConstU64},
-};
+use frame_support::{derive_impl, parameter_types};
use rand::{rngs::StdRng, Rng, SeedableRng};
use rand_distr::Pareto;
-use sp_core::H256;
-use sp_runtime::traits::{BlakeTwo256, IdentityLookup};
use std::collections::{BTreeMap, BTreeSet};
type Block = frame_system::mocking::MockBlock;
@@ -59,29 +54,7 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
parameter_types! {
diff --git a/substrate/frame/message-queue/src/mock.rs b/substrate/frame/message-queue/src/mock.rs
index f1067ed961e8a..a46fa31df3e20 100644
--- a/substrate/frame/message-queue/src/mock.rs
+++ b/substrate/frame/message-queue/src/mock.rs
@@ -23,15 +23,8 @@ pub use super::mock_helpers::*;
use super::*;
use crate as pallet_message_queue;
-use frame_support::{
- derive_impl, parameter_types,
- traits::{ConstU32, ConstU64},
-};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use frame_support::{derive_impl, parameter_types};
+use sp_runtime::BuildStorage;
use sp_std::collections::btree_map::BTreeMap;
type Block = frame_system::mocking::MockBlock;
@@ -46,29 +39,7 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
parameter_types! {
pub const HeapSize: u32 = 24;
diff --git a/substrate/frame/nft-fractionalization/src/mock.rs b/substrate/frame/nft-fractionalization/src/mock.rs
index 40cce96d55073..a41386150091d 100644
--- a/substrate/frame/nft-fractionalization/src/mock.rs
+++ b/substrate/frame/nft-fractionalization/src/mock.rs
@@ -27,9 +27,8 @@ use frame_support::{
};
use frame_system::EnsureSigned;
use pallet_nfts::PalletFeatures;
-use sp_core::H256;
use sp_runtime::{
- traits::{BlakeTwo256, IdentifyAccount, IdentityLookup, Verify},
+ traits::{IdentifyAccount, IdentityLookup, Verify},
BuildStorage, MultiSignature,
};
@@ -52,29 +51,10 @@ construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type AccountId = AccountId;
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type DbWeight = ();
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/nfts/src/mock.rs b/substrate/frame/nfts/src/mock.rs
index ac6d0d757325d..e86fafd07e965 100644
--- a/substrate/frame/nfts/src/mock.rs
+++ b/substrate/frame/nfts/src/mock.rs
@@ -24,10 +24,9 @@ use frame_support::{
construct_runtime, derive_impl, parameter_types,
traits::{AsEnsureOriginWithArg, ConstU32, ConstU64},
};
-use sp_core::H256;
use sp_keystore::{testing::MemoryKeystore, KeystoreExt};
use sp_runtime::{
- traits::{BlakeTwo256, IdentifyAccount, IdentityLookup, Verify},
+ traits::{IdentifyAccount, IdentityLookup, Verify},
BuildStorage, MultiSignature,
};
@@ -48,29 +47,10 @@ pub type AccountId = ::AccountId;
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type AccountId = AccountId;
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type DbWeight = ();
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/nis/src/mock.rs b/substrate/frame/nis/src/mock.rs
index 98b653635caf2..03976bc66c4df 100644
--- a/substrate/frame/nis/src/mock.rs
+++ b/substrate/frame/nis/src/mock.rs
@@ -21,19 +21,13 @@ use crate::{self as pallet_nis, Perquintill, WithMaximumOf};
use frame_support::{
derive_impl, ord_parameter_types, parameter_types,
- traits::{
- fungible::Inspect, ConstU16, ConstU32, ConstU64, Everything, OnFinalize, OnInitialize,
- StorageMapShim,
- },
+ traits::{fungible::Inspect, ConstU32, ConstU64, OnFinalize, OnInitialize, StorageMapShim},
weights::Weight,
PalletId,
};
use pallet_balances::{Instance1, Instance2};
-use sp_core::{ConstU128, H256};
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_core::ConstU128;
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -52,29 +46,8 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type DbWeight = ();
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ConstU16<42>;
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/node-authorization/src/mock.rs b/substrate/frame/node-authorization/src/mock.rs
index bd648de2b243c..84ca4d7eff701 100644
--- a/substrate/frame/node-authorization/src/mock.rs
+++ b/substrate/frame/node-authorization/src/mock.rs
@@ -20,16 +20,9 @@
use super::*;
use crate as pallet_node_authorization;
-use frame_support::{
- derive_impl, ord_parameter_types,
- traits::{ConstU32, ConstU64},
-};
+use frame_support::{derive_impl, ord_parameter_types, traits::ConstU32};
use frame_system::EnsureSignedBy;
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -43,29 +36,7 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type DbWeight = ();
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
ord_parameter_types! {
diff --git a/substrate/frame/preimage/src/mock.rs b/substrate/frame/preimage/src/mock.rs
index 60ffecbb44805..a43e8347d76bf 100644
--- a/substrate/frame/preimage/src/mock.rs
+++ b/substrate/frame/preimage/src/mock.rs
@@ -22,13 +22,12 @@ use super::*;
use crate as pallet_preimage;
use frame_support::{
derive_impl, ord_parameter_types, parameter_types,
- traits::{fungible::HoldConsideration, ConstU32, ConstU64, Everything},
- weights::constants::RocksDbWeight,
+ traits::{fungible::HoldConsideration, ConstU32, ConstU64},
};
use frame_system::EnsureSignedBy;
use sp_core::H256;
use sp_runtime::{
- traits::{BlakeTwo256, Convert, IdentityLookup},
+ traits::{BlakeTwo256, Convert},
BuildStorage,
};
@@ -45,29 +44,8 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = RocksDbWeight;
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/recovery/src/mock.rs b/substrate/frame/recovery/src/mock.rs
index ba7958f7dd460..89374527e069c 100644
--- a/substrate/frame/recovery/src/mock.rs
+++ b/substrate/frame/recovery/src/mock.rs
@@ -22,13 +22,9 @@ use super::*;
use crate as recovery;
use frame_support::{
derive_impl, parameter_types,
- traits::{ConstU32, ConstU64, OnFinalize, OnInitialize},
-};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
+ traits::{OnFinalize, OnInitialize},
};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -43,29 +39,8 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
parameter_types! {
diff --git a/substrate/frame/referenda/src/mock.rs b/substrate/frame/referenda/src/mock.rs
index d9f9042fefc9f..bfafc107c28bc 100644
--- a/substrate/frame/referenda/src/mock.rs
+++ b/substrate/frame/referenda/src/mock.rs
@@ -29,9 +29,8 @@ use frame_support::{
weights::Weight,
};
use frame_system::{EnsureRoot, EnsureSignedBy};
-use sp_core::H256;
use sp_runtime::{
- traits::{BlakeTwo256, Hash, IdentityLookup},
+ traits::{BlakeTwo256, Hash},
BuildStorage, DispatchResult, Perbill,
};
@@ -62,28 +61,8 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
type BaseCallFilter = BaseFilter;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_preimage::Config for Test {
type RuntimeEvent = RuntimeEvent;
diff --git a/substrate/frame/remark/src/mock.rs b/substrate/frame/remark/src/mock.rs
index 5a5e6a3ccdff2..d89583513b60d 100644
--- a/substrate/frame/remark/src/mock.rs
+++ b/substrate/frame/remark/src/mock.rs
@@ -18,15 +18,8 @@
//! Test environment for remarks pallet.
use crate as pallet_remark;
-use frame_support::{
- derive_impl,
- traits::{ConstU16, ConstU32, ConstU64},
-};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use frame_support::derive_impl;
+use sp_runtime::BuildStorage;
pub type Block = frame_system::mocking::MockBlock;
@@ -41,29 +34,7 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type DbWeight = ();
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ConstU16<42>;
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_remark::Config for Test {
diff --git a/substrate/frame/root-offences/src/mock.rs b/substrate/frame/root-offences/src/mock.rs
index b0f346032b95e..1f7cce27769f1 100644
--- a/substrate/frame/root-offences/src/mock.rs
+++ b/substrate/frame/root-offences/src/mock.rs
@@ -27,13 +27,7 @@ use frame_support::{
traits::{ConstU32, ConstU64, Hooks, OneSessionHandler},
};
use pallet_staking::StakerStatus;
-use sp_core::H256;
-use sp_runtime::{
- curve::PiecewiseLinear,
- testing::UintAuthorityId,
- traits::{BlakeTwo256, IdentityLookup, Zero},
- BuildStorage,
-};
+use sp_runtime::{curve::PiecewiseLinear, testing::UintAuthorityId, traits::Zero, BuildStorage};
use sp_staking::{EraIndex, SessionIndex};
use sp_std::collections::btree_map::BTreeMap;
@@ -86,29 +80,8 @@ impl sp_runtime::BoundToRuntimeAppPublic for OtherSessionHandler {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/scheduler/src/mock.rs b/substrate/frame/scheduler/src/mock.rs
index dbdc430a83317..bf7dac0d53ae2 100644
--- a/substrate/frame/scheduler/src/mock.rs
+++ b/substrate/frame/scheduler/src/mock.rs
@@ -22,17 +22,10 @@ use super::*;
use crate as scheduler;
use frame_support::{
derive_impl, ord_parameter_types, parameter_types,
- traits::{
- ConstU32, ConstU64, Contains, EitherOfDiverse, EqualPrivilegeOnly, OnFinalize, OnInitialize,
- },
- weights::constants::RocksDbWeight,
+ traits::{ConstU32, Contains, EitherOfDiverse, EqualPrivilegeOnly, OnFinalize, OnInitialize},
};
use frame_system::{EnsureRoot, EnsureSignedBy};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage, Perbill,
-};
+use sp_runtime::{BuildStorage, Perbill};
// Logger module to track execution.
#[frame_support::pallet]
@@ -147,28 +140,7 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl system::Config for Test {
type BaseCallFilter = BaseFilter;
- type BlockWeights = BlockWeights;
- type BlockLength = ();
- type DbWeight = RocksDbWeight;
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl logger::Config for Test {
type RuntimeEvent = RuntimeEvent;
diff --git a/substrate/frame/scored-pool/src/mock.rs b/substrate/frame/scored-pool/src/mock.rs
index e767b49b983a3..6fba1bb3d5376 100644
--- a/substrate/frame/scored-pool/src/mock.rs
+++ b/substrate/frame/scored-pool/src/mock.rs
@@ -25,12 +25,7 @@ use frame_support::{
traits::{ConstU32, ConstU64},
};
use frame_system::EnsureSignedBy;
-use sp_core::H256;
-use sp_runtime::{
- bounded_vec,
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::{bounded_vec, BuildStorage};
type Block = frame_system::mocking::MockBlock;
@@ -53,29 +48,8 @@ ord_parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/session/src/mock.rs b/substrate/frame/session/src/mock.rs
index eb9eddfd847e6..89804f72cd626 100644
--- a/substrate/frame/session/src/mock.rs
+++ b/substrate/frame/session/src/mock.rs
@@ -24,20 +24,12 @@ use crate::historical as pallet_session_historical;
use std::collections::BTreeMap;
-use sp_core::{crypto::key_types::DUMMY, H256};
-use sp_runtime::{
- impl_opaque_keys,
- testing::UintAuthorityId,
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_core::crypto::key_types::DUMMY;
+use sp_runtime::{impl_opaque_keys, testing::UintAuthorityId, BuildStorage};
use sp_staking::SessionIndex;
use sp_state_machine::BasicExternalities;
-use frame_support::{
- derive_impl, parameter_types,
- traits::{ConstU32, ConstU64},
-};
+use frame_support::{derive_impl, parameter_types, traits::ConstU64};
impl_opaque_keys! {
pub struct MockSessionKeys {
@@ -234,29 +226,7 @@ pub fn new_test_ext() -> sp_io::TestExternalities {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_timestamp::Config for Test {
diff --git a/substrate/frame/staking/src/mock.rs b/substrate/frame/staking/src/mock.rs
index 40a5be51dedf2..24311cb9e7826 100644
--- a/substrate/frame/staking/src/mock.rs
+++ b/substrate/frame/staking/src/mock.rs
@@ -31,14 +31,8 @@ use frame_support::{
weights::constants::RocksDbWeight,
};
use frame_system::{EnsureRoot, EnsureSignedBy};
-use sp_core::H256;
use sp_io;
-use sp_runtime::{
- curve::PiecewiseLinear,
- testing::UintAuthorityId,
- traits::{IdentityLookup, Zero},
- BuildStorage,
-};
+use sp_runtime::{curve::PiecewiseLinear, testing::UintAuthorityId, traits::Zero, BuildStorage};
use sp_staking::{
offence::{DisableStrategy, OffenceDetails, OnOffenceHandler},
OnStakingUpdate,
@@ -49,7 +43,6 @@ pub const BLOCK_TIME: u64 = 1000;
/// The AccountId alias in this test module.
pub(crate) type AccountId = u64;
-pub(crate) type Nonce = u64;
pub(crate) type BlockNumber = u64;
pub(crate) type Balance = u128;
@@ -127,29 +120,9 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
type DbWeight = RocksDbWeight;
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = Nonce;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = ::sp_runtime::traits::BlakeTwo256;
- type AccountId = AccountId;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = frame_support::traits::ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
}
impl pallet_balances::Config for Test {
type MaxLocks = frame_support::traits::ConstU32<1024>;
diff --git a/substrate/frame/statement/src/mock.rs b/substrate/frame/statement/src/mock.rs
index c5bee2639dcd7..4ab9cf9e0f96a 100644
--- a/substrate/frame/statement/src/mock.rs
+++ b/substrate/frame/statement/src/mock.rs
@@ -22,14 +22,10 @@ use super::*;
use crate as pallet_statement;
use frame_support::{
derive_impl, ord_parameter_types,
- traits::{ConstU32, ConstU64, Everything},
- weights::constants::RocksDbWeight,
-};
-use sp_core::{Pair, H256};
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- AccountId32, BuildStorage,
+ traits::{ConstU32, ConstU64},
};
+use sp_core::Pair;
+use sp_runtime::{traits::IdentityLookup, AccountId32, BuildStorage};
type Block = frame_system::mocking::MockBlock;
@@ -49,29 +45,10 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = RocksDbWeight;
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type AccountId = AccountId32;
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/sudo/src/mock.rs b/substrate/frame/sudo/src/mock.rs
index 9ad14804524a9..3b907a2716836 100644
--- a/substrate/frame/sudo/src/mock.rs
+++ b/substrate/frame/sudo/src/mock.rs
@@ -19,16 +19,9 @@
use super::*;
use crate as sudo;
-use frame_support::{
- derive_impl,
- traits::{ConstU32, Contains},
-};
-use sp_core::{ConstU64, H256};
+use frame_support::{derive_impl, traits::Contains};
use sp_io;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::BuildStorage;
// Logger module to track execution.
#[frame_support::pallet]
@@ -113,29 +106,7 @@ impl Contains for BlockEverything {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = BlockEverything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
// Implement the logger module's `Config` on the Test runtime.
diff --git a/substrate/frame/system/src/mock.rs b/substrate/frame/system/src/mock.rs
index 06527a9bb2912..c4108099e39ff 100644
--- a/substrate/frame/system/src/mock.rs
+++ b/substrate/frame/system/src/mock.rs
@@ -16,15 +16,8 @@
// limitations under the License.
use crate::{self as frame_system, *};
-use frame_support::{
- derive_impl, parameter_types,
- traits::{ConstU32, ConstU64},
-};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage, Perbill,
-};
+use frame_support::{derive_impl, parameter_types};
+use sp_runtime::{BuildStorage, Perbill};
type Block = mocking::MockBlock;
@@ -87,29 +80,12 @@ impl OnKilledAccount for RecordKilled {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
type BlockWeights = RuntimeBlockWeights;
type BlockLength = RuntimeBlockLength;
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<10>;
- type DbWeight = DbWeight;
type Version = Version;
- type PalletInfo = PalletInfo;
type AccountData = u32;
- type OnNewAccount = ();
type OnKilledAccount = RecordKilled;
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
pub type SysEvent = frame_system::Event;
diff --git a/substrate/frame/timestamp/src/mock.rs b/substrate/frame/timestamp/src/mock.rs
index 5cbc5211368d4..244b66a4bb2c6 100644
--- a/substrate/frame/timestamp/src/mock.rs
+++ b/substrate/frame/timestamp/src/mock.rs
@@ -20,16 +20,9 @@
use super::*;
use crate as pallet_timestamp;
-use frame_support::{
- derive_impl, parameter_types,
- traits::{ConstU32, ConstU64},
-};
-use sp_core::H256;
+use frame_support::{derive_impl, parameter_types, traits::ConstU64};
use sp_io::TestExternalities;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
type Moment = u64;
@@ -44,29 +37,7 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
- type AccountData = ();
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
parameter_types! {
diff --git a/substrate/frame/tips/src/tests.rs b/substrate/frame/tips/src/tests.rs
index 9d4047cd80eab..0e7ea1f47817c 100644
--- a/substrate/frame/tips/src/tests.rs
+++ b/substrate/frame/tips/src/tests.rs
@@ -59,29 +59,10 @@ parameter_types! {
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type AccountId = u128; // u64 is not enough to hold bytes used to generate bounty account
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/treasury/src/tests.rs b/substrate/frame/treasury/src/tests.rs
index e35d50e23a342..b488300de99d5 100644
--- a/substrate/frame/treasury/src/tests.rs
+++ b/substrate/frame/treasury/src/tests.rs
@@ -20,9 +20,8 @@
#![cfg(test)]
use core::{cell::RefCell, marker::PhantomData};
-use sp_core::H256;
use sp_runtime::{
- traits::{BadOrigin, BlakeTwo256, Dispatchable, IdentityLookup},
+ traits::{BadOrigin, Dispatchable, IdentityLookup},
BuildStorage,
};
@@ -56,29 +55,10 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type RuntimeCall = RuntimeCall;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type AccountId = u128; // u64 is not enough to hold bytes used to generate bounty account
type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
type MaxLocks = ();
diff --git a/substrate/frame/uniques/src/mock.rs b/substrate/frame/uniques/src/mock.rs
index 16da2b2a2e285..eae125971635e 100644
--- a/substrate/frame/uniques/src/mock.rs
+++ b/substrate/frame/uniques/src/mock.rs
@@ -24,11 +24,7 @@ use frame_support::{
construct_runtime, derive_impl,
traits::{AsEnsureOriginWithArg, ConstU32, ConstU64},
};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -43,29 +39,8 @@ construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockWeights = ();
- type BlockLength = ();
- type RuntimeOrigin = RuntimeOrigin;
- type RuntimeCall = RuntimeCall;
- type Nonce = u64;
- type Hash = H256;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type DbWeight = ();
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/utility/src/tests.rs b/substrate/frame/utility/src/tests.rs
index 1a1196cb4c066..8742513be9504 100644
--- a/substrate/frame/utility/src/tests.rs
+++ b/substrate/frame/utility/src/tests.rs
@@ -27,13 +27,12 @@ use frame_support::{
dispatch::{DispatchErrorWithPostInfo, Pays},
error::BadOrigin,
parameter_types, storage,
- traits::{ConstU32, ConstU64, Contains},
+ traits::{ConstU64, Contains},
weights::Weight,
};
use pallet_collective::{EnsureProportionAtLeast, Instance1};
-use sp_core::H256;
use sp_runtime::{
- traits::{BlakeTwo256, Dispatchable, Hash, IdentityLookup},
+ traits::{BlakeTwo256, Dispatchable, Hash},
BuildStorage, DispatchError, TokenError,
};
@@ -148,27 +147,8 @@ parameter_types! {
impl frame_system::Config for Test {
type BaseCallFilter = TestBaseCallFilter;
type BlockWeights = BlockWeights;
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = frame_system::weights::SubstrateWeight;
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/vesting/src/mock.rs b/substrate/frame/vesting/src/mock.rs
index befe8cd3b760e..8a0cd13512536 100644
--- a/substrate/frame/vesting/src/mock.rs
+++ b/substrate/frame/vesting/src/mock.rs
@@ -17,13 +17,9 @@
use frame_support::{
derive_impl, parameter_types,
- traits::{ConstU32, ConstU64, WithdrawReasons},
-};
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, Identity, IdentityLookup},
- BuildStorage,
+ traits::{ConstU32, WithdrawReasons},
};
+use sp_runtime::{traits::Identity, BuildStorage};
use super::*;
use crate as pallet_vesting;
@@ -42,28 +38,7 @@ frame_support::construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
type AccountData = pallet_balances::AccountData;
- type AccountId = u64;
- type BaseCallFilter = frame_support::traits::Everything;
- type BlockHashCount = ConstU64<250>;
- type BlockLength = ();
- type BlockWeights = ();
- type RuntimeCall = RuntimeCall;
- type DbWeight = ();
- type RuntimeEvent = RuntimeEvent;
- type Hash = H256;
- type Hashing = BlakeTwo256;
type Block = Block;
- type Nonce = u64;
- type Lookup = IdentityLookup;
- type OnKilledAccount = ();
- type OnNewAccount = ();
- type OnSetCode = ();
- type MaxConsumers = frame_support::traits::ConstU32<16>;
- type RuntimeOrigin = RuntimeOrigin;
- type PalletInfo = PalletInfo;
- type SS58Prefix = ();
- type SystemWeightInfo = ();
- type Version = ();
}
impl pallet_balances::Config for Test {
diff --git a/substrate/frame/whitelist/src/mock.rs b/substrate/frame/whitelist/src/mock.rs
index c0c38075f2989..e323e806b8152 100644
--- a/substrate/frame/whitelist/src/mock.rs
+++ b/substrate/frame/whitelist/src/mock.rs
@@ -21,16 +21,9 @@
use crate as pallet_whitelist;
-use frame_support::{
- construct_runtime, derive_impl,
- traits::{ConstU32, ConstU64, Nothing},
-};
+use frame_support::{construct_runtime, derive_impl, traits::ConstU64};
use frame_system::EnsureRoot;
-use sp_core::H256;
-use sp_runtime::{
- traits::{BlakeTwo256, IdentityLookup},
- BuildStorage,
-};
+use sp_runtime::BuildStorage;
type Block = frame_system::mocking::MockBlock;
@@ -46,29 +39,8 @@ construct_runtime!(
#[derive_impl(frame_system::config_preludes::TestDefaultConfig as frame_system::DefaultConfig)]
impl frame_system::Config for Test {
- type BaseCallFilter = Nothing;
- type BlockWeights = ();
- type BlockLength = ();
- type DbWeight = ();
- type RuntimeOrigin = RuntimeOrigin;
- type Nonce = u64;
- type Hash = H256;
- type RuntimeCall = RuntimeCall;
- type Hashing = BlakeTwo256;
- type AccountId = u64;
- type Lookup = IdentityLookup;
type Block = Block;
- type RuntimeEvent = RuntimeEvent;
- type BlockHashCount = ConstU64<250>;
- type Version = ();
- type PalletInfo = PalletInfo;
type AccountData = pallet_balances::AccountData;
- type OnNewAccount = ();
- type OnKilledAccount = ();
- type SystemWeightInfo = ();
- type SS58Prefix = ();
- type OnSetCode = ();
- type MaxConsumers = ConstU32<16>;
}
impl pallet_balances::Config for Test {
From 197c6cf9e09afaeab26b31e266c1f45cff6b1197 Mon Sep 17 00:00:00 2001
From: Alexandru Gheorghe <49718502+alexggh@users.noreply.github.com>
Date: Mon, 19 Feb 2024 14:22:49 +0200
Subject: [PATCH 05/10] gossip-support: add unittests for update authorities
(#3258)
~The previous fix was actually incomplete because we update the
authorties only on the situation where we decided to reconnect because
we had a low connectivity issue. Now the problem is that
update_authority_ids use the list of connected peers, so on restart that
does contain anything, so calling immediately after
issue_connection_request won't detect all authorities, so we need to
also check every block as the comment said, but that did not match the
code.~
Actually the fix was correct the flow is follow if more than 1/3 of the
authorities can not be resolved we set last_failure and call
`ConnectToResolvedValidators`.
We will call UpdateAuthorities for all the authorities already connected
and for which we already know the address and for the ones that will
connect later on `PeerConnected` will have the AuthorityId field set,
because it is already known, so approval-distribution will update its
cache topology.
---------
Signed-off-by: Alexandru Gheorghe
Co-authored-by: Alexander Samusev <41779041+alvicsam@users.noreply.github.com>
---
Cargo.lock | 1 +
.../node/network/gossip-support/Cargo.toml | 1 +
.../node/network/gossip-support/src/lib.rs | 8 +-
.../node/network/gossip-support/src/tests.rs | 675 +++++++++++++-----
4 files changed, 506 insertions(+), 179 deletions(-)
diff --git a/Cargo.lock b/Cargo.lock
index aea00abb8f036..c26c4081bbd9d 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -12325,6 +12325,7 @@ dependencies = [
"futures",
"futures-timer",
"lazy_static",
+ "parking_lot 0.12.1",
"polkadot-node-network-protocol",
"polkadot-node-subsystem",
"polkadot-node-subsystem-test-helpers",
diff --git a/polkadot/node/network/gossip-support/Cargo.toml b/polkadot/node/network/gossip-support/Cargo.toml
index c17f39b019de1..8d0edc206d728 100644
--- a/polkadot/node/network/gossip-support/Cargo.toml
+++ b/polkadot/node/network/gossip-support/Cargo.toml
@@ -38,5 +38,6 @@ polkadot-node-subsystem-test-helpers = { path = "../../subsystem-test-helpers" }
assert_matches = "1.4.0"
async-trait = "0.1.74"
+parking_lot = "0.12.1"
lazy_static = "1.4.0"
quickcheck = "1.0.3"
diff --git a/polkadot/node/network/gossip-support/src/lib.rs b/polkadot/node/network/gossip-support/src/lib.rs
index e9cb8a4de1c47..4dfdd1f7208f6 100644
--- a/polkadot/node/network/gossip-support/src/lib.rs
+++ b/polkadot/node/network/gossip-support/src/lib.rs
@@ -63,8 +63,12 @@ use metrics::Metrics;
const LOG_TARGET: &str = "parachain::gossip-support";
// How much time should we wait to reissue a connection request
// since the last authority discovery resolution failure.
+#[cfg(not(test))]
const BACKOFF_DURATION: Duration = Duration::from_secs(5);
+#[cfg(test)]
+const BACKOFF_DURATION: Duration = Duration::from_millis(500);
+
/// Duration after which we consider low connectivity a problem.
///
/// Especially at startup low connectivity is expected (authority discovery cache needs to be
@@ -271,8 +275,8 @@ where
)
.await?;
}
- // authority_discovery is just a cache so let's try every leaf to detect if there
- // are new authorities there.
+ // authority_discovery is just a cache so let's try every time we try to re-connect
+ // if new authorities are present.
self.update_authority_ids(sender, session_info.discovery_keys).await;
}
}
diff --git a/polkadot/node/network/gossip-support/src/tests.rs b/polkadot/node/network/gossip-support/src/tests.rs
index e5ee101c31d85..6817c85f98d87 100644
--- a/polkadot/node/network/gossip-support/src/tests.rs
+++ b/polkadot/node/network/gossip-support/src/tests.rs
@@ -25,13 +25,19 @@ use lazy_static::lazy_static;
use quickcheck::quickcheck;
use rand::seq::SliceRandom as _;
+use parking_lot::Mutex;
use sc_network::multiaddr::Protocol;
use sp_authority_discovery::AuthorityPair as AuthorityDiscoveryPair;
use sp_consensus_babe::{AllowedSlots, BabeEpochConfiguration, Epoch as BabeEpoch};
use sp_core::crypto::Pair as PairT;
use sp_keyring::Sr25519Keyring;
+use std::sync::Arc;
-use polkadot_node_network_protocol::grid_topology::{SessionGridTopology, TopologyPeerInfo};
+use polkadot_node_network_protocol::{
+ grid_topology::{SessionGridTopology, TopologyPeerInfo},
+ peer_set::ValidationVersion,
+ ObservedRole,
+};
use polkadot_node_subsystem::messages::{AllMessages, RuntimeApiMessage, RuntimeApiRequest};
use polkadot_node_subsystem_test_helpers as test_helpers;
use polkadot_node_subsystem_util::TimeoutExt as _;
@@ -51,7 +57,6 @@ const AUTHORITY_KEYRINGS: &[Sr25519Keyring] = &[
];
lazy_static! {
- static ref MOCK_AUTHORITY_DISCOVERY: MockAuthorityDiscovery = MockAuthorityDiscovery::new();
static ref AUTHORITIES: Vec =
AUTHORITY_KEYRINGS.iter().map(|k| k.public().into()).collect();
@@ -89,17 +94,14 @@ type VirtualOverseer = test_helpers::TestSubsystemContextHandle>,
- authorities: HashMap>,
+ addrs: Arc>>>,
+ authorities: Arc>>>,
}
impl MockAuthorityDiscovery {
- fn new() -> Self {
- let authorities: HashMap<_, _> = PAST_PRESENT_FUTURE_AUTHORITIES
- .clone()
- .into_iter()
- .map(|a| (PeerId::random(), a))
- .collect();
+ fn new(authorities: Vec) -> Self {
+ let authorities: HashMap<_, _> =
+ authorities.clone().into_iter().map(|a| (PeerId::random(), a)).collect();
let addrs = authorities
.clone()
.into_iter()
@@ -109,10 +111,37 @@ impl MockAuthorityDiscovery {
})
.collect();
Self {
- addrs,
- authorities: authorities.into_iter().map(|(p, a)| (p, HashSet::from([a]))).collect(),
+ addrs: Arc::new(Mutex::new(addrs)),
+ authorities: Arc::new(Mutex::new(
+ authorities.into_iter().map(|(p, a)| (p, HashSet::from([a]))).collect(),
+ )),
}
}
+
+ fn authorities(&self) -> HashMap> {
+ self.authorities.lock().clone()
+ }
+
+ fn add_more_authorties(
+ &self,
+ new_known: Vec,
+ ) -> HashMap> {
+ let authorities: HashMap<_, _> =
+ new_known.clone().into_iter().map(|a| (PeerId::random(), a)).collect();
+ let addrs: HashMap> = authorities
+ .clone()
+ .into_iter()
+ .map(|(p, a)| {
+ let multiaddr = Multiaddr::empty().with(Protocol::P2p(p.into()));
+ (a, HashSet::from([multiaddr]))
+ })
+ .collect();
+ let authorities: HashMap> =
+ authorities.into_iter().map(|(p, a)| (p, HashSet::from([a]))).collect();
+ self.addrs.as_ref().lock().extend(addrs);
+ self.authorities.as_ref().lock().extend(authorities.clone());
+ authorities
+ }
}
#[async_trait]
@@ -121,19 +150,23 @@ impl AuthorityDiscovery for MockAuthorityDiscovery {
&mut self,
authority: polkadot_primitives::AuthorityDiscoveryId,
) -> Option> {
- self.addrs.get(&authority).cloned()
+ self.addrs.lock().get(&authority).cloned()
}
+
async fn get_authority_ids_by_peer_id(
&mut self,
peer_id: polkadot_node_network_protocol::PeerId,
) -> Option> {
- self.authorities.get(&peer_id).cloned()
+ self.authorities.as_ref().lock().get(&peer_id).cloned()
}
}
-async fn get_multiaddrs(authorities: Vec) -> Vec> {
+async fn get_multiaddrs(
+ authorities: Vec,
+ mock_authority_discovery: MockAuthorityDiscovery,
+) -> Vec> {
let mut addrs = Vec::with_capacity(authorities.len());
- let mut discovery = MOCK_AUTHORITY_DISCOVERY.clone();
+ let mut discovery = mock_authority_discovery.clone();
for authority in authorities.into_iter() {
if let Some(addr) = discovery.get_addresses_by_authority_id(authority).await {
addrs.push(addr);
@@ -144,9 +177,10 @@ async fn get_multiaddrs(authorities: Vec) -> Vec,
+ mock_authority_discovery: MockAuthorityDiscovery,
) -> HashMap> {
let mut addrs = HashMap::with_capacity(authorities.len());
- let mut discovery = MOCK_AUTHORITY_DISCOVERY.clone();
+ let mut discovery = mock_authority_discovery.clone();
for authority in authorities.into_iter() {
if let Some(addr) = discovery.get_addresses_by_authority_id(authority.clone()).await {
addrs.insert(authority, addr);
@@ -155,12 +189,10 @@ async fn get_address_map(
addrs
}
-fn make_subsystem() -> GossipSupport {
- GossipSupport::new(
- make_ferdie_keystore(),
- MOCK_AUTHORITY_DISCOVERY.clone(),
- Metrics::new_dummy(),
- )
+fn make_subsystem_with_authority_discovery(
+ mock: MockAuthorityDiscovery,
+) -> GossipSupport {
+ GossipSupport::new(make_ferdie_keystore(), mock, Metrics::new_dummy())
}
fn test_harness, AD: AuthorityDiscovery>(
@@ -291,59 +323,65 @@ async fn test_neighbors(overseer: &mut VirtualOverseer, expected_session: Sessio
#[test]
fn issues_a_connection_request_on_new_session() {
+ let mock_authority_discovery =
+ MockAuthorityDiscovery::new(PAST_PRESENT_FUTURE_AUTHORITIES.clone());
+ let mock_authority_discovery_clone = mock_authority_discovery.clone();
let hash = Hash::repeat_byte(0xAA);
- let state = test_harness(make_subsystem(), |mut virtual_overseer| async move {
- let overseer = &mut virtual_overseer;
- overseer_signal_active_leaves(overseer, hash).await;
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::SessionIndexForChild(tx),
- )) => {
- assert_eq!(relay_parent, hash);
- tx.send(Ok(1)).unwrap();
- }
- );
+ let state = test_harness(
+ make_subsystem_with_authority_discovery(mock_authority_discovery.clone()),
+ |mut virtual_overseer| async move {
+ let overseer = &mut virtual_overseer;
+ overseer_signal_active_leaves(overseer, hash).await;
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionIndexForChild(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(1)).unwrap();
+ }
+ );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::SessionInfo(s, tx),
- )) => {
- assert_eq!(relay_parent, hash);
- assert_eq!(s, 1);
- tx.send(Ok(Some(make_session_info()))).unwrap();
- }
- );
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionInfo(s, tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ assert_eq!(s, 1);
+ tx.send(Ok(Some(make_session_info()))).unwrap();
+ }
+ );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::Authorities(tx),
- )) => {
- assert_eq!(relay_parent, hash);
- tx.send(Ok(AUTHORITIES.clone())).unwrap();
- }
- );
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::Authorities(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(AUTHORITIES.clone())).unwrap();
+ }
+ );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
- validator_addrs,
- peer_set,
- }) => {
- assert_eq!(validator_addrs, get_multiaddrs(AUTHORITIES_WITHOUT_US.clone()).await);
- assert_eq!(peer_set, PeerSet::Validation);
- }
- );
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
+ validator_addrs,
+ peer_set,
+ }) => {
+ assert_eq!(validator_addrs, get_multiaddrs(AUTHORITIES_WITHOUT_US.clone(), mock_authority_discovery_clone).await);
+ assert_eq!(peer_set, PeerSet::Validation);
+ }
+ );
- test_neighbors(overseer, 1).await;
+ test_neighbors(overseer, 1).await;
- virtual_overseer
- });
+ virtual_overseer
+ },
+ );
assert_eq!(state.last_session_index, Some(1));
assert!(state.last_failure.is_none());
@@ -363,6 +401,7 @@ fn issues_a_connection_request_on_new_session() {
tx.send(Ok(1)).unwrap();
}
);
+
virtual_overseer
});
@@ -414,7 +453,7 @@ fn issues_a_connection_request_on_new_session() {
validator_addrs,
peer_set,
}) => {
- assert_eq!(validator_addrs, get_multiaddrs(AUTHORITIES_WITHOUT_US.clone()).await);
+ assert_eq!(validator_addrs, get_multiaddrs(AUTHORITIES_WITHOUT_US.clone(), mock_authority_discovery.clone()).await);
assert_eq!(peer_set, PeerSet::Validation);
}
);
@@ -430,125 +469,405 @@ fn issues_a_connection_request_on_new_session() {
#[test]
fn issues_connection_request_to_past_present_future() {
let hash = Hash::repeat_byte(0xAA);
- test_harness(make_subsystem(), |mut virtual_overseer| async move {
- let overseer = &mut virtual_overseer;
- overseer_signal_active_leaves(overseer, hash).await;
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::SessionIndexForChild(tx),
- )) => {
- assert_eq!(relay_parent, hash);
- tx.send(Ok(1)).unwrap();
+ let mock_authority_discovery =
+ MockAuthorityDiscovery::new(PAST_PRESENT_FUTURE_AUTHORITIES.clone());
+ test_harness(
+ make_subsystem_with_authority_discovery(mock_authority_discovery.clone()),
+ |mut virtual_overseer| async move {
+ let overseer = &mut virtual_overseer;
+ overseer_signal_active_leaves(overseer, hash).await;
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionIndexForChild(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(1)).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionInfo(s, tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ assert_eq!(s, 1);
+ tx.send(Ok(Some(make_session_info()))).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::Authorities(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(PAST_PRESENT_FUTURE_AUTHORITIES.clone())).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
+ validator_addrs,
+ peer_set,
+ }) => {
+ let all_without_ferdie: Vec<_> = PAST_PRESENT_FUTURE_AUTHORITIES
+ .iter()
+ .cloned()
+ .filter(|p| p != &Sr25519Keyring::Ferdie.public().into())
+ .collect();
+
+ let addrs = get_multiaddrs(all_without_ferdie, mock_authority_discovery.clone()).await;
+
+ assert_eq!(validator_addrs, addrs);
+ assert_eq!(peer_set, PeerSet::Validation);
+ }
+ );
+
+ // Ensure neighbors are unaffected
+ test_neighbors(overseer, 1).await;
+
+ virtual_overseer
+ },
+ );
+}
+
+// Test we notify peer about learning of the authority ID after session boundary, when we couldn't
+// connect to more than 1/3 of the authorities.
+#[test]
+fn issues_update_authorities_after_session() {
+ let hash = Hash::repeat_byte(0xAA);
+
+ let mut authorities = PAST_PRESENT_FUTURE_AUTHORITIES.clone();
+ let unknown_at_session = authorities.split_off(authorities.len() / 3 - 1);
+ let mut authority_discovery_mock = MockAuthorityDiscovery::new(authorities);
+
+ test_harness(
+ make_subsystem_with_authority_discovery(authority_discovery_mock.clone()),
+ |mut virtual_overseer| async move {
+ let overseer = &mut virtual_overseer;
+ // 1. Initialize with the first leaf in the session.
+ overseer_signal_active_leaves(overseer, hash).await;
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionIndexForChild(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(1)).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionInfo(s, tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ assert_eq!(s, 1);
+ let mut session_info = make_session_info();
+ session_info.discovery_keys = PAST_PRESENT_FUTURE_AUTHORITIES.clone();
+ tx.send(Ok(Some(session_info))).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::Authorities(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(PAST_PRESENT_FUTURE_AUTHORITIES.clone())).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
+ validator_addrs,
+ peer_set,
+ }) => {
+ let all_without_ferdie: Vec<_> = PAST_PRESENT_FUTURE_AUTHORITIES
+ .iter()
+ .cloned()
+ .filter(|p| p != &Sr25519Keyring::Ferdie.public().into())
+ .collect();
+
+ let addrs = get_multiaddrs(all_without_ferdie, authority_discovery_mock.clone()).await;
+
+ assert_eq!(validator_addrs, addrs);
+ assert_eq!(peer_set, PeerSet::Validation);
+ }
+ );
+
+ // Ensure neighbors are unaffected
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ _,
+ RuntimeApiRequest::CurrentBabeEpoch(tx),
+ )) => {
+ let _ = tx.send(Ok(BabeEpoch {
+ epoch_index: 2 as _,
+ start_slot: 0.into(),
+ duration: 200,
+ authorities: vec![(Sr25519Keyring::Alice.public().into(), 1)],
+ randomness: [0u8; 32],
+ config: BabeEpochConfiguration {
+ c: (1, 4),
+ allowed_slots: AllowedSlots::PrimarySlots,
+ },
+ })).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeRx(NetworkBridgeRxMessage::NewGossipTopology {
+ session: _,
+ local_index: _,
+ canonical_shuffling: _,
+ shuffled_indices: _,
+ }) => {
+
+ }
+ );
+
+ // 2. Connect all authorities that are known so far.
+ let known_authorities = authority_discovery_mock.authorities();
+ for (peer_id, _id) in known_authorities.iter() {
+ let msg =
+ GossipSupportMessage::NetworkBridgeUpdate(NetworkBridgeEvent::PeerConnected(
+ *peer_id,
+ ObservedRole::Authority,
+ ValidationVersion::V3.into(),
+ None,
+ ));
+ overseer.send(FromOrchestra::Communication { msg }).await
}
- );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::SessionInfo(s, tx),
- )) => {
- assert_eq!(relay_parent, hash);
- assert_eq!(s, 1);
- tx.send(Ok(Some(make_session_info()))).unwrap();
+ Delay::new(BACKOFF_DURATION).await;
+ // 3. Send a new leaf after BACKOFF_DURATION and check UpdateAuthority is emitted for
+ // all known connected peers.
+ let hash = Hash::repeat_byte(0xBB);
+ overseer_signal_active_leaves(overseer, hash).await;
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionIndexForChild(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(1)).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionInfo(s, tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ assert_eq!(s, 1);
+ let mut session_info = make_session_info();
+ session_info.discovery_keys = PAST_PRESENT_FUTURE_AUTHORITIES.clone();
+ tx.send(Ok(Some(session_info))).unwrap();
+
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::Authorities(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(PAST_PRESENT_FUTURE_AUTHORITIES.clone())).unwrap();
+ }
+ );
+
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
+ validator_addrs: _,
+ peer_set: _,
+ }) => {
+ }
+ );
+
+ for _ in 0..known_authorities.len() {
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeRx(NetworkBridgeRxMessage::UpdatedAuthorityIds {
+ peer_id,
+ authority_ids,
+ }) => {
+ assert_eq!(authority_discovery_mock.get_authority_ids_by_peer_id(peer_id).await.unwrap_or_default(), authority_ids);
+ }
+ );
}
- );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::Authorities(tx),
- )) => {
- assert_eq!(relay_parent, hash);
- tx.send(Ok(PAST_PRESENT_FUTURE_AUTHORITIES.clone())).unwrap();
+ assert!(overseer.recv().timeout(TIMEOUT).await.is_none());
+ // 4. Connect more authorities except one
+ let newly_added = authority_discovery_mock.add_more_authorties(unknown_at_session);
+ let mut newly_added_iter = newly_added.iter();
+ let unconnected_at_last_retry = newly_added_iter
+ .next()
+ .map(|(peer_id, authority_id)| (*peer_id, authority_id.clone()))
+ .unwrap();
+ for (peer_id, _) in newly_added_iter {
+ let msg =
+ GossipSupportMessage::NetworkBridgeUpdate(NetworkBridgeEvent::PeerConnected(
+ *peer_id,
+ ObservedRole::Authority,
+ ValidationVersion::V3.into(),
+ None,
+ ));
+ overseer.send(FromOrchestra::Communication { msg }).await
}
- );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
- validator_addrs,
- peer_set,
- }) => {
- let all_without_ferdie: Vec<_> = PAST_PRESENT_FUTURE_AUTHORITIES
- .iter()
- .cloned()
- .filter(|p| p != &Sr25519Keyring::Ferdie.public().into())
- .collect();
+ // 5. Send a new leaf and check UpdateAuthority is emitted only for the newly connected
+ // peers.
+ let hash = Hash::repeat_byte(0xCC);
+ Delay::new(BACKOFF_DURATION).await;
+ overseer_signal_active_leaves(overseer, hash).await;
- let addrs = get_multiaddrs(all_without_ferdie).await;
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionIndexForChild(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(1)).unwrap();
+ }
+ );
- assert_eq!(validator_addrs, addrs);
- assert_eq!(peer_set, PeerSet::Validation);
- }
- );
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionInfo(s, tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ assert_eq!(s, 1);
+ let mut session_info = make_session_info();
+ session_info.discovery_keys = PAST_PRESENT_FUTURE_AUTHORITIES.clone();
+ tx.send(Ok(Some(session_info))).unwrap();
+ }
+ );
- // Ensure neighbors are unaffected
- test_neighbors(overseer, 1).await;
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::Authorities(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(PAST_PRESENT_FUTURE_AUTHORITIES.clone())).unwrap();
+ }
+ );
- virtual_overseer
- });
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
+ validator_addrs: _,
+ peer_set: _,
+ }) => {
+ }
+ );
+
+ for _ in 1..newly_added.len() {
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeRx(NetworkBridgeRxMessage::UpdatedAuthorityIds {
+ peer_id,
+ authority_ids,
+ }) => {
+ assert_ne!(peer_id, unconnected_at_last_retry.0);
+ assert_eq!(newly_added.get(&peer_id).cloned().unwrap_or_default(), authority_ids);
+ }
+ );
+ }
+
+ assert!(overseer.recv().timeout(TIMEOUT).await.is_none());
+ virtual_overseer
+ },
+ );
}
#[test]
fn disconnect_when_not_in_past_present_future() {
sp_tracing::try_init_simple();
+ let mock_authority_discovery =
+ MockAuthorityDiscovery::new(PAST_PRESENT_FUTURE_AUTHORITIES.clone());
let hash = Hash::repeat_byte(0xAA);
- test_harness(make_subsystem(), |mut virtual_overseer| async move {
- let overseer = &mut virtual_overseer;
- overseer_signal_active_leaves(overseer, hash).await;
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::SessionIndexForChild(tx),
- )) => {
- assert_eq!(relay_parent, hash);
- tx.send(Ok(1)).unwrap();
- }
- );
+ test_harness(
+ make_subsystem_with_authority_discovery(mock_authority_discovery.clone()),
+ |mut virtual_overseer| async move {
+ let overseer = &mut virtual_overseer;
+ overseer_signal_active_leaves(overseer, hash).await;
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionIndexForChild(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(1)).unwrap();
+ }
+ );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::SessionInfo(s, tx),
- )) => {
- assert_eq!(relay_parent, hash);
- assert_eq!(s, 1);
- let mut heute_leider_nicht = make_session_info();
- heute_leider_nicht.discovery_keys = AUTHORITIES_WITHOUT_US.clone();
- tx.send(Ok(Some(heute_leider_nicht))).unwrap();
- }
- );
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::SessionInfo(s, tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ assert_eq!(s, 1);
+ let mut heute_leider_nicht = make_session_info();
+ heute_leider_nicht.discovery_keys = AUTHORITIES_WITHOUT_US.clone();
+ tx.send(Ok(Some(heute_leider_nicht))).unwrap();
+ }
+ );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::RuntimeApi(RuntimeApiMessage::Request(
- relay_parent,
- RuntimeApiRequest::Authorities(tx),
- )) => {
- assert_eq!(relay_parent, hash);
- tx.send(Ok(AUTHORITIES_WITHOUT_US.clone())).unwrap();
- }
- );
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::RuntimeApi(RuntimeApiMessage::Request(
+ relay_parent,
+ RuntimeApiRequest::Authorities(tx),
+ )) => {
+ assert_eq!(relay_parent, hash);
+ tx.send(Ok(AUTHORITIES_WITHOUT_US.clone())).unwrap();
+ }
+ );
- assert_matches!(
- overseer_recv(overseer).await,
- AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
- validator_addrs,
- peer_set,
- }) => {
- assert!(validator_addrs.is_empty());
- assert_eq!(peer_set, PeerSet::Validation);
- }
- );
+ assert_matches!(
+ overseer_recv(overseer).await,
+ AllMessages::NetworkBridgeTx(NetworkBridgeTxMessage::ConnectToResolvedValidators {
+ validator_addrs,
+ peer_set,
+ }) => {
+ assert!(validator_addrs.is_empty());
+ assert_eq!(peer_set, PeerSet::Validation);
+ }
+ );
- virtual_overseer
- });
+ virtual_overseer
+ },
+ );
}
#[test]
@@ -579,13 +898,15 @@ fn test_log_output() {
#[test]
fn issues_a_connection_request_when_last_request_was_mostly_unresolved() {
let hash = Hash::repeat_byte(0xAA);
- let mut state = make_subsystem();
+ let mock_authority_discovery =
+ MockAuthorityDiscovery::new(PAST_PRESENT_FUTURE_AUTHORITIES.clone());
+ let state = make_subsystem_with_authority_discovery(mock_authority_discovery.clone());
// There will be two lookup failures:
let alice = Sr25519Keyring::Alice.public().into();
let bob = Sr25519Keyring::Bob.public().into();
- let alice_addr = state.authority_discovery.addrs.remove(&alice);
- state.authority_discovery.addrs.remove(&bob);
-
+ let alice_addr = state.authority_discovery.addrs.lock().remove(&alice);
+ state.authority_discovery.addrs.lock().remove(&bob);
+ let mock_authority_discovery_clone = mock_authority_discovery.clone();
let mut state = {
let alice = alice.clone();
let bob = bob.clone();
@@ -633,7 +954,7 @@ fn issues_a_connection_request_when_last_request_was_mostly_unresolved() {
validator_addrs,
peer_set,
}) => {
- let mut expected = get_address_map(AUTHORITIES_WITHOUT_US.clone()).await;
+ let mut expected = get_address_map(AUTHORITIES_WITHOUT_US.clone(), mock_authority_discovery_clone.clone()).await;
expected.remove(&alice);
expected.remove(&bob);
let expected: HashSet = expected.into_values().flat_map(|v| v.into_iter()).collect();
@@ -652,7 +973,7 @@ fn issues_a_connection_request_when_last_request_was_mostly_unresolved() {
assert!(state.last_failure.is_some());
state.last_failure = state.last_failure.and_then(|i| i.checked_sub(BACKOFF_DURATION));
// One error less:
- state.authority_discovery.addrs.insert(alice, alice_addr.unwrap());
+ state.authority_discovery.addrs.lock().insert(alice, alice_addr.unwrap());
let hash = Hash::repeat_byte(0xBB);
let state = test_harness(state, |mut virtual_overseer| async move {
@@ -698,7 +1019,7 @@ fn issues_a_connection_request_when_last_request_was_mostly_unresolved() {
validator_addrs,
peer_set,
}) => {
- let mut expected = get_address_map(AUTHORITIES_WITHOUT_US.clone()).await;
+ let mut expected = get_address_map(AUTHORITIES_WITHOUT_US.clone(), mock_authority_discovery.clone()).await;
expected.remove(&bob);
let expected: HashSet = expected.into_values().flat_map(|v| v.into_iter()).collect();
assert_eq!(validator_addrs.into_iter().flat_map(|v| v.into_iter()).collect::>(), expected);
From 435e33926177c3c384d9ba4867952ebdb6a003b0 Mon Sep 17 00:00:00 2001
From: Matteo Muraca <56828990+muraca@users.noreply.github.com>
Date: Mon, 19 Feb 2024 14:19:25 +0100
Subject: [PATCH 06/10] removed `pallet::getter` from `pallet-sudo` (#3370)
part of #3326
@ggwpez @kianenigma @shawntabrizi
---------
Signed-off-by: Matteo Muraca
Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com>
---
substrate/frame/sudo/src/extension.rs | 4 ++--
substrate/frame/sudo/src/lib.rs | 3 +--
substrate/frame/sudo/src/tests.rs | 10 +++++-----
3 files changed, 8 insertions(+), 9 deletions(-)
diff --git a/substrate/frame/sudo/src/extension.rs b/substrate/frame/sudo/src/extension.rs
index c717ff3567268..e90286e5a7c6b 100644
--- a/substrate/frame/sudo/src/extension.rs
+++ b/substrate/frame/sudo/src/extension.rs
@@ -15,7 +15,7 @@
// See the License for the specific language governing permissions and
// limitations under the License.
-use crate::{Config, Pallet};
+use crate::{Config, Key};
use codec::{Decode, Encode};
use frame_support::{dispatch::DispatchInfo, ensure};
use scale_info::TypeInfo;
@@ -86,7 +86,7 @@ where
info: &DispatchInfoOf,
_len: usize,
) -> TransactionValidity {
- let sudo_key: T::AccountId = >::key().ok_or(UnknownTransaction::CannotLookup)?;
+ let sudo_key: T::AccountId = Key::::get().ok_or(UnknownTransaction::CannotLookup)?;
ensure!(*who == sudo_key, InvalidTransaction::BadSigner);
Ok(ValidTransaction {
diff --git a/substrate/frame/sudo/src/lib.rs b/substrate/frame/sudo/src/lib.rs
index 4f14c32ff76b0..2ebe4cb015712 100644
--- a/substrate/frame/sudo/src/lib.rs
+++ b/substrate/frame/sudo/src/lib.rs
@@ -329,7 +329,6 @@ pub mod pallet {
/// The `AccountId` of the sudo key.
#[pallet::storage]
- #[pallet::getter(fn key)]
pub(super) type Key = StorageValue<_, T::AccountId, OptionQuery>;
#[pallet::genesis_config]
@@ -352,7 +351,7 @@ pub mod pallet {
let sender = ensure_signed_or_root(origin)?;
if let Some(sender) = sender {
- if Self::key().map_or(false, |k| k == sender) {
+ if Key::::get().map_or(false, |k| k == sender) {
Ok(())
} else {
Err(Error::::RequireSudo.into())
diff --git a/substrate/frame/sudo/src/tests.rs b/substrate/frame/sudo/src/tests.rs
index 73689415a737f..00bb86cc2686f 100644
--- a/substrate/frame/sudo/src/tests.rs
+++ b/substrate/frame/sudo/src/tests.rs
@@ -28,7 +28,7 @@ use mock::{
fn test_setup_works() {
// Environment setup, logger storage, and sudo `key` retrieval should work as expected.
new_test_ext(1).execute_with(|| {
- assert_eq!(Sudo::key(), Some(1u64));
+ assert_eq!(Key::::get(), Some(1u64));
assert!(Logger::i32_log().is_empty());
assert!(Logger::account_log().is_empty());
});
@@ -135,7 +135,7 @@ fn set_key_basics() {
new_test_ext(1).execute_with(|| {
// A root `key` can change the root `key`
assert_ok!(Sudo::set_key(RuntimeOrigin::signed(1), 2));
- assert_eq!(Sudo::key(), Some(2u64));
+ assert_eq!(Key::::get(), Some(2u64));
});
new_test_ext(1).execute_with(|| {
@@ -161,7 +161,7 @@ fn set_key_emits_events_correctly() {
fn remove_key_works() {
new_test_ext(1).execute_with(|| {
assert_ok!(Sudo::remove_key(RuntimeOrigin::signed(1)));
- assert!(Sudo::key().is_none());
+ assert!(Key::::get().is_none());
System::assert_has_event(TestEvent::Sudo(Event::KeyRemoved {}));
assert_noop!(Sudo::remove_key(RuntimeOrigin::signed(1)), Error::::RequireSudo);
@@ -173,11 +173,11 @@ fn remove_key_works() {
fn using_root_origin_works() {
new_test_ext(1).execute_with(|| {
assert_ok!(Sudo::remove_key(RuntimeOrigin::root()));
- assert!(Sudo::key().is_none());
+ assert!(Key::::get().is_none());
System::assert_has_event(TestEvent::Sudo(Event::KeyRemoved {}));
assert_ok!(Sudo::set_key(RuntimeOrigin::root(), 1));
- assert_eq!(Some(1), Sudo::key());
+ assert_eq!(Some(1), Key::::get());
});
}
From 320863a8471ee25dc5b5ebc2395a0d139163092e Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Anton=20Vilhelm=20=C3=81sgeirsson?=
Date: Mon, 19 Feb 2024 13:25:19 +0000
Subject: [PATCH 07/10] Add Coretime to Westend (#3319)
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
Adds the coretime and on demand pallets to enable Coretime on Westend.
In order for the migration to run successfully, we need the
Broker/Coretime parachain to be live.
TODO:
- [ ] Broker parachain is live
https://github.com/paritytech/polkadot-sdk/pull/3272
---------
Co-authored-by: command-bot <>
Co-authored-by: Bastian Köcher
---
polkadot/runtime/westend/src/lib.rs | 69 +++++++++++++++++--
.../weights/runtime_parachains_coretime.rs | 57 ++++++++-------
polkadot/runtime/westend/src/xcm_config.rs | 3 +
polkadot/xcm/src/v2/mod.rs | 5 +-
prdoc/pr_3319.prdoc | 11 +++
5 files changed, 114 insertions(+), 31 deletions(-)
create mode 100644 prdoc/pr_3319.prdoc
diff --git a/polkadot/runtime/westend/src/lib.rs b/polkadot/runtime/westend/src/lib.rs
index 03bd5b18b5bed..bbb010f60bffe 100644
--- a/polkadot/runtime/westend/src/lib.rs
+++ b/polkadot/runtime/westend/src/lib.rs
@@ -61,12 +61,16 @@ use runtime_common::{
impls::{
LocatableAssetConverter, ToAuthor, VersionedLocatableAsset, VersionedLocationConverter,
},
- paras_registrar, paras_sudo_wrapper, prod_or_fast, slots, BalanceToU256, BlockHashCount,
- BlockLength, CurrencyToVote, SlowAdjustingFeeUpdate, U256ToBalance,
+ paras_registrar, paras_sudo_wrapper, prod_or_fast, slots,
+ traits::Leaser,
+ BalanceToU256, BlockHashCount, BlockLength, CurrencyToVote, SlowAdjustingFeeUpdate,
+ U256ToBalance,
};
use runtime_parachains::{
+ assigner_coretime as parachains_assigner_coretime,
+ assigner_on_demand as parachains_assigner_on_demand,
assigner_parachains as parachains_assigner_parachains,
- configuration as parachains_configuration, disputes as parachains_disputes,
+ configuration as parachains_configuration, coretime, disputes as parachains_disputes,
disputes::slashing as parachains_slashing,
dmp as parachains_dmp, hrmp as parachains_hrmp, inclusion as parachains_inclusion,
inclusion::{AggregateMessageOrigin, UmpQueueId},
@@ -147,7 +151,7 @@ pub const VERSION: RuntimeVersion = RuntimeVersion {
spec_name: create_runtime_str!("westend"),
impl_name: create_runtime_str!("parity-westend"),
authoring_version: 2,
- spec_version: 1_007_000,
+ spec_version: 1_007_001,
impl_version: 0,
apis: RUNTIME_API_VERSIONS,
transaction_version: 24,
@@ -1143,7 +1147,7 @@ impl parachains_paras::Config for Runtime {
type QueueFootprinter = ParaInclusion;
type NextSessionRotation = Babe;
type OnNewHead = ();
- type AssignCoretime = ();
+ type AssignCoretime = CoretimeAssignmentProvider;
}
parameter_types! {
@@ -1212,20 +1216,42 @@ impl parachains_paras_inherent::Config for Runtime {
impl parachains_scheduler::Config for Runtime {
// If you change this, make sure the `Assignment` type of the new provider is binary compatible,
// otherwise provide a migration.
- type AssignmentProvider = ParachainsAssignmentProvider;
+ type AssignmentProvider = CoretimeAssignmentProvider;
}
parameter_types! {
pub const BrokerId: u32 = BROKER_ID;
}
+impl coretime::Config for Runtime {
+ type RuntimeOrigin = RuntimeOrigin;
+ type RuntimeEvent = RuntimeEvent;
+ type Currency = Balances;
+ type BrokerId = BrokerId;
+ type WeightInfo = weights::runtime_parachains_coretime::WeightInfo;
+ type SendXcm = crate::xcm_config::XcmRouter;
+}
+
+parameter_types! {
+ pub const OnDemandTrafficDefaultValue: FixedU128 = FixedU128::from_u32(1);
+}
+
+impl parachains_assigner_on_demand::Config for Runtime {
+ type RuntimeEvent = RuntimeEvent;
+ type Currency = Balances;
+ type TrafficDefaultValue = OnDemandTrafficDefaultValue;
+ type WeightInfo = weights::runtime_parachains_assigner_on_demand::WeightInfo;
+}
+
impl parachains_assigner_parachains::Config for Runtime {}
+impl parachains_assigner_coretime::Config for Runtime {}
+
impl parachains_initializer::Config for Runtime {
type Randomness = pallet_babe::RandomnessFromOneEpochAgo;
type ForceOrigin = EnsureRoot;
type WeightInfo = weights::runtime_parachains_initializer::WeightInfo;
- type CoretimeOnNewSession = ();
+ type CoretimeOnNewSession = Coretime;
}
impl paras_sudo_wrapper::Config for Runtime {}
@@ -1480,6 +1506,8 @@ construct_runtime! {
ParasDisputes: parachains_disputes = 53,
ParasSlashing: parachains_slashing = 54,
ParachainsAssignmentProvider: parachains_assigner_parachains = 55,
+ OnDemandAssignmentProvider: parachains_assigner_on_demand = 56,
+ CoretimeAssignmentProvider: parachains_assigner_coretime = 57,
// Parachain Onboarding Pallets. Start indices at 60 to leave room.
Registrar: paras_registrar = 60,
@@ -1488,6 +1516,7 @@ construct_runtime! {
Auctions: auctions = 63,
Crowdloan: crowdloan = 64,
AssignedSlots: assigned_slots = 65,
+ Coretime: coretime = 66,
// Pallet for sending XCM.
XcmPallet: pallet_xcm = 99,
@@ -1555,6 +1584,24 @@ pub mod migrations {
#[cfg(feature = "try-runtime")]
use sp_core::crypto::ByteArray;
+ pub struct GetLegacyLeaseImpl;
+ impl coretime::migration::GetLegacyLease for GetLegacyLeaseImpl {
+ fn get_parachain_lease_in_blocks(para: ParaId) -> Option {
+ let now = frame_system::Pallet::::block_number();
+ let lease = slots::Pallet::::lease(para);
+ if lease.is_empty() {
+ return None
+ }
+ // Lease not yet started, ignore:
+ if lease.iter().any(Option::is_none) {
+ return None
+ }
+ let (index, _) =
+ as Leaser>::lease_period_index(now)?;
+ Some(index.saturating_add(lease.len() as u32).saturating_mul(LeasePeriod::get()))
+ }
+ }
+
parameter_types! {
pub const ImOnlinePalletName: &'static str = "ImOnline";
}
@@ -1658,6 +1705,12 @@ pub mod migrations {
parachains_configuration::migration::v11::MigrateToV11,
// permanent
pallet_xcm::migration::MigrateToLatestXcmVersion,
+ // Migrate from legacy lease to coretime. Needs to run after configuration v11
+ coretime::migration::MigrateToCoretime<
+ Runtime,
+ crate::xcm_config::XcmRouter,
+ GetLegacyLeaseImpl,
+ >,
);
}
@@ -1696,6 +1749,8 @@ mod benches {
[runtime_parachains::initializer, Initializer]
[runtime_parachains::paras, Paras]
[runtime_parachains::paras_inherent, ParaInherent]
+ [runtime_parachains::assigner_on_demand, OnDemandAssignmentProvider]
+ [runtime_parachains::coretime, Coretime]
// Substrate
[pallet_bags_list, VoterList]
[pallet_balances, Balances]
diff --git a/polkadot/runtime/westend/src/weights/runtime_parachains_coretime.rs b/polkadot/runtime/westend/src/weights/runtime_parachains_coretime.rs
index d9f2d45207b92..aa65a2e9034a7 100644
--- a/polkadot/runtime/westend/src/weights/runtime_parachains_coretime.rs
+++ b/polkadot/runtime/westend/src/weights/runtime_parachains_coretime.rs
@@ -16,11 +16,11 @@
//! Autogenerated weights for `runtime_parachains::coretime`
//!
-//! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 4.0.0-dev
-//! DATE: 2023-12-01, STEPS: `50`, REPEAT: `20`, LOW RANGE: `[]`, HIGH RANGE: `[]`
+//! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 32.0.0
+//! DATE: 2024-02-15, STEPS: `50`, REPEAT: `20`, LOW RANGE: `[]`, HIGH RANGE: `[]`
//! WORST CASE MAP SIZE: `1000000`
-//! HOSTNAME: `runner-r43aesjn-project-674-concurrent-0`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
-//! WASM-EXECUTION: `Compiled`, CHAIN: `Some("rococo-dev")`, DB CACHE: 1024
+//! HOSTNAME: `runner-bn-ce5rx-project-674-concurrent-0`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
+//! WASM-EXECUTION: `Compiled`, CHAIN: `Some("westend-dev")`, DB CACHE: 1024
// Executed Command:
// target/production/polkadot
@@ -32,10 +32,10 @@
// --wasm-execution=compiled
// --heap-pages=4096
// --json-file=/builds/parity/mirrors/polkadot-sdk/.git/.artifacts/bench.json
-// --pallet=runtime_common::coretime
-// --chain=rococo-dev
+// --pallet=runtime_parachains::coretime
+// --chain=westend-dev
// --header=./polkadot/file_header.txt
-// --output=./polkadot/runtime/rococo/src/weights/
+// --output=./polkadot/runtime/westend/src/weights/
#![cfg_attr(rustfmt, rustfmt_skip)]
#![allow(unused_parens)]
@@ -45,28 +45,39 @@
use frame_support::{traits::Get, weights::Weight};
use core::marker::PhantomData;
-use runtime_parachains::configuration::{self, WeightInfo as ConfigWeightInfo};
-
-/// Weight functions for `runtime_common::coretime`.
+/// Weight functions for `runtime_parachains::coretime`.
pub struct WeightInfo(PhantomData);
-impl runtime_parachains::coretime::WeightInfo for WeightInfo {
+impl runtime_parachains::coretime::WeightInfo for WeightInfo {
+ /// Storage: `Configuration::PendingConfigs` (r:1 w:1)
+ /// Proof: `Configuration::PendingConfigs` (`max_values`: Some(1), `max_size`: None, mode: `Measured`)
+ /// Storage: `Configuration::BypassConsistencyCheck` (r:1 w:0)
+ /// Proof: `Configuration::BypassConsistencyCheck` (`max_values`: Some(1), `max_size`: None, mode: `Measured`)
+ /// Storage: `ParasShared::CurrentSessionIndex` (r:1 w:0)
+ /// Proof: `ParasShared::CurrentSessionIndex` (`max_values`: Some(1), `max_size`: None, mode: `Measured`)
fn request_core_count() -> Weight {
- ::WeightInfo::set_config_with_u32()
+ // Proof Size summary in bytes:
+ // Measured: `151`
+ // Estimated: `1636`
+ // Minimum execution time: 7_486_000 picoseconds.
+ Weight::from_parts(7_889_000, 0)
+ .saturating_add(Weight::from_parts(0, 1636))
+ .saturating_add(T::DbWeight::get().reads(3))
+ .saturating_add(T::DbWeight::get().writes(1))
}
- /// Storage: `CoreTimeAssignmentProvider::CoreDescriptors` (r:1 w:1)
- /// Proof: `CoreTimeAssignmentProvider::CoreDescriptors` (`max_values`: None, `max_size`: None, mode: `Measured`)
- /// Storage: `CoreTimeAssignmentProvider::CoreSchedules` (r:0 w:1)
- /// Proof: `CoreTimeAssignmentProvider::CoreSchedules` (`max_values`: None, `max_size`: None, mode: `Measured`)
+ /// Storage: `CoretimeAssignmentProvider::CoreDescriptors` (r:1 w:1)
+ /// Proof: `CoretimeAssignmentProvider::CoreDescriptors` (`max_values`: None, `max_size`: None, mode: `Measured`)
+ /// Storage: `CoretimeAssignmentProvider::CoreSchedules` (r:0 w:1)
+ /// Proof: `CoretimeAssignmentProvider::CoreSchedules` (`max_values`: None, `max_size`: None, mode: `Measured`)
/// The range of component `s` is `[1, 100]`.
fn assign_core(s: u32, ) -> Weight {
// Proof Size summary in bytes:
- // Measured: `76`
- // Estimated: `3541`
- // Minimum execution time: 6_275_000 picoseconds.
- Weight::from_parts(6_883_543, 0)
- .saturating_add(Weight::from_parts(0, 3541))
- // Standard Error: 202
- .saturating_add(Weight::from_parts(15_028, 0).saturating_mul(s.into()))
+ // Measured: `147`
+ // Estimated: `3612`
+ // Minimum execution time: 9_409_000 picoseconds.
+ Weight::from_parts(10_177_115, 0)
+ .saturating_add(Weight::from_parts(0, 3612))
+ // Standard Error: 259
+ .saturating_add(Weight::from_parts(13_932, 0).saturating_mul(s.into()))
.saturating_add(T::DbWeight::get().reads(1))
.saturating_add(T::DbWeight::get().writes(2))
}
diff --git a/polkadot/runtime/westend/src/xcm_config.rs b/polkadot/runtime/westend/src/xcm_config.rs
index a11c52156c830..06124d896fbb3 100644
--- a/polkadot/runtime/westend/src/xcm_config.rs
+++ b/polkadot/runtime/westend/src/xcm_config.rs
@@ -115,11 +115,13 @@ parameter_types! {
pub Collectives: Location = Parachain(COLLECTIVES_ID).into_location();
pub BridgeHub: Location = Parachain(BRIDGE_HUB_ID).into_location();
pub People: Location = Parachain(PEOPLE_ID).into_location();
+ pub Broker: Location = Parachain(BROKER_ID).into_location();
pub Wnd: AssetFilter = Wild(AllOf { fun: WildFungible, id: AssetId(TokenLocation::get()) });
pub WndForAssetHub: (AssetFilter, Location) = (Wnd::get(), AssetHub::get());
pub WndForCollectives: (AssetFilter, Location) = (Wnd::get(), Collectives::get());
pub WndForBridgeHub: (AssetFilter, Location) = (Wnd::get(), BridgeHub::get());
pub WndForPeople: (AssetFilter, Location) = (Wnd::get(), People::get());
+ pub WndForBroker: (AssetFilter, Location) = (Wnd::get(), Broker::get());
pub MaxInstructions: u32 = 100;
pub MaxAssetsIntoHolding: u32 = 64;
}
@@ -129,6 +131,7 @@ pub type TrustedTeleporters = (
xcm_builder::Case,
xcm_builder::Case,
xcm_builder::Case,
+ xcm_builder::Case,
);
pub struct OnlyParachains;
diff --git a/polkadot/xcm/src/v2/mod.rs b/polkadot/xcm/src/v2/mod.rs
index 188b7f0b5c938..347f3f2c29206 100644
--- a/polkadot/xcm/src/v2/mod.rs
+++ b/polkadot/xcm/src/v2/mod.rs
@@ -1134,7 +1134,10 @@ impl TryFrom> for Instruction Self::UnsubscribeVersion,
- _ => return Err(()),
+ i => {
+ log::debug!(target: "xcm::v3tov2", "`{i:?}` not supported by v2");
+ return Err(());
+ },
})
}
}
diff --git a/prdoc/pr_3319.prdoc b/prdoc/pr_3319.prdoc
new file mode 100644
index 0000000000000..b84ec25a22eda
--- /dev/null
+++ b/prdoc/pr_3319.prdoc
@@ -0,0 +1,11 @@
+# Schema: Polkadot SDK PRDoc Schema (prdoc) v1.0.0
+# See doc at https://raw.githubusercontent.com/paritytech/polkadot-sdk/master/prdoc/schema_user.json
+
+title: Add Coretime to Westend
+
+doc:
+ - audience: Runtime User
+ description: |
+ Add the on demand and coretime assigners and migrate from legacy parachain auctions to coretime.
+
+crates: [ ]
From ca382f32033d8350d49934b30680d8c30dd9bdfc Mon Sep 17 00:00:00 2001
From: PG Herveou
Date: Mon, 19 Feb 2024 16:29:47 +0100
Subject: [PATCH 08/10] Contracts: xcm host fn fixes (#3086)
## Xcm changes:
- Fix `pallet_xcm::execute`, move the logic into The `ExecuteController`
so it can be shared with anything that implement that trait.
- Make `ExecuteController::execute` retursn `DispatchErrorWithPostInfo`
instead of `DispatchError`, so that we don't charge the full
`max_weight` provided if the execution is incomplete (useful for
force_batch or contracts calls)
- Fix docstring for `pallet_xcm::execute`, to reflect the changes from
#2405
- Update the signature for `ExecuteController::execute`, we don't need
to return the `Outcome` anymore since we only care about
`Outcome::Complete`
## Contracts changes:
- Update host fn `xcm_exexute`, we don't need to write the `Outcome` to
the sandbox memory anymore. This was also not charged as well before so
it if fixes this too.
- One of the issue was that the dry_run of a contract that call
`xcm_execute` would exhaust the `gas_limit`.
This is because `XcmExecuteController::execute` takes a `max_weight`
argument, and since we don't want the user to specify it manually we
were passing everything left by pre-charghing
`ctx.ext.gas_meter().gas_left()`
- To fix it I added a `fn influence_lowest_limit` on the `Token` trait
and make it return false for `RuntimeCost::XcmExecute`.
- Got rid of the `RuntimeToken` indirection, we can just use
`RuntimeCost` directly.
---------
Co-authored-by: command-bot <>
---
polkadot/xcm/pallet-xcm/src/lib.rs | 60 +++++++-----
polkadot/xcm/pallet-xcm/src/tests/mod.rs | 38 ++++----
polkadot/xcm/xcm-builder/src/controller.rs | 15 ++-
.../fixtures/contracts/xcm_execute.rs | 11 ++-
.../frame/contracts/mock-network/src/lib.rs | 3 +-
.../frame/contracts/mock-network/src/tests.rs | 71 ++++++++++----
substrate/frame/contracts/src/exec.rs | 7 ++
substrate/frame/contracts/src/gas.rs | 9 +-
substrate/frame/contracts/src/wasm/mod.rs | 4 +
substrate/frame/contracts/src/wasm/runtime.rs | 95 ++++++++-----------
substrate/frame/contracts/uapi/src/host.rs | 3 +-
.../frame/contracts/uapi/src/host/riscv32.rs | 2 +-
.../frame/contracts/uapi/src/host/wasm32.rs | 7 +-
13 files changed, 192 insertions(+), 133 deletions(-)
diff --git a/polkadot/xcm/pallet-xcm/src/lib.rs b/polkadot/xcm/pallet-xcm/src/lib.rs
index 586c275ae980f..5e1a3e55f9b62 100644
--- a/polkadot/xcm/pallet-xcm/src/lib.rs
+++ b/polkadot/xcm/pallet-xcm/src/lib.rs
@@ -29,7 +29,7 @@ pub mod migration;
use codec::{Decode, Encode, EncodeLike, MaxEncodedLen};
use frame_support::{
- dispatch::GetDispatchInfo,
+ dispatch::{DispatchErrorWithPostInfo, GetDispatchInfo, WithPostDispatchInfo},
pallet_prelude::*,
traits::{
Contains, ContainsPair, Currency, Defensive, EnsureOrigin, Get, LockableCurrency,
@@ -291,22 +291,38 @@ pub mod pallet {
origin: OriginFor,
message: Box::RuntimeCall>>,
max_weight: Weight,
- ) -> Result {
- let origin_location = T::ExecuteXcmOrigin::ensure_origin(origin)?;
- let mut hash = message.using_encoded(sp_io::hashing::blake2_256);
- let message = (*message).try_into().map_err(|()| Error::::BadVersion)?;
- let value = (origin_location, message);
- ensure!(T::XcmExecuteFilter::contains(&value), Error::::Filtered);
- let (origin_location, message) = value;
- let outcome = T::XcmExecutor::prepare_and_execute(
- origin_location,
- message,
- &mut hash,
- max_weight,
- max_weight,
- );
+ ) -> Result {
+ log::trace!(target: "xcm::pallet_xcm::execute", "message {:?}, max_weight {:?}", message, max_weight);
+ let outcome = (|| {
+ let origin_location = T::ExecuteXcmOrigin::ensure_origin(origin)?;
+ let mut hash = message.using_encoded(sp_io::hashing::blake2_256);
+ let message = (*message).try_into().map_err(|()| Error::::BadVersion)?;
+ let value = (origin_location, message);
+ ensure!(T::XcmExecuteFilter::contains(&value), Error::::Filtered);
+ let (origin_location, message) = value;
+ Ok(T::XcmExecutor::prepare_and_execute(
+ origin_location,
+ message,
+ &mut hash,
+ max_weight,
+ max_weight,
+ ))
+ })()
+ .map_err(|e: DispatchError| {
+ e.with_weight(::execute())
+ })?;
+
Self::deposit_event(Event::Attempted { outcome: outcome.clone() });
- Ok(outcome)
+ let weight_used = outcome.weight_used();
+ outcome.ensure_complete().map_err(|error| {
+ log::error!(target: "xcm::pallet_xcm::execute", "XCM execution failed with error {:?}", error);
+ Error::::LocalExecutionIncomplete.with_weight(
+ weight_used.saturating_add(
+ ::execute(),
+ ),
+ )
+ })?;
+ Ok(weight_used)
}
}
@@ -1009,9 +1025,6 @@ pub mod pallet {
/// No more than `max_weight` will be used in its attempted execution. If this is less than
/// the maximum amount of weight that the message could take to be executed, then no
/// execution attempt will be made.
- ///
- /// NOTE: A successful return to this does *not* imply that the `msg` was executed
- /// successfully to completion; only that it was attempted.
#[pallet::call_index(3)]
#[pallet::weight(max_weight.saturating_add(T::WeightInfo::execute()))]
pub fn execute(
@@ -1019,13 +1032,8 @@ pub mod pallet {
message: Box::RuntimeCall>>,
max_weight: Weight,
) -> DispatchResultWithPostInfo {
- log::trace!(target: "xcm::pallet_xcm::execute", "message {:?}, max_weight {:?}", message, max_weight);
- let outcome = >::execute(origin, message, max_weight)?;
- let weight_used = outcome.weight_used();
- outcome.ensure_complete().map_err(|error| {
- log::error!(target: "xcm::pallet_xcm::execute", "XCM execution failed with error {:?}", error);
- Error::::LocalExecutionIncomplete
- })?;
+ let weight_used =
+ >::execute(origin, message, max_weight)?;
Ok(Some(weight_used.saturating_add(T::WeightInfo::execute())).into())
}
diff --git a/polkadot/xcm/pallet-xcm/src/tests/mod.rs b/polkadot/xcm/pallet-xcm/src/tests/mod.rs
index e5ac80c3a1427..28c7d197443b0 100644
--- a/polkadot/xcm/pallet-xcm/src/tests/mod.rs
+++ b/polkadot/xcm/pallet-xcm/src/tests/mod.rs
@@ -20,11 +20,12 @@ pub(crate) mod assets_transfer;
use crate::{
mock::*, pallet::SupportedVersion, AssetTraps, Config, CurrentMigration, Error,
- LatestVersionedLocation, Pallet, Queries, QueryStatus, VersionDiscoveryQueue,
- VersionMigrationStage, VersionNotifiers, VersionNotifyTargets, WeightInfo,
+ ExecuteControllerWeightInfo, LatestVersionedLocation, Pallet, Queries, QueryStatus,
+ VersionDiscoveryQueue, VersionMigrationStage, VersionNotifiers, VersionNotifyTargets,
+ WeightInfo,
};
use frame_support::{
- assert_noop, assert_ok,
+ assert_err_ignore_postinfo, assert_noop, assert_ok,
traits::{Currency, Hooks},
weights::Weight,
};
@@ -450,19 +451,19 @@ fn trapped_assets_can_be_claimed() {
assert_eq!(Balances::total_balance(&BOB), INITIAL_BALANCE + SEND_AMOUNT);
assert_eq!(AssetTraps::::iter().collect::>(), vec![]);
- let weight = BaseXcmWeight::get() * 3;
- assert_ok!(>::execute(
- RuntimeOrigin::signed(ALICE),
- Box::new(VersionedXcm::from(Xcm(vec![
- ClaimAsset { assets: (Here, SEND_AMOUNT).into(), ticket: Here.into() },
- buy_execution((Here, SEND_AMOUNT)),
- DepositAsset { assets: AllCounted(1).into(), beneficiary: dest },
- ]))),
- weight
- ));
- let outcome =
- Outcome::Incomplete { used: BaseXcmWeight::get(), error: XcmError::UnknownClaim };
- assert_eq!(last_event(), RuntimeEvent::XcmPallet(crate::Event::Attempted { outcome }));
+ // Can't claim twice.
+ assert_err_ignore_postinfo!(
+ XcmPallet::execute(
+ RuntimeOrigin::signed(ALICE),
+ Box::new(VersionedXcm::from(Xcm(vec![
+ ClaimAsset { assets: (Here, SEND_AMOUNT).into(), ticket: Here.into() },
+ buy_execution((Here, SEND_AMOUNT)),
+ DepositAsset { assets: AllCounted(1).into(), beneficiary: dest },
+ ]))),
+ weight
+ ),
+ Error::::LocalExecutionIncomplete
+ );
});
}
@@ -495,11 +496,14 @@ fn incomplete_execute_reverts_side_effects() {
// all effects are reverted and balances unchanged for either sender or receiver
assert_eq!(Balances::total_balance(&ALICE), INITIAL_BALANCE);
assert_eq!(Balances::total_balance(&BOB), INITIAL_BALANCE);
+
assert_eq!(
result,
Err(sp_runtime::DispatchErrorWithPostInfo {
post_info: frame_support::dispatch::PostDispatchInfo {
- actual_weight: None,
+ actual_weight: Some(
+ as ExecuteControllerWeightInfo>::execute() + weight
+ ),
pays_fee: frame_support::dispatch::Pays::Yes,
},
error: sp_runtime::DispatchError::Module(sp_runtime::ModuleError {
diff --git a/polkadot/xcm/xcm-builder/src/controller.rs b/polkadot/xcm/xcm-builder/src/controller.rs
index 8ead18b5bd7fb..ba2b1fb44b8ee 100644
--- a/polkadot/xcm/xcm-builder/src/controller.rs
+++ b/polkadot/xcm/xcm-builder/src/controller.rs
@@ -18,7 +18,10 @@
//! Controller traits defined in this module are high-level traits that will rely on other traits
//! from `xcm-executor` to perform their tasks.
-use frame_support::pallet_prelude::DispatchError;
+use frame_support::{
+ dispatch::{DispatchErrorWithPostInfo, WithPostDispatchInfo},
+ pallet_prelude::DispatchError,
+};
use sp_std::boxed::Box;
use xcm::prelude::*;
pub use xcm_executor::traits::QueryHandler;
@@ -52,7 +55,8 @@ pub trait ExecuteController {
/// Weight information for ExecuteController functions.
type WeightInfo: ExecuteControllerWeightInfo;
- /// Attempt to execute an XCM locally, and return the outcome.
+ /// Attempt to execute an XCM locally, returns Ok with the weight consumed if the execution
+ /// complete successfully, Err otherwise.
///
/// # Parameters
///
@@ -63,7 +67,7 @@ pub trait ExecuteController {
origin: Origin,
message: Box>,
max_weight: Weight,
- ) -> Result;
+ ) -> Result;
}
/// Weight functions needed for [`SendController`].
@@ -137,8 +141,9 @@ impl ExecuteController for () {
_origin: Origin,
_message: Box>,
_max_weight: Weight,
- ) -> Result {
- Ok(Outcome::Error { error: XcmError::Unimplemented })
+ ) -> Result {
+ Err(DispatchError::Other("ExecuteController::execute not implemented")
+ .with_weight(Weight::zero()))
}
}
diff --git a/substrate/frame/contracts/fixtures/contracts/xcm_execute.rs b/substrate/frame/contracts/fixtures/contracts/xcm_execute.rs
index 09d0b6cf97281..1d570ffead718 100644
--- a/substrate/frame/contracts/fixtures/contracts/xcm_execute.rs
+++ b/substrate/frame/contracts/fixtures/contracts/xcm_execute.rs
@@ -30,10 +30,11 @@ pub extern "C" fn deploy() {}
pub extern "C" fn call() {
input!(512, msg: [u8],);
- let mut outcome = [0u8; 512];
- let outcome = &mut &mut outcome[..];
-
#[allow(deprecated)]
- api::xcm_execute(msg, outcome).unwrap();
- api::return_value(uapi::ReturnFlags::empty(), outcome);
+ let err_code = match api::xcm_execute(msg) {
+ Ok(_) => 0u32,
+ Err(code) => code as u32,
+ };
+
+ api::return_value(uapi::ReturnFlags::empty(), &err_code.to_le_bytes());
}
diff --git a/substrate/frame/contracts/mock-network/src/lib.rs b/substrate/frame/contracts/mock-network/src/lib.rs
index eea9dde062c83..8a17a3f2fa781 100644
--- a/substrate/frame/contracts/mock-network/src/lib.rs
+++ b/substrate/frame/contracts/mock-network/src/lib.rs
@@ -26,7 +26,8 @@ use crate::primitives::{AccountId, UNITS};
use sp_runtime::BuildStorage;
use xcm::latest::prelude::*;
use xcm_executor::traits::ConvertLocation;
-use xcm_simulator::{decl_test_network, decl_test_parachain, decl_test_relay_chain, TestExt};
+pub use xcm_simulator::TestExt;
+use xcm_simulator::{decl_test_network, decl_test_parachain, decl_test_relay_chain};
// Accounts
pub const ADMIN: sp_runtime::AccountId32 = sp_runtime::AccountId32::new([0u8; 32]);
diff --git a/substrate/frame/contracts/mock-network/src/tests.rs b/substrate/frame/contracts/mock-network/src/tests.rs
index c25373bcbe3ae..d22221fe8ee05 100644
--- a/substrate/frame/contracts/mock-network/src/tests.rs
+++ b/substrate/frame/contracts/mock-network/src/tests.rs
@@ -21,7 +21,6 @@ use crate::{
primitives::{AccountId, CENTS},
relay_chain, MockNet, ParaA, ParachainBalances, Relay, ALICE, BOB, INITIAL_BALANCE,
};
-use assert_matches::assert_matches;
use codec::{Decode, Encode};
use frame_support::{
assert_err,
@@ -31,11 +30,18 @@ use frame_support::{
use pallet_balances::{BalanceLock, Reasons};
use pallet_contracts::{Code, CollectEvents, DebugInfo, Determinism};
use pallet_contracts_fixtures::compile_module;
+use pallet_contracts_uapi::ReturnErrorCode;
use xcm::{v4::prelude::*, VersionedLocation, VersionedXcm};
use xcm_simulator::TestExt;
type ParachainContracts = pallet_contracts::Pallet;
+macro_rules! assert_return_code {
+ ( $x:expr , $y:expr $(,)? ) => {{
+ assert_eq!(u32::from_le_bytes($x.data[..].try_into().unwrap()), $y as u32);
+ }};
+}
+
/// Instantiate the tests contract, and fund it with some balance and assets.
fn instantiate_test_contract(name: &str) -> AccountId {
let (wasm, _) = compile_module::(name).unwrap();
@@ -100,19 +106,57 @@ fn test_xcm_execute() {
DebugInfo::UnsafeDebug,
CollectEvents::UnsafeCollect,
Determinism::Enforced,
- )
- .result
- .unwrap();
+ );
- let mut data = &result.data[..];
- let outcome = Outcome::decode(&mut data).expect("Failed to decode xcm_execute Outcome");
- assert_matches!(outcome, Outcome::Complete { .. });
+ assert_eq!(result.gas_consumed, result.gas_required);
+ assert_return_code!(&result.result.unwrap(), ReturnErrorCode::Success);
// Check if the funds are subtracted from the account of Alice and added to the account of
// Bob.
let initial = INITIAL_BALANCE;
- assert_eq!(parachain::Assets::balance(0, contract_addr), initial);
assert_eq!(ParachainBalances::free_balance(BOB), initial + amount);
+ assert_eq!(ParachainBalances::free_balance(&contract_addr), initial - amount);
+ });
+}
+
+#[test]
+fn test_xcm_execute_incomplete() {
+ MockNet::reset();
+
+ let contract_addr = instantiate_test_contract("xcm_execute");
+ let amount = 10 * CENTS;
+
+ // Execute XCM instructions through the contract.
+ ParaA::execute_with(|| {
+ // The XCM used to transfer funds to Bob.
+ let message: Xcm<()> = Xcm(vec![
+ WithdrawAsset(vec![(Here, amount).into()].into()),
+ // This will fail as the contract does not have enough balance to complete both
+ // withdrawals.
+ WithdrawAsset(vec![(Here, INITIAL_BALANCE).into()].into()),
+ DepositAsset {
+ assets: All.into(),
+ beneficiary: AccountId32 { network: None, id: BOB.clone().into() }.into(),
+ },
+ ]);
+
+ let result = ParachainContracts::bare_call(
+ ALICE,
+ contract_addr.clone(),
+ 0,
+ Weight::MAX,
+ None,
+ VersionedXcm::V4(message).encode(),
+ DebugInfo::UnsafeDebug,
+ CollectEvents::UnsafeCollect,
+ Determinism::Enforced,
+ );
+
+ assert_eq!(result.gas_consumed, result.gas_required);
+ assert_return_code!(&result.result.unwrap(), ReturnErrorCode::XcmExecutionFailed);
+
+ assert_eq!(ParachainBalances::free_balance(BOB), INITIAL_BALANCE);
+ assert_eq!(ParachainBalances::free_balance(&contract_addr), INITIAL_BALANCE - amount);
});
}
@@ -182,17 +226,10 @@ fn test_xcm_execute_reentrant_call() {
DebugInfo::UnsafeDebug,
CollectEvents::UnsafeCollect,
Determinism::Enforced,
- )
- .result
- .unwrap();
-
- let mut data = &result.data[..];
- let outcome = Outcome::decode(&mut data).expect("Failed to decode xcm_execute Outcome");
- assert_matches!(
- outcome,
- Outcome::Incomplete { used: _, error: XcmError::ExpectationFalse }
);
+ assert_return_code!(&result.result.unwrap(), ReturnErrorCode::XcmExecutionFailed);
+
// Funds should not change hands as the XCM transact failed.
assert_eq!(ParachainBalances::free_balance(BOB), INITIAL_BALANCE);
});
diff --git a/substrate/frame/contracts/src/exec.rs b/substrate/frame/contracts/src/exec.rs
index 6f7131f3ea416..79220021efe48 100644
--- a/substrate/frame/contracts/src/exec.rs
+++ b/substrate/frame/contracts/src/exec.rs
@@ -287,6 +287,9 @@ pub trait Ext: sealing::Sealed {
/// Returns `true` if debug message recording is enabled. Otherwise `false` is returned.
fn append_debug_buffer(&mut self, msg: &str) -> bool;
+ /// Returns `true` if debug message recording is enabled. Otherwise `false` is returned.
+ fn debug_buffer_enabled(&self) -> bool;
+
/// Call some dispatchable and return the result.
fn call_runtime(&self, call: ::RuntimeCall) -> DispatchResultWithPostInfo;
@@ -1429,6 +1432,10 @@ where
self.top_frame_mut().nested_storage.charge(diff)
}
+ fn debug_buffer_enabled(&self) -> bool {
+ self.debug_message.is_some()
+ }
+
fn append_debug_buffer(&mut self, msg: &str) -> bool {
if let Some(buffer) = &mut self.debug_message {
buffer
diff --git a/substrate/frame/contracts/src/gas.rs b/substrate/frame/contracts/src/gas.rs
index 11292dc03f032..9271b615d0026 100644
--- a/substrate/frame/contracts/src/gas.rs
+++ b/substrate/frame/contracts/src/gas.rs
@@ -63,6 +63,11 @@ pub trait Token: Copy + Clone + TestAuxiliaries {
/// while calculating the amount. In this case it is ok to use saturating operations
/// since on overflow they will return `max_value` which should consume all gas.
fn weight(&self) -> Weight;
+
+ /// Returns true if this token is expected to influence the lowest gas limit.
+ fn influence_lowest_gas_limit(&self) -> bool {
+ true
+ }
}
/// A wrapper around a type-erased trait object of what used to be a `Token`.
@@ -160,7 +165,9 @@ impl GasMeter {
/// This is when a maximum a priori amount was charged and then should be partially
/// refunded to match the actual amount.
pub fn adjust_gas>(&mut self, charged_amount: ChargedAmount, token: Tok) {
- self.gas_left_lowest = self.gas_left_lowest();
+ if token.influence_lowest_gas_limit() {
+ self.gas_left_lowest = self.gas_left_lowest();
+ }
let adjustment = charged_amount.0.saturating_sub(token.weight());
self.gas_left = self.gas_left.saturating_add(adjustment).min(self.gas_limit);
}
diff --git a/substrate/frame/contracts/src/wasm/mod.rs b/substrate/frame/contracts/src/wasm/mod.rs
index d00ec2e47521b..1c7395ec3bfff 100644
--- a/substrate/frame/contracts/src/wasm/mod.rs
+++ b/substrate/frame/contracts/src/wasm/mod.rs
@@ -687,6 +687,10 @@ mod tests {
&mut self.gas_meter
}
fn charge_storage(&mut self, _diff: &crate::storage::meter::Diff) {}
+
+ fn debug_buffer_enabled(&self) -> bool {
+ true
+ }
fn append_debug_buffer(&mut self, msg: &str) -> bool {
self.debug_buffer.extend(msg.as_bytes());
true
diff --git a/substrate/frame/contracts/src/wasm/runtime.rs b/substrate/frame/contracts/src/wasm/runtime.rs
index 3af0d04a3ad13..74b19910c3719 100644
--- a/substrate/frame/contracts/src/wasm/runtime.rs
+++ b/substrate/frame/contracts/src/wasm/runtime.rs
@@ -21,7 +21,6 @@ use crate::{
exec::{ExecError, ExecResult, Ext, Key, TopicOf},
gas::{ChargedAmount, Token},
primitives::ExecReturnValue,
- schedule::HostFnWeights,
BalanceOf, CodeHash, Config, DebugBufferVec, Error, SENTINEL,
};
use codec::{Decode, DecodeLimit, Encode, MaxEncodedLen};
@@ -235,6 +234,8 @@ pub enum RuntimeCosts {
ChainExtension(Weight),
/// Weight charged for calling into the runtime.
CallRuntime(Weight),
+ /// Weight charged for calling xcm_execute.
+ CallXcmExecute(Weight),
/// Weight of calling `seal_set_code_hash`
SetCodeHash,
/// Weight of calling `ecdsa_to_eth_address`
@@ -251,10 +252,18 @@ pub enum RuntimeCosts {
RemoveDelegateDependency,
}
-impl RuntimeCosts {
- fn token(&self, s: &HostFnWeights) -> RuntimeToken {
+impl Token for RuntimeCosts {
+ fn influence_lowest_gas_limit(&self) -> bool {
+ match self {
+ &Self::CallXcmExecute(_) => false,
+ _ => true,
+ }
+ }
+
+ fn weight(&self) -> Weight {
+ let s = T::Schedule::get().host_fn_weights;
use self::RuntimeCosts::*;
- let weight = match *self {
+ match *self {
CopyFromContract(len) => s.return_per_byte.saturating_mul(len.into()),
CopyToContract(len) => s.input_per_byte.saturating_mul(len.into()),
Caller => s.caller,
@@ -323,8 +332,7 @@ impl RuntimeCosts {
Sr25519Verify(len) => s
.sr25519_verify
.saturating_add(s.sr25519_verify_per_byte.saturating_mul(len.into())),
- ChainExtension(weight) => weight,
- CallRuntime(weight) => weight,
+ ChainExtension(weight) | CallRuntime(weight) | CallXcmExecute(weight) => weight,
SetCodeHash => s.set_code_hash,
EcdsaToEthAddress => s.ecdsa_to_eth_address,
ReentrantCount => s.reentrance_count,
@@ -332,11 +340,6 @@ impl RuntimeCosts {
InstantationNonce => s.instantiation_nonce,
AddDelegateDependency => s.add_delegate_dependency,
RemoveDelegateDependency => s.remove_delegate_dependency,
- };
- RuntimeToken {
- #[cfg(test)]
- _created_from: *self,
- weight,
}
}
}
@@ -347,25 +350,10 @@ impl RuntimeCosts {
/// a function won't work out.
macro_rules! charge_gas {
($runtime:expr, $costs:expr) => {{
- let token = $costs.token(&$runtime.ext.schedule().host_fn_weights);
- $runtime.ext.gas_meter_mut().charge(token)
+ $runtime.ext.gas_meter_mut().charge($costs)
}};
}
-#[cfg_attr(test, derive(Debug, PartialEq, Eq))]
-#[derive(Copy, Clone)]
-struct RuntimeToken {
- #[cfg(test)]
- _created_from: RuntimeCosts,
- weight: Weight,
-}
-
-impl Token for RuntimeToken {
- fn weight(&self) -> Weight {
- self.weight
- }
-}
-
/// The kind of call that should be performed.
enum CallType {
/// Execute another instantiated contract
@@ -506,28 +494,25 @@ impl<'a, E: Ext + 'a> Runtime<'a, E> {
/// This is when a maximum a priori amount was charged and then should be partially
/// refunded to match the actual amount.
pub fn adjust_gas(&mut self, charged: ChargedAmount, actual_costs: RuntimeCosts) {
- let token = actual_costs.token(&self.ext.schedule().host_fn_weights);
- self.ext.gas_meter_mut().adjust_gas(charged, token);
+ self.ext.gas_meter_mut().adjust_gas(charged, actual_costs);
}
/// Charge, Run and adjust gas, for executing the given dispatchable.
- fn call_dispatchable<
- ErrorReturnCode: Get,
- F: FnOnce(&mut Self) -> DispatchResultWithPostInfo,
- >(
+ fn call_dispatchable>(
&mut self,
dispatch_info: DispatchInfo,
- run: F,
+ runtime_cost: impl Fn(Weight) -> RuntimeCosts,
+ run: impl FnOnce(&mut Self) -> DispatchResultWithPostInfo,
) -> Result {
use frame_support::dispatch::extract_actual_weight;
- let charged = self.charge_gas(RuntimeCosts::CallRuntime(dispatch_info.weight))?;
+ let charged = self.charge_gas(runtime_cost(dispatch_info.weight))?;
let result = run(self);
let actual_weight = extract_actual_weight(&result, &dispatch_info);
- self.adjust_gas(charged, RuntimeCosts::CallRuntime(actual_weight));
+ self.adjust_gas(charged, runtime_cost(actual_weight));
match result {
Ok(_) => Ok(ReturnErrorCode::Success),
Err(e) => {
- if self.ext.append_debug_buffer("") {
+ if self.ext.debug_buffer_enabled() {
self.ext.append_debug_buffer("call failed with: ");
self.ext.append_debug_buffer(e.into());
};
@@ -2113,9 +2098,11 @@ pub mod env {
ctx.charge_gas(RuntimeCosts::CopyFromContract(call_len))?;
let call: ::RuntimeCall =
ctx.read_sandbox_memory_as_unbounded(memory, call_ptr, call_len)?;
- ctx.call_dispatchable::(call.get_dispatch_info(), |ctx| {
- ctx.ext.call_runtime(call)
- })
+ ctx.call_dispatchable::(
+ call.get_dispatch_info(),
+ RuntimeCosts::CallRuntime,
+ |ctx| ctx.ext.call_runtime(call),
+ )
}
/// Execute an XCM program locally, using the contract's address as the origin.
@@ -2126,7 +2113,6 @@ pub mod env {
memory: _,
msg_ptr: u32,
msg_len: u32,
- output_ptr: u32,
) -> Result {
use frame_support::dispatch::DispatchInfo;
use xcm::VersionedXcm;
@@ -2135,26 +2121,27 @@ pub mod env {
ctx.charge_gas(RuntimeCosts::CopyFromContract(msg_len))?;
let message: VersionedXcm> =
ctx.read_sandbox_memory_as_unbounded(memory, msg_ptr, msg_len)?;
+ ensure_executable::(&message)?;
let execute_weight =
<::Xcm as ExecuteController<_, _>>::WeightInfo::execute();
let weight = ctx.ext.gas_meter().gas_left().max(execute_weight);
let dispatch_info = DispatchInfo { weight, ..Default::default() };
- ensure_executable::(&message)?;
- ctx.call_dispatchable::(dispatch_info, |ctx| {
- let origin = crate::RawOrigin::Signed(ctx.ext.address().clone()).into();
- let outcome = <::Xcm>::execute(
- origin,
- Box::new(message),
- weight.saturating_sub(execute_weight),
- )?;
+ ctx.call_dispatchable::(
+ dispatch_info,
+ RuntimeCosts::CallXcmExecute,
+ |ctx| {
+ let origin = crate::RawOrigin::Signed(ctx.ext.address().clone()).into();
+ let weight_used = <::Xcm>::execute(
+ origin,
+ Box::new(message),
+ weight.saturating_sub(execute_weight),
+ )?;
- ctx.write_sandbox_memory(memory, output_ptr, &outcome.encode())?;
- let pre_dispatch_weight =
- <::Xcm as ExecuteController<_, _>>::WeightInfo::execute();
- Ok(Some(outcome.weight_used().saturating_add(pre_dispatch_weight)).into())
- })
+ Ok(Some(weight_used.saturating_add(execute_weight)).into())
+ },
+ )
}
/// Send an XCM program from the contract to the specified destination.
diff --git a/substrate/frame/contracts/uapi/src/host.rs b/substrate/frame/contracts/uapi/src/host.rs
index c8b9ae8b2def9..7894dc3a210ae 100644
--- a/substrate/frame/contracts/uapi/src/host.rs
+++ b/substrate/frame/contracts/uapi/src/host.rs
@@ -792,7 +792,7 @@ pub trait HostFn {
#[deprecated(
note = "Unstable function. Behaviour can change without further notice. Use only for testing."
)]
- fn xcm_execute(msg: &[u8], output: &mut &mut [u8]) -> Result;
+ fn xcm_execute(msg: &[u8]) -> Result;
/// Send an XCM program from the contract to the specified destination.
/// This is equivalent to dispatching `pallet_xcm::send` through `call_runtime`, except that
@@ -804,7 +804,6 @@ pub trait HostFn {
/// traps otherwise.
/// - `msg`: The message, should be decodable as a [VersionedXcm](https://paritytech.github.io/polkadot-sdk/master/staging_xcm/enum.VersionedXcm.html),
/// traps otherwise.
- /// - `output`: A reference to the output data buffer to write the [XcmHash](https://paritytech.github.io/polkadot-sdk/master/staging_xcm/v3/type.XcmHash.html)
///
/// # Return
///
diff --git a/substrate/frame/contracts/uapi/src/host/riscv32.rs b/substrate/frame/contracts/uapi/src/host/riscv32.rs
index b1934cc469e4b..dc1c48308df81 100644
--- a/substrate/frame/contracts/uapi/src/host/riscv32.rs
+++ b/substrate/frame/contracts/uapi/src/host/riscv32.rs
@@ -297,7 +297,7 @@ impl HostFn for HostFnImpl {
todo!()
}
- fn xcm_execute(msg: &[u8], output: &mut &mut [u8]) -> Result {
+ fn xcm_execute(msg: &[u8]) -> Result {
todo!()
}
diff --git a/substrate/frame/contracts/uapi/src/host/wasm32.rs b/substrate/frame/contracts/uapi/src/host/wasm32.rs
index 77cf22891e2f5..3df3abeb7dcdc 100644
--- a/substrate/frame/contracts/uapi/src/host/wasm32.rs
+++ b/substrate/frame/contracts/uapi/src/host/wasm32.rs
@@ -160,7 +160,7 @@ mod sys {
pub fn weight_to_fee(gas: u64, output_ptr: *mut u8, output_len_ptr: *mut u32);
- pub fn xcm_execute(msg_ptr: *const u8, msg_len: u32, output_ptr: *mut u8) -> ReturnCode;
+ pub fn xcm_execute(msg_ptr: *const u8, msg_len: u32) -> ReturnCode;
pub fn xcm_send(
dest_ptr: *const u8,
@@ -819,9 +819,8 @@ impl HostFn for HostFnImpl {
unsafe { sys::reentrance_count() }
}
- fn xcm_execute(msg: &[u8], output: &mut &mut [u8]) -> Result {
- let ret_code =
- unsafe { sys::xcm_execute(msg.as_ptr(), msg.len() as _, output.as_mut_ptr()) };
+ fn xcm_execute(msg: &[u8]) -> Result {
+ let ret_code = unsafe { sys::xcm_execute(msg.as_ptr(), msg.len() as _) };
ret_code.into()
}
From 5f8b6f38a3406b5ca901b8972860c78300313659 Mon Sep 17 00:00:00 2001
From: girazoki
Date: Tue, 20 Feb 2024 15:28:05 +0100
Subject: [PATCH 09/10] implement ConversionToAssetBalance in asset-rate
(#2903)
Implements the `ConversionToAssetBalance` trait to asset-rate by doing
`1/rate*(balance)`.
---
prdoc/pr_2903.prdoc | 15 +++++++++++
substrate/frame/asset-rate/src/lib.rs | 34 +++++++++++++++++++++++--
substrate/frame/asset-rate/src/tests.rs | 29 +++++++++++++++++++--
3 files changed, 74 insertions(+), 4 deletions(-)
create mode 100644 prdoc/pr_2903.prdoc
diff --git a/prdoc/pr_2903.prdoc b/prdoc/pr_2903.prdoc
new file mode 100644
index 0000000000000..dd22fa0eea375
--- /dev/null
+++ b/prdoc/pr_2903.prdoc
@@ -0,0 +1,15 @@
+# Schema: Polkadot SDK PRDoc Schema (prdoc) v1.0.0
+# See doc at https://raw.githubusercontent.com/paritytech/polkadot-sdk/master/prdoc/schema_user.json
+
+title: "Implement `ConversionToAssetBalance` in asset-rate"
+
+doc:
+ - audience: Runtime Dev
+ description: |
+ Implements the `ConversionToAssetBalance` trait to the asset-rate pallet.
+
+ Previously only the `ConversionFromAssetBalance` trait was implemented, which would allow to convert an asset balance into the corresponding native balance.
+
+ The `ConversionToAssetBalance` allows to use pallet-asset-rate, e.g., as a mechanism to charge XCM fees in an asset that is not the native.
+crates: [ ]
+
diff --git a/substrate/frame/asset-rate/src/lib.rs b/substrate/frame/asset-rate/src/lib.rs
index d4afca8b73c4b..befabfe54aa0e 100644
--- a/substrate/frame/asset-rate/src/lib.rs
+++ b/substrate/frame/asset-rate/src/lib.rs
@@ -59,8 +59,14 @@
#![cfg_attr(not(feature = "std"), no_std)]
-use frame_support::traits::{fungible::Inspect, tokens::ConversionFromAssetBalance};
-use sp_runtime::{traits::Zero, FixedPointNumber, FixedU128};
+use frame_support::traits::{
+ fungible::Inspect,
+ tokens::{ConversionFromAssetBalance, ConversionToAssetBalance},
+};
+use sp_runtime::{
+ traits::{CheckedDiv, Zero},
+ FixedPointNumber, FixedU128,
+};
use sp_std::boxed::Box;
pub use pallet::*;
@@ -144,6 +150,8 @@ pub mod pallet {
UnknownAssetKind,
/// The given asset ID already has an assigned conversion rate and cannot be re-created.
AlreadyExists,
+ /// Overflow ocurred when calculating the inverse rate.
+ Overflow,
}
#[pallet::call]
@@ -246,3 +254,25 @@ where
pallet::ConversionRateToNative::::set(asset_id.clone(), Some(1.into()));
}
}
+
+/// Exposes conversion of a native balance to an asset balance.
+impl ConversionToAssetBalance, AssetKindOf, BalanceOf> for Pallet
+where
+ T: Config,
+{
+ type Error = pallet::Error