mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 19:17:58 +00:00
8ba7a6aba8
This PR prepares chains specs for _native-runtime-free_ world. This PR has following changes: - `substrate`: - adds support for: - JSON based `GenesisConfig` to `ChainSpec` allowing interaction with runtime `GenesisBuilder` API. - interacting with arbitrary runtime wasm blob to[ `chain-spec-builder`](https://github.com/paritytech/substrate/blob/3ef576eaeb3f42610e85daecc464961cf1295570/bin/utils/chain-spec-builder/src/lib.rs#L46) command line util, - removes [`code`](https://github.com/paritytech/substrate/blob/3ef576eaeb3f42610e85daecc464961cf1295570/frame/system/src/lib.rs#L660) from `system_pallet` - adds `code` to the `ChainSpec` - deprecates [`ChainSpec::from_genesis`](https://github.com/paritytech/substrate/blob/3ef576eaeb3f42610e85daecc464961cf1295570/client/chain-spec/src/chain_spec.rs#L263), but also changes the signature of this method extending it with `code` argument. [`ChainSpec::builder()`](https://github.com/paritytech/substrate/blob/20bee680ed098be7239cf7a6b804cd4de267983e/client/chain-spec/src/chain_spec.rs#L507) should be used instead. - `polkadot`: - all references to `RuntimeGenesisConfig` in `node/service` are removed, - all `(kusama|polkadot|versi|rococo|wococo)_(staging|dev)_genesis_config` functions now return the JSON patch for default runtime `GenesisConfig`, - `ChainSpecBuilder` is used, `ChainSpec::from_genesis` is removed, - `cumulus`: - `ChainSpecBuilder` is used, `ChainSpec::from_genesis` is removed, - _JSON_ patch configuration used instead of `RuntimeGenesisConfig struct` in all chain specs. --------- Co-authored-by: command-bot <> Co-authored-by: Javier Viola <javier@parity.io> Co-authored-by: Davide Galassi <davxy@datawok.net> Co-authored-by: Francisco Aguirre <franciscoaguirreperez@gmail.com> Co-authored-by: Kevin Krone <kevin@parity.io> Co-authored-by: Bastian Köcher <git@kchr.de>
133 lines
3.9 KiB
Rust
133 lines
3.9 KiB
Rust
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// This file is part of Polkadot.
|
|
|
|
// Polkadot is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Polkadot is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Polkadot. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! A Polkadot test client.
|
|
//!
|
|
//! This test client is using the Polkadot test runtime.
|
|
|
|
mod block_builder;
|
|
|
|
use polkadot_primitives::Block;
|
|
use sp_runtime::BuildStorage;
|
|
use std::sync::Arc;
|
|
|
|
pub use block_builder::*;
|
|
pub use polkadot_test_runtime as runtime;
|
|
pub use polkadot_test_service::{
|
|
construct_extrinsic, construct_transfer_extrinsic, Client, FullBackend,
|
|
};
|
|
pub use substrate_test_client::*;
|
|
|
|
/// Test client executor.
|
|
pub type Executor = client::LocalCallExecutor<
|
|
Block,
|
|
FullBackend,
|
|
WasmExecutor<(sp_io::SubstrateHostFunctions, frame_benchmarking::benchmarking::HostFunctions)>,
|
|
>;
|
|
|
|
/// Test client builder for Polkadot.
|
|
pub type TestClientBuilder =
|
|
substrate_test_client::TestClientBuilder<Block, Executor, FullBackend, GenesisParameters>;
|
|
|
|
/// `LongestChain` type for the test runtime/client.
|
|
pub type LongestChain = sc_consensus::LongestChain<FullBackend, Block>;
|
|
|
|
/// Parameters of test-client builder with test-runtime.
|
|
#[derive(Default)]
|
|
pub struct GenesisParameters;
|
|
|
|
impl substrate_test_client::GenesisInit for GenesisParameters {
|
|
fn genesis_storage(&self) -> Storage {
|
|
polkadot_test_service::chain_spec::polkadot_local_testnet_config()
|
|
.build_storage()
|
|
.expect("Builds test runtime genesis storage")
|
|
}
|
|
}
|
|
|
|
/// A `test-runtime` extensions to `TestClientBuilder`.
|
|
pub trait TestClientBuilderExt: Sized {
|
|
/// Build the test client.
|
|
fn build(self) -> Client {
|
|
self.build_with_longest_chain().0
|
|
}
|
|
|
|
/// Build the test client and longest chain selector.
|
|
fn build_with_longest_chain(self) -> (Client, LongestChain);
|
|
}
|
|
|
|
impl TestClientBuilderExt for TestClientBuilder {
|
|
fn build_with_longest_chain(self) -> (Client, LongestChain) {
|
|
let executor = WasmExecutor::builder().build();
|
|
let executor = client::LocalCallExecutor::new(
|
|
self.backend().clone(),
|
|
executor.clone(),
|
|
Default::default(),
|
|
ExecutionExtensions::new(Default::default(), Arc::new(executor)),
|
|
)
|
|
.unwrap();
|
|
|
|
self.build_with_executor(executor)
|
|
}
|
|
}
|
|
|
|
/// A `TestClientBuilder` with default backend and executor.
|
|
pub trait DefaultTestClientBuilderExt: Sized {
|
|
/// Create new `TestClientBuilder`
|
|
fn new() -> Self;
|
|
}
|
|
|
|
impl DefaultTestClientBuilderExt for TestClientBuilder {
|
|
fn new() -> Self {
|
|
Self::with_default_backend()
|
|
}
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use super::*;
|
|
use sp_consensus::BlockOrigin;
|
|
|
|
#[test]
|
|
fn ensure_test_client_can_build_and_import_block() {
|
|
let mut client = TestClientBuilder::new().build();
|
|
|
|
let block_builder = client.init_polkadot_block_builder();
|
|
let block = block_builder.build().expect("Finalizes the block").block;
|
|
|
|
futures::executor::block_on(client.import(BlockOrigin::Own, block))
|
|
.expect("Imports the block");
|
|
}
|
|
|
|
#[test]
|
|
fn ensure_test_client_can_push_extrinsic() {
|
|
let mut client = TestClientBuilder::new().build();
|
|
|
|
let transfer = construct_transfer_extrinsic(
|
|
&client,
|
|
sp_keyring::Sr25519Keyring::Alice,
|
|
sp_keyring::Sr25519Keyring::Bob,
|
|
1000,
|
|
);
|
|
let mut block_builder = client.init_polkadot_block_builder();
|
|
block_builder.push_polkadot_extrinsic(transfer).expect("Pushes extrinsic");
|
|
|
|
let block = block_builder.build().expect("Finalizes the block").block;
|
|
|
|
futures::executor::block_on(client.import(BlockOrigin::Own, block))
|
|
.expect("Imports the block");
|
|
}
|
|
}
|