mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-30 13:07:23 +00:00
af914e9f40
* Add test from original bug report Original is from @pepyakin in 3d7b27f3421818e8d6de568e02fbc2947a06246b. I adapted it to work with the latest master. * No longer cleanup module instance * Replace runtime cache with synchronous clone * Fix test * Preserve initial runtime memory and restore it on fetch * Remove leftover comment * Fix style * Improve variable naming * Replace get_into() with get() * Handle missing memory export better * Return earlier when creating runtime first time * Improve comments * fmt * Fix #2967. * Eradicate `code` from `Error::InvalidCode` * tidy * A state snapshot doc. * Store multiple runtimes by hash. * Get rid of deref. * Docs * Use Self for instantiate_module * REVERT ME * Should be ok * Commit * Remove dbg * Use fast-memory's erase * Clean and undo hacks. * Introduce a dedicated error for heap_base * Ban the start function. * Clean, docs and refactor * Add rustflags. * Update Cargo.lock * Apply Basti's suggestions Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * Rename allocates_huge_stack_array * Extend TestClientBuilder with set_heap_pages * Update the test. * Update core/executor/src/wasm_executor.rs Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * Update core/executor/src/wasm_runtimes_cache.rs Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * Update core/executor/src/error.rs Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * Update core/executor/src/error.rs Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * Fix tests. * Update cargo-lock * Use wasmi master * Use master wasmi * Move tests. * Use wasmi crates.io * Update Cargo.lock * Fix build.rs * Bump runtime version * Revert initial_heap_pages renaming * Bump wasmi up to 0.5.0 * Bump runtime version * Don't restore an instance every now and then * Update core/executor/src/wasm_runtimes_cache.rs Co-Authored-By: DemiMarie-parity <48690212+DemiMarie-parity@users.noreply.github.com> * Propagate error in CacheError * Clarify the get_heap_base call in instantiation * Supply --export=__heap_base See https://reviews.llvm.org/D62744 Co-authored-by: Jim Posen <jim.posen@gmail.com> * Bump version. * Use combinators for segments. * Fix build.rs * Fix build.rs for runtime-test
79 lines
2.7 KiB
Rust
79 lines
2.7 KiB
Rust
// Copyright 2017-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/>.
|
|
|
|
//! Tool for creating the genesis block.
|
|
|
|
use std::collections::HashMap;
|
|
use runtime_io::{blake2_256, twox_128};
|
|
use super::{AuthorityId, AccountId, WASM_BINARY};
|
|
use parity_codec::{Encode, KeyedVec, Joiner};
|
|
use primitives::{ChangesTrieConfiguration, map, storage::well_known_keys};
|
|
use runtime_primitives::traits::Block;
|
|
|
|
/// Configuration of a general Substrate test genesis block.
|
|
pub struct GenesisConfig {
|
|
pub changes_trie_config: Option<ChangesTrieConfiguration>,
|
|
pub authorities: Vec<AuthorityId>,
|
|
pub balances: Vec<(AccountId, u64)>,
|
|
pub heap_pages_override: Option<u64>,
|
|
}
|
|
|
|
impl GenesisConfig {
|
|
pub fn new(
|
|
support_changes_trie: bool,
|
|
authorities: Vec<AuthorityId>,
|
|
endowed_accounts: Vec<AccountId>,
|
|
balance: u64,
|
|
heap_pages_override: Option<u64>,
|
|
) -> Self {
|
|
GenesisConfig {
|
|
changes_trie_config: match support_changes_trie {
|
|
true => Some(super::changes_trie_config()),
|
|
false => None,
|
|
},
|
|
authorities: authorities.clone(),
|
|
balances: endowed_accounts.into_iter().map(|a| (a, balance)).collect(),
|
|
heap_pages_override,
|
|
}
|
|
}
|
|
|
|
pub fn genesis_map(&self) -> HashMap<Vec<u8>, Vec<u8>> {
|
|
let wasm_runtime = WASM_BINARY.to_vec();
|
|
let mut map: HashMap<Vec<u8>, Vec<u8>> = self.balances.iter()
|
|
.map(|&(ref account, balance)| (account.to_keyed_vec(b"balance:"), vec![].and(&balance)))
|
|
.map(|(k, v)| (blake2_256(&k[..])[..].to_vec(), v.to_vec()))
|
|
.chain(vec![
|
|
(well_known_keys::CODE.into(), wasm_runtime),
|
|
(
|
|
well_known_keys::HEAP_PAGES.into(),
|
|
vec![].and(&(self.heap_pages_override.unwrap_or(16 as u64))),
|
|
),
|
|
].into_iter())
|
|
.collect();
|
|
if let Some(ref changes_trie_config) = self.changes_trie_config {
|
|
map.insert(well_known_keys::CHANGES_TRIE_CONFIG.to_vec(), changes_trie_config.encode());
|
|
}
|
|
map.insert(twox_128(&b"sys:auth"[..])[..].to_vec(), self.authorities.encode());
|
|
map
|
|
}
|
|
}
|
|
|
|
pub fn additional_storage_with_genesis(genesis_block: &crate::Block) -> HashMap<Vec<u8>, Vec<u8>> {
|
|
map![
|
|
twox_128(&b"latest"[..]).to_vec() => genesis_block.hash().as_fixed_bytes().to_vec()
|
|
]
|
|
}
|