mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-13 05:51:02 +00:00
Build LongestChain with TestClientBuilder (#2792)
* Switch to `TestClientBuilder` and support generating LongestChain * Make sure test-client works without the wasm blob * Use `TestClientBuilder` in more places
This commit is contained in:
@@ -104,22 +104,78 @@ pub type LightExecutor = client::light::call_executor::RemoteOrLocalCallExecutor
|
||||
>;
|
||||
|
||||
/// A builder for creating a test client instance.
|
||||
pub struct TestClientBuilder {
|
||||
pub struct TestClientBuilder<E, B> {
|
||||
execution_strategies: ExecutionStrategies,
|
||||
genesis_extension: HashMap<Vec<u8>, Vec<u8>>,
|
||||
support_changes_trie: bool,
|
||||
backend: Arc<B>,
|
||||
_phantom: std::marker::PhantomData<E>,
|
||||
}
|
||||
|
||||
impl TestClientBuilder {
|
||||
#[cfg(feature = "include-wasm-blob")]
|
||||
impl<B> TestClientBuilder<LocalExecutor, B> where
|
||||
B: backend::LocalBackend<runtime::Block, Blake2Hasher>,
|
||||
{
|
||||
/// Create a new instance of the test client builder using the given backend.
|
||||
pub fn new_with_backend(backend: Arc<B>) -> Self {
|
||||
TestClientBuilder {
|
||||
execution_strategies: ExecutionStrategies::default(),
|
||||
genesis_extension: HashMap::default(),
|
||||
support_changes_trie: false,
|
||||
backend,
|
||||
_phantom: Default::default(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(feature = "include-wasm-blob")]
|
||||
impl TestClientBuilder<LocalExecutor, Backend> {
|
||||
/// Create a new instance of the test client builder.
|
||||
pub fn new() -> Self {
|
||||
TestClientBuilder {
|
||||
execution_strategies: ExecutionStrategies::default(),
|
||||
genesis_extension: HashMap::default(),
|
||||
support_changes_trie: false,
|
||||
backend: Arc::new(Backend::new_test(std::u32::MAX, std::u64::MAX)),
|
||||
_phantom: Default::default(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(not(feature = "include-wasm-blob"))]
|
||||
impl<E, B> TestClientBuilder<E, B> where
|
||||
B: backend::LocalBackend<runtime::Block, Blake2Hasher>,
|
||||
{
|
||||
/// Create a new instance of the test client builder using the given backend.
|
||||
pub fn new_with_backend(backend: Arc<B>) -> Self {
|
||||
TestClientBuilder {
|
||||
execution_strategies: ExecutionStrategies::default(),
|
||||
genesis_extension: HashMap::default(),
|
||||
support_changes_trie: false,
|
||||
backend,
|
||||
_phantom: Default::default(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(not(feature = "include-wasm-blob"))]
|
||||
impl<E> TestClientBuilder<E, Backend> {
|
||||
/// Create a new instance of the test client builder.
|
||||
pub fn new() -> Self {
|
||||
TestClientBuilder {
|
||||
execution_strategies: ExecutionStrategies::default(),
|
||||
genesis_extension: HashMap::default(),
|
||||
support_changes_trie: false,
|
||||
backend: Arc::new(Backend::new_test(std::u32::MAX, std::u64::MAX)),
|
||||
_phantom: Default::default(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl<E, B> TestClientBuilder<E, B> where
|
||||
B: backend::LocalBackend<runtime::Block, Blake2Hasher>,
|
||||
E: executor::NativeExecutionDispatch
|
||||
{
|
||||
/// Set the execution strategy that should be used by all contexts.
|
||||
pub fn set_execution_strategy(
|
||||
mut self,
|
||||
@@ -151,60 +207,46 @@ impl TestClientBuilder {
|
||||
}
|
||||
|
||||
/// Build the test client.
|
||||
#[cfg(feature = "include-wasm-blob")]
|
||||
pub fn build(self) -> client::Client<
|
||||
Backend, Executor, runtime::Block, runtime::RuntimeApi
|
||||
> {
|
||||
let backend = Arc::new(Backend::new_test(std::u32::MAX, std::u64::MAX));
|
||||
self.build_with_backend(backend)
|
||||
}
|
||||
|
||||
/// Build the test client with the given backend.
|
||||
#[cfg(feature = "include-wasm-blob")]
|
||||
pub fn build_with_backend<B>(self, backend: Arc<B>) -> client::Client<
|
||||
B,
|
||||
client::LocalCallExecutor<B, executor::NativeExecutor<LocalExecutor>>,
|
||||
client::LocalCallExecutor<B, executor::NativeExecutor<E>>,
|
||||
runtime::Block,
|
||||
runtime::RuntimeApi
|
||||
> where B: backend::LocalBackend<runtime::Block, Blake2Hasher> {
|
||||
let executor = NativeExecutor::new(None);
|
||||
let executor = LocalCallExecutor::new(backend.clone(), executor);
|
||||
|
||||
client::Client::new(
|
||||
backend,
|
||||
executor,
|
||||
genesis_storage(self.support_changes_trie, self.genesis_extension),
|
||||
self.execution_strategies
|
||||
).expect("Creates new client")
|
||||
runtime::RuntimeApi,
|
||||
> {
|
||||
self.build_with_longest_chain().0
|
||||
}
|
||||
|
||||
/// Build the test client with the given native executor.
|
||||
pub fn build_with_native_executor<E>(
|
||||
self,
|
||||
executor: executor::NativeExecutor<E>
|
||||
) -> client::Client<
|
||||
Backend,
|
||||
client::LocalCallExecutor<Backend, executor::NativeExecutor<E>>,
|
||||
runtime::Block,
|
||||
runtime::RuntimeApi
|
||||
> where E: executor::NativeExecutionDispatch
|
||||
{
|
||||
let backend = Arc::new(Backend::new_test(std::u32::MAX, std::u64::MAX));
|
||||
let executor = LocalCallExecutor::new(backend.clone(), executor);
|
||||
/// Build the test client and longest chain as select chain.
|
||||
pub fn build_with_longest_chain(self) -> (
|
||||
client::Client<
|
||||
B,
|
||||
client::LocalCallExecutor<B, executor::NativeExecutor<E>>,
|
||||
runtime::Block,
|
||||
runtime::RuntimeApi,
|
||||
>,
|
||||
client::LongestChain<B, runtime::Block>,
|
||||
) {
|
||||
let executor = NativeExecutor::<E>::new(None);
|
||||
let executor = LocalCallExecutor::new(self.backend.clone(), executor);
|
||||
|
||||
client::Client::new(
|
||||
backend,
|
||||
let client = client::Client::new(
|
||||
self.backend.clone(),
|
||||
executor,
|
||||
genesis_storage(self.support_changes_trie, self.genesis_extension),
|
||||
self.execution_strategies
|
||||
).expect("Creates new client")
|
||||
self.execution_strategies,
|
||||
).expect("Creates new client");
|
||||
|
||||
#[allow(deprecated)]
|
||||
let longest_chain = client::LongestChain::new(self.backend, client.import_lock());
|
||||
|
||||
(client, longest_chain)
|
||||
}
|
||||
}
|
||||
|
||||
/// Creates new client instance used for tests.
|
||||
#[cfg(feature = "include-wasm-blob")]
|
||||
pub fn new() -> client::Client<Backend, Executor, runtime::Block, runtime::RuntimeApi> {
|
||||
new_with_backend(Arc::new(Backend::new_test(::std::u32::MAX, ::std::u64::MAX)), false)
|
||||
TestClientBuilder::new().build()
|
||||
}
|
||||
|
||||
/// Creates new light client instance used for tests.
|
||||
@@ -221,40 +263,6 @@ pub fn new_light() -> client::Client<LightBackend, LightExecutor, runtime::Block
|
||||
client::Client::new(backend, call_executor, genesis_storage(false, Default::default()), Default::default()).unwrap()
|
||||
}
|
||||
|
||||
/// Creates new client instance used for tests with the given api execution strategy.
|
||||
#[cfg(feature = "include-wasm-blob")]
|
||||
pub fn new_with_execution_strategy(
|
||||
execution_strategy: ExecutionStrategy
|
||||
) -> client::Client<Backend, Executor, runtime::Block, runtime::RuntimeApi> {
|
||||
TestClientBuilder::new().set_execution_strategy(execution_strategy).build()
|
||||
}
|
||||
|
||||
/// Creates new test client instance that suports changes trie creation.
|
||||
#[cfg(feature = "include-wasm-blob")]
|
||||
pub fn new_with_changes_trie()
|
||||
-> client::Client<Backend, Executor, runtime::Block, runtime::RuntimeApi>
|
||||
{
|
||||
TestClientBuilder::new().set_support_changes_trie(true).build()
|
||||
}
|
||||
|
||||
/// Creates new client instance used for tests with an explicitly provided backend.
|
||||
/// This is useful for testing backend implementations.
|
||||
#[cfg(feature = "include-wasm-blob")]
|
||||
pub fn new_with_backend<B>(
|
||||
backend: Arc<B>,
|
||||
support_changes_trie: bool
|
||||
) -> client::Client<
|
||||
B,
|
||||
client::LocalCallExecutor<B, executor::NativeExecutor<LocalExecutor>>,
|
||||
runtime::Block,
|
||||
runtime::RuntimeApi
|
||||
> where B: backend::LocalBackend<runtime::Block, Blake2Hasher>
|
||||
{
|
||||
TestClientBuilder::new()
|
||||
.set_support_changes_trie(support_changes_trie)
|
||||
.build_with_backend(backend)
|
||||
}
|
||||
|
||||
fn genesis_config(support_changes_trie: bool) -> GenesisConfig {
|
||||
GenesisConfig::new(support_changes_trie, vec![
|
||||
AuthorityKeyring::Alice.into(),
|
||||
|
||||
@@ -26,7 +26,7 @@ use crate::{TestClient, AccountKeyring};
|
||||
use runtime_primitives::traits::Block as BlockT;
|
||||
use crate::backend;
|
||||
use crate::blockchain::{Backend as BlockChainBackendT, HeaderBackend};
|
||||
use crate::{BlockBuilderExt, new_with_backend};
|
||||
use crate::{BlockBuilderExt, TestClientBuilder};
|
||||
use runtime::{self, Transfer};
|
||||
use runtime_primitives::generic::BlockId;
|
||||
|
||||
@@ -40,7 +40,7 @@ pub fn test_leaves_for_backend<B: 'static>(backend: Arc<B>) where
|
||||
// B2 -> C3
|
||||
// A1 -> D2
|
||||
|
||||
let client = new_with_backend(backend.clone(), false);
|
||||
let client = TestClientBuilder::new_with_backend(backend.clone()).build();
|
||||
let blockchain = backend.blockchain();
|
||||
|
||||
let genesis_hash = client.info().chain.genesis_hash;
|
||||
@@ -156,7 +156,7 @@ pub fn test_children_for_backend<B: 'static>(backend: Arc<B>) where
|
||||
// B2 -> C3
|
||||
// A1 -> D2
|
||||
|
||||
let client = new_with_backend(backend.clone(), false);
|
||||
let client = TestClientBuilder::new_with_backend(backend.clone()).build();
|
||||
let blockchain = backend.blockchain();
|
||||
|
||||
// G -> A1
|
||||
@@ -246,7 +246,7 @@ pub fn test_blockchain_query_by_number_gets_canonical<B: 'static>(backend: Arc<B
|
||||
// A1 -> B2 -> B3 -> B4
|
||||
// B2 -> C3
|
||||
// A1 -> D2
|
||||
let client = new_with_backend(backend.clone(), false);
|
||||
let client = TestClientBuilder::new_with_backend(backend.clone()).build();
|
||||
let blockchain = backend.blockchain();
|
||||
|
||||
// G -> A1
|
||||
|
||||
Reference in New Issue
Block a user