mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 10:27:59 +00:00
febf29390a
* DigestItem::ChangesTrieSignal * introduce changes_trie::State * introduce config activation block * ChangesTrieSignal::as_new_configuration * moved well_known_cache_keys to client * extracted DbChangesTrieStorage to separate file * change meaning of none in blockchain cache * changes trie config (FULL) cache draft * eliminating const ChangesTrieConfiguration * delay pruning * continue elimination * do not prune CT config from cache * removed redundant code * fix some TODOs * introduce ConfigurationRange * use Configuration range in build * build skewed digest * remove debug print * extracted surface iterator * key_changes works with skewed digests * fix client build * add test for NeverPrune * fix TODO * fixed some TODOs * more tests * fixing TODOs * fixed compilation * update runtime version * git rid of large tuple * too long lines * config_activation_block -> zero * obsolete TODO * removed unjustified expect * update TODOs with issue number * new CT pruning algorithm fixed cache + multiple blocks finalization track CT configuraiton on light clients support CT configuration change revert revert CT config test new CT pruning algorithm fixed cache + multiple blocks finalization track CT configuraiton on light clients support CT configuration change revert revert CT config test * BlockIdOrHeader isn't really required * removed debug leftovers + some docs * more docs * more post-merge fixes * more post-merge fixes * revertes some unnecessary changes * reverted unnecessary changes * fix compilation + unnecessary changes * (restart CI) * fix cache update when finalizing multiple blocks * fixed tests * collect_extrinsics -> set_collect_extrinsics * restore lost test * do not calculate block number twice * Update primitives/blockchain/src/error.rs Co-Authored-By: cheme <emericchevalier.pro@gmail.com> * map_err -> unwrap_or * document get_at Result * delete abandoned file * added weight for set_changes_trie_config * prefer_configs -> fail_if_disabled * Update client/api/src/backend.rs Co-Authored-By: cheme <emericchevalier.pro@gmail.com> * Update client/db/src/changes_tries_storage.rs Co-Authored-By: cheme <emericchevalier.pro@gmail.com> * CommitOperation+merge -> CommitOperations * fixed test compilation * merged two different CTRange structs * lost file * uggrade db from v0 to v1 (init CT cache + add column) * fix after merge Co-authored-by: cheme <emericchevalier.pro@gmail.com> Co-authored-by: Gavin Wood <github@gavwood.com>
74 lines
2.7 KiB
Rust
74 lines
2.7 KiB
Rust
// Copyright 2018-2020 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/>.
|
|
|
|
//! Block Builder extensions for tests.
|
|
|
|
use sp_api::{ApiExt, ProvideRuntimeApi};
|
|
use sp_core::ChangesTrieConfiguration;
|
|
use sc_client_api::backend;
|
|
use sp_runtime::traits::HasherFor;
|
|
|
|
use sc_block_builder::BlockBuilderApi;
|
|
|
|
/// Extension trait for test block builder.
|
|
pub trait BlockBuilderExt {
|
|
/// Add transfer extrinsic to the block.
|
|
fn push_transfer(&mut self, transfer: substrate_test_runtime::Transfer) -> Result<(), sp_blockchain::Error>;
|
|
/// Add storage change extrinsic to the block.
|
|
fn push_storage_change(
|
|
&mut self,
|
|
key: Vec<u8>,
|
|
value: Option<Vec<u8>>,
|
|
) -> Result<(), sp_blockchain::Error>;
|
|
/// Add changes trie configuration update extrinsic to the block.
|
|
fn push_changes_trie_configuration_update(
|
|
&mut self,
|
|
new_config: Option<ChangesTrieConfiguration>,
|
|
) -> Result<(), sp_blockchain::Error>;
|
|
}
|
|
|
|
impl<'a, A, B> BlockBuilderExt for sc_block_builder::BlockBuilder<'a, substrate_test_runtime::Block, A, B> where
|
|
A: ProvideRuntimeApi<substrate_test_runtime::Block> + 'a,
|
|
A::Api: BlockBuilderApi<substrate_test_runtime::Block, Error = sp_blockchain::Error> +
|
|
ApiExt<
|
|
substrate_test_runtime::Block,
|
|
StateBackend = backend::StateBackendFor<B, substrate_test_runtime::Block>
|
|
>,
|
|
B: backend::Backend<substrate_test_runtime::Block>,
|
|
// Rust bug: https://github.com/rust-lang/rust/issues/24159
|
|
backend::StateBackendFor<B, substrate_test_runtime::Block>:
|
|
sp_api::StateBackend<HasherFor<substrate_test_runtime::Block>>,
|
|
{
|
|
fn push_transfer(&mut self, transfer: substrate_test_runtime::Transfer) -> Result<(), sp_blockchain::Error> {
|
|
self.push(transfer.into_signed_tx())
|
|
}
|
|
|
|
fn push_storage_change(
|
|
&mut self,
|
|
key: Vec<u8>,
|
|
value: Option<Vec<u8>>,
|
|
) -> Result<(), sp_blockchain::Error> {
|
|
self.push(substrate_test_runtime::Extrinsic::StorageChange(key, value))
|
|
}
|
|
|
|
fn push_changes_trie_configuration_update(
|
|
&mut self,
|
|
new_config: Option<ChangesTrieConfiguration>,
|
|
) -> Result<(), sp_blockchain::Error> {
|
|
self.push(substrate_test_runtime::Extrinsic::ChangesTrieConfigUpdate(new_config))
|
|
}
|
|
}
|