mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-26 21:41:08 +00:00
bad3ce4e17
* ensure imbalances are properly accounted for (#2183) * ensure imbalances are properly accounted for * bump runtime version * Update node/runtime/src/lib.rs * implement contract events (#2161) * implement contract events * update runtime * renaming * update test code hash * improve complexity details * add deposit event base cost * add test * Revert "add deposit event base cost" This reverts commit 58ec010c0f4f4f0e16935ad41da32aedd17a8c57. * update test * Revert "update test" This reverts commit 6fe61a593ccf0d41f09a0b97472b28ed8751a999. * Revert "Revert "add deposit event base cost"" This reverts commit 145e8a9bac15313a4c380aa66b94fd4d36fa3f6d. * Fix format a bit * Replace Vec<u8> with [u8; 32] for contract storage key (#2184) * Replace Vec<u8> with [u8; 32] for contract storage key * Read storage keys from sandbox memory into fixed size buffer * Increment `impl_version` * Remove redundant Ok(()) and explicitly specify StorageKey buffer type (#2188) * Switch to `derive(Encode, Decode)` for `Call` (#2178) * Add some tests * More tests * Switch to `derive(Encode, Decode)` for `Call` * Update lock files * Simplify the macro cases * Cache changes trie config in db storage (#2170) * cache changes trie config in db storage * Update core/client/db/src/lib.rs Co-Authored-By: svyatonik <svyatonik@gmail.com> * Update core/client/db/src/lib.rs Co-Authored-By: svyatonik <svyatonik@gmail.com> * Fix version check for renamed runtime api methods (#2190) * Add feature to disable including the test-runtime wasm blob * Enable `std` feature for `consensus_authorities` * Implement `skip_initialize_block` and `initialize_block` for runtime api * Add test and fixes bug * Begin to implement support for passing the `ProofRecorder` * Make sure proof generation works as intended * Fixes tests * Make `BlockBuilder` generate proofs on request. * Adds `TestClientBuilder` to simplify creating a test client * Add `include-wasm-blob` to `test-client` as well * Make `test-client` compile without including the wasm file * Disable more stuff in test-client without wasm * Reorganize the re-exports * Use correct bounds * Update docs * Update core/client/src/block_builder/block_builder.rs Co-Authored-By: bkchr <bkchr@users.noreply.github.com> * Extend test to actually generated proof * Switch to enum for `skip_initialize_block` * Some wasm files updates
110 lines
3.0 KiB
Rust
110 lines
3.0 KiB
Rust
// Copyright 2018-2019 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate 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.
|
|
|
|
// Substrate 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 Substrate. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Client extension for tests.
|
|
|
|
use client::{self, Client};
|
|
use consensus::{
|
|
ImportBlock, BlockImport, BlockOrigin, Error as ConsensusError,
|
|
ForkChoiceStrategy,
|
|
};
|
|
use runtime_primitives::Justification;
|
|
use runtime_primitives::generic::BlockId;
|
|
use primitives::Blake2Hasher;
|
|
use runtime;
|
|
use parity_codec::alloc::collections::hash_map::HashMap;
|
|
|
|
/// Extension trait for a test client.
|
|
pub trait TestClient: Sized {
|
|
/// Import block to the chain. No finality.
|
|
fn import(&self, origin: BlockOrigin, block: runtime::Block)
|
|
-> Result<(), ConsensusError>;
|
|
|
|
/// Import block with justification, finalizes block.
|
|
fn import_justified(
|
|
&self,
|
|
origin: BlockOrigin,
|
|
block: runtime::Block,
|
|
justification: Justification
|
|
) -> Result<(), ConsensusError>;
|
|
|
|
/// Finalize a block.
|
|
fn finalize_block(
|
|
&self,
|
|
id: BlockId<runtime::Block>,
|
|
justification: Option<Justification>,
|
|
) -> client::error::Result<()>;
|
|
|
|
/// Returns hash of the genesis block.
|
|
fn genesis_hash(&self) -> runtime::Hash;
|
|
}
|
|
|
|
impl<B, E, RA> TestClient for Client<B, E, runtime::Block, RA>
|
|
where
|
|
B: client::backend::Backend<runtime::Block, Blake2Hasher>,
|
|
E: client::CallExecutor<runtime::Block, Blake2Hasher>,
|
|
Self: BlockImport<runtime::Block, Error=ConsensusError>,
|
|
{
|
|
fn import(&self, origin: BlockOrigin, block: runtime::Block)
|
|
-> Result<(), ConsensusError>
|
|
{
|
|
let import = ImportBlock {
|
|
origin,
|
|
header: block.header,
|
|
justification: None,
|
|
post_digests: vec![],
|
|
body: Some(block.extrinsics),
|
|
finalized: false,
|
|
auxiliary: Vec::new(),
|
|
fork_choice: ForkChoiceStrategy::LongestChain,
|
|
};
|
|
|
|
self.import_block(import, HashMap::new()).map(|_| ())
|
|
}
|
|
|
|
fn import_justified(
|
|
&self,
|
|
origin: BlockOrigin,
|
|
block: runtime::Block,
|
|
justification: Justification,
|
|
) -> Result<(), ConsensusError> {
|
|
let import = ImportBlock {
|
|
origin,
|
|
header: block.header,
|
|
justification: Some(justification),
|
|
post_digests: vec![],
|
|
body: Some(block.extrinsics),
|
|
finalized: true,
|
|
auxiliary: Vec::new(),
|
|
fork_choice: ForkChoiceStrategy::LongestChain,
|
|
};
|
|
|
|
self.import_block(import, HashMap::new()).map(|_| ())
|
|
}
|
|
|
|
fn finalize_block(
|
|
&self,
|
|
id: BlockId<runtime::Block>,
|
|
justification: Option<Justification>,
|
|
) -> client::error::Result<()> {
|
|
self.finalize_block(id, justification, true)
|
|
}
|
|
|
|
fn genesis_hash(&self) -> runtime::Hash {
|
|
self.block_hash(0).unwrap().unwrap()
|
|
}
|
|
}
|