mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-09 20:11:09 +00:00
Added new empty shell runtime for BridgeHubPolkadot (without bridging stuff) for onboarding parachain on Polkadot (#2137)
* Added new empty shell runtime for `BridgeHubPolkadot` (without bridging stuff) for onboarding parachain on Polkadot * Fix benchmarks/try-runtime * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs frame_system * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs pallet_balances * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs pallet_multisig * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs pallet_xcm * Fixes * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs pallet_session * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs pallet_utility * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs pallet_timestamp * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs pallet_collator_selection * ".git/.scripts/commands/bench/bench.sh" pallet bridge-hub-polkadot bridge-hubs cumulus_pallet_xcmp_queue * PR fixes * Rebase fix * Fix new runtime api * ".git/.scripts/commands/bench/bench.sh" xcm bridge-hub-polkadot bridge-hubs pallet_xcm_benchmarks::fungible * ".git/.scripts/commands/bench/bench.sh" xcm bridge-hub-polkadot bridge-hubs pallet_xcm_benchmarks::generic * Updated aura/bootNodes in `create_bridge_hub_polkadot_spec.sh` --------- Co-authored-by: command-bot <>
This commit is contained in:
@@ -39,7 +39,20 @@ elif [[ $runtimeName == "collectives-polkadot" ]]; then
|
||||
cumulus_pallet_xcmp_queue
|
||||
frame_system
|
||||
)
|
||||
elif [[ $runtimeName == "bridge-hub-rococo" ]] || [[ $runtimeName == "bridge-hub-kusama" ]]; then
|
||||
elif [[ $runtimeName == "bridge-hub-kusama" ]] || [[ $runtimeName == "bridge-hub-polkadot" ]]; then
|
||||
pallets=(
|
||||
frame_system
|
||||
pallet_balances
|
||||
pallet_collator_selection
|
||||
pallet_multisig
|
||||
pallet_session
|
||||
pallet_timestamp
|
||||
pallet_utility
|
||||
cumulus_pallet_xcmp_queue
|
||||
pallet_xcm_benchmarks::generic
|
||||
pallet_xcm_benchmarks::fungible
|
||||
)
|
||||
elif [[ $runtimeName == "bridge-hub-rococo" ]]; then
|
||||
pallets=(
|
||||
frame_system
|
||||
pallet_balances
|
||||
|
||||
@@ -8,5 +8,6 @@ ${__dir}/benchmarks-ci.sh assets statemine target/production
|
||||
${__dir}/benchmarks-ci.sh assets statemint target/production
|
||||
${__dir}/benchmarks-ci.sh assets westmint target/production
|
||||
|
||||
${__dir}/benchmarks-ci.sh bridge-hubs bridge-hub-polkadot target/production
|
||||
${__dir}/benchmarks-ci.sh bridge-hubs bridge-hub-kusama target/production
|
||||
${__dir}/benchmarks-ci.sh bridge-hubs bridge-hub-rococo target/production
|
||||
|
||||
@@ -83,6 +83,7 @@ STATEMINE_DIGEST = ENV['STATEMINE_DIGEST'] || 'digests/statemine-srtool-digest.j
|
||||
STATEMINT_DIGEST = ENV['STATEMINT_DIGEST'] || 'digests/statemint-srtool-digest.json'
|
||||
BRIDGE_HUB_ROCOCO_DIGEST = ENV['BRIDGE_HUB_ROCOCO_DIGEST'] || 'digests/bridge-hub-rococo-srtool-digest.json'
|
||||
BRIDGE_HUB_KUSAMA_DIGEST = ENV['BRIDGE_HUB_KUSAMA_DIGEST'] || 'digests/bridge-hub-kusama-srtool-digest.json'
|
||||
BRIDGE_HUB_POLKADOT_DIGEST = ENV['BRIDGE_HUB_POLKADOT_DIGEST'] || 'digests/bridge-hub-polkadot-srtool-digest.json'
|
||||
ROCOCO_PARA_DIGEST = ENV['ROCOCO_PARA_DIGEST'] || 'digests/rococo-parachain-srtool-digest.json'
|
||||
CANVAS_KUSAMA_DIGEST = ENV['CANVAS_KUSAMA_DIGEST'] || 'digests/contracts-rococo-srtool-digest.json'
|
||||
|
||||
@@ -131,7 +132,8 @@ else
|
||||
{ name: "contracts", data: $srtool_contracts_rococo[0] },
|
||||
{ name: "polkadot-collectives", data: $srtool_polkadot_collectives[0] },
|
||||
{ name: "bridge-hub-rococo", data: $srtool_bridge_hub_rococo[0] },
|
||||
{ name: "bridge-hub-kusama", data: $srtool_bridge_hub_kusama[0] }
|
||||
{ name: "bridge-hub-kusama", data: $srtool_bridge_hub_kusama[0] },
|
||||
{ name: "bridge-hub-polkadot", data: $srtool_bridge_hub_polkadot[0] }
|
||||
] }\' > context.json',
|
||||
cumulus_data,
|
||||
substrate_data,
|
||||
@@ -144,7 +146,8 @@ else
|
||||
CANVAS_KUSAMA_DIGEST,
|
||||
POLKADOT_COLLECTIVES_DIGEST,
|
||||
BRIDGE_HUB_ROCOCO_DIGEST,
|
||||
BRIDGE_HUB_KUSAMA_DIGEST
|
||||
BRIDGE_HUB_KUSAMA_DIGEST,
|
||||
BRIDGE_HUB_POLKADOT_DIGEST
|
||||
)
|
||||
end
|
||||
system(cmd)
|
||||
|
||||
@@ -70,6 +70,7 @@ benchmarks-bridge-hubs:
|
||||
before_script:
|
||||
- !reference [.docker-env, before_script]
|
||||
script:
|
||||
- ./scripts/benchmarks-ci.sh bridge-hubs bridge-hub-polkadot ./artifacts
|
||||
- ./scripts/benchmarks-ci.sh bridge-hubs bridge-hub-kusama ./artifacts
|
||||
- ./scripts/benchmarks-ci.sh bridge-hubs bridge-hub-rococo ./artifacts
|
||||
- export CURRENT_TIME=$(date '+%s')
|
||||
|
||||
Executable
+111
@@ -0,0 +1,111 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
usage() {
|
||||
echo Usage:
|
||||
echo "$1 <srtool compressed runtime path>"
|
||||
echo "$2 <para_id>"
|
||||
echo "e.g.: ./scripts/create_bridge_hub_polkadot_spec.sh ./target/release/wbuild/bridge-hub-polkadot-runtime/bridge_hub_polkadot_runtime.compact.compressed.wasm 1002"
|
||||
exit 1
|
||||
}
|
||||
|
||||
if [ -z "$1" ]; then
|
||||
usage
|
||||
fi
|
||||
|
||||
if [ -z "$2" ]; then
|
||||
usage
|
||||
fi
|
||||
|
||||
set -e
|
||||
|
||||
rt_path=$1
|
||||
para_id=$2
|
||||
|
||||
echo "Generating chain spec for runtime: $rt_path and para_id: $para_id"
|
||||
|
||||
binary="./target/release/polkadot-parachain"
|
||||
|
||||
# build the chain spec we'll manipulate
|
||||
$binary build-spec --chain bridge-hub-polkadot-dev > chain-spec-plain.json
|
||||
|
||||
# convert runtime to hex
|
||||
cat $rt_path | od -A n -v -t x1 | tr -d ' \n' > rt-hex.txt
|
||||
|
||||
# replace the runtime in the spec with the given runtime and set some values to production
|
||||
# TODO: missing .bootNodes
|
||||
# TODO: missing .genesis.runtime.collatorSelection.invulnerables
|
||||
# TODO: missing .genesis.runtime.session.keys
|
||||
cat chain-spec-plain.json | jq --rawfile code rt-hex.txt '.genesis.runtime.system.code = ("0x" + $code)' \
|
||||
| jq '.name = "Polkadot BridgeHub"' \
|
||||
| jq '.id = "bridge-hub-polkadot"' \
|
||||
| jq '.chainType = "Live"' \
|
||||
| jq '.bootNodes = [
|
||||
"/dns/polkadot-bridge-hub-connect-a-0.polkadot.io/tcp/30334/p2p/12D3KooWAVQMhkXmc5ueSYasdsRWQbKus2YGZ6HDZUB4ViJMCxXy",
|
||||
"/dns/polkadot-bridge-hub-connect-a-1.polkadot.io/tcp/30334/p2p/12D3KooWG4ypDHLKGCv4BZ6PuaGUwQHKAH6p2D6arR2uQ1eiR1T3",
|
||||
"/dns/polkadot-bridge-hub-connect-b-0.polkadot.io/tcp/30334/p2p/12D3KooWCwGKxjpJXnx1mwXKvaxGQm769EM3b6Pg5vbU33wbhsNw",
|
||||
"/dns/polkadot-bridge-hub-connect-b-1.polkadot.io/tcp/30334/p2p/12D3KooWLiSEdhriJUPdZKFtAjZrQncxN2ssEoDKVrt5mGM4Qu4J",
|
||||
|
||||
"/dns/polkadot-bridge-hub-connect-a-0.polkadot.io/tcp/443/wss/p2p/12D3KooWAVQMhkXmc5ueSYasdsRWQbKus2YGZ6HDZUB4ViJMCxXy",
|
||||
"/dns/polkadot-bridge-hub-connect-a-1.polkadot.io/tcp/443/wss/p2p/12D3KooWG4ypDHLKGCv4BZ6PuaGUwQHKAH6p2D6arR2uQ1eiR1T3",
|
||||
"/dns/polkadot-bridge-hub-connect-b-0.polkadot.io/tcp/443/wss/p2p/12D3KooWCwGKxjpJXnx1mwXKvaxGQm769EM3b6Pg5vbU33wbhsNw",
|
||||
"/dns/polkadot-bridge-hub-connect-b-1.polkadot.io/tcp/443/wss/p2p/12D3KooWLiSEdhriJUPdZKFtAjZrQncxN2ssEoDKVrt5mGM4Qu4J"
|
||||
]' \
|
||||
| jq '.relay_chain = "polkadot"' \
|
||||
| jq --argjson para_id $para_id '.para_id = $para_id' \
|
||||
| jq --argjson para_id $para_id '.genesis.runtime.parachainInfo.parachainId = $para_id' \
|
||||
| jq '.genesis.runtime.balances.balances = []' \
|
||||
| jq '.genesis.runtime.collatorSelection.invulnerables = [
|
||||
"TODO:ACC1",
|
||||
"TODO:ACC2",
|
||||
"TODO:ACC3",
|
||||
"TODO:ACC4"
|
||||
]' \
|
||||
| jq '.genesis.runtime.session.keys = [
|
||||
[
|
||||
"TODO:ACC1",
|
||||
"TODO:ACC1",
|
||||
{
|
||||
"aura": "5EX6AnyuSPEFQ7HAPjRgzqk1sxgh8cyacGimwJ16y1nJ2w7g"
|
||||
}
|
||||
],
|
||||
[
|
||||
"TODO:ACC2",
|
||||
"TODO:ACC2",
|
||||
{
|
||||
"aura": "5DZN8UhaJftvKhMMARmJBwrwzuEDpoUzzBvvWMbFXYsJ4CmK"
|
||||
}
|
||||
],
|
||||
[
|
||||
"TODO:ACC3",
|
||||
"TODO:ACC3",
|
||||
{
|
||||
"aura": "5FKsn83rXQQiw7HwoeYoLMoYS5GP9YVNHZiCHwA4DSwDcPVa"
|
||||
}
|
||||
],
|
||||
[
|
||||
"TODO:ACC4",
|
||||
"TODO:ACC4",
|
||||
{
|
||||
"aura": "5DCg19ckcJz4m52Th4o1LcSRK3H7NsUcQsRbu7pTDM3mZ26v"
|
||||
}
|
||||
]
|
||||
]' \
|
||||
> edited-chain-spec-plain.json
|
||||
|
||||
# build a raw spec
|
||||
$binary build-spec --chain edited-chain-spec-plain.json --raw > chain-spec-raw.json
|
||||
cp edited-chain-spec-plain.json bridge-hub-polkadot-spec.json
|
||||
cp chain-spec-raw.json ./parachains/chain-specs/bridge-hub-polkadot.json
|
||||
cp chain-spec-raw.json bridge-hub-polkadot-spec-raw.json
|
||||
|
||||
# build genesis data
|
||||
$binary export-genesis-state --chain chain-spec-raw.json > bridge-hub-polkadot-genesis-head-data
|
||||
|
||||
# build genesis wasm
|
||||
$binary export-genesis-wasm --chain chain-spec-raw.json > bridge-hub-polkadot-wasm
|
||||
|
||||
# cleanup
|
||||
rm -f rt-hex.txt
|
||||
rm -f chain-spec-plain.json
|
||||
rm -f chain-spec-raw.json
|
||||
rm -f edited-chain-spec-plain.json
|
||||
Reference in New Issue
Block a user