mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 15:07:59 +00:00
b0e1212d48
* Using child storage, (srml-support only), test failing . * fix simple tests. * Enumerable by requiring owned struct (previous form only allow &'static). Broken tests are from genesis init. * implement for_child_keys_with_prefix * indent * clear_child_prefix fix. * clear_child_prefix fix 2. * fix for storage_impl, if/when allowing child and not child this could be reverted. * Fix lot of urlinked child genesis, still need to look upon actual genesis srml module code. Probably still a lot of broken code needing debugging. * switch well_known_key to their associated module child trie. Fix a genesis init (balance). Complete some testing. Comment some tests before using. * fixing test runtime child keys * latest commit fix broken genesis init * fix system balances child name. * Important fix: storage_root from test externalities need children (it is already the case for ext). * executive root with child calculation * Avoid empty trie on test ext. * Symetric removal of key for system. * commenting changes related tests. * Remove child module specifics. * fix issues. * fix some formatting * fix bench and bump runtime * Remove extend_storage_overlays, assimilate_storage do the same as is proper considering srml macro. * Fix warning for assimilate. * Removing kill as they do not impact any test cases. * Use tuple of storage map instead of two parameters. This changes the behavior of decl_storage genesis build closure (breaking api). * Do not use build storage before assimilate. * fix error * Update core/state-machine/src/backend.rs
100 lines
3.2 KiB
Rust
100 lines
3.2 KiB
Rust
// Copyright 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/>.
|
|
|
|
use runtime_io::{with_externalities, Blake2Hasher};
|
|
use srml_support::{StorageValue, StorageMap, StorageDoubleMap};
|
|
use srml_support::storage::unhashed;
|
|
use codec::{Encode, Decode};
|
|
|
|
pub trait Trait {
|
|
type Origin;
|
|
type BlockNumber: Encode + Decode + Default + Clone;
|
|
}
|
|
|
|
srml_support::decl_module! {
|
|
pub struct Module<T: Trait> for enum Call where origin: T::Origin {}
|
|
}
|
|
|
|
srml_support::decl_storage!{
|
|
trait Store for Module<T: Trait> as FinalKeys {
|
|
pub Value config(value): u32;
|
|
|
|
pub Map: map u32 => u32;
|
|
pub Map2: map hasher(twox_128) u32 => u32;
|
|
|
|
pub LinkedMap: linked_map u32 => u32;
|
|
pub LinkedMap2: linked_map hasher(twox_128) u32 => u32;
|
|
|
|
pub DoubleMap: double_map u32, blake2_256(u32) => u32;
|
|
pub DoubleMap2: double_map hasher(twox_128) u32, blake2_128(u32) => u32;
|
|
|
|
pub Foo get(foo) config(): Option<T::BlockNumber>;
|
|
pub Foo2 get(foo2) config(): double_map u32, blake2_256(T::BlockNumber) => Option<u32>;
|
|
}
|
|
}
|
|
|
|
struct Test;
|
|
impl Trait for Test {
|
|
type BlockNumber = u32;
|
|
type Origin = u32;
|
|
}
|
|
|
|
fn new_test_ext() -> runtime_io::TestExternalities<Blake2Hasher> {
|
|
GenesisConfig::<Test>::default().build_storage().unwrap().into()
|
|
}
|
|
|
|
#[test]
|
|
fn final_keys() {
|
|
with_externalities(&mut new_test_ext(), || {
|
|
Value::put(1);
|
|
assert_eq!(unhashed::get::<u32>(&runtime_io::twox_128(b"FinalKeys Value")), Some(1u32));
|
|
|
|
Map::insert(1, 2);
|
|
let mut k = b"FinalKeys Map".to_vec();
|
|
k.extend(1u32.encode());
|
|
assert_eq!(unhashed::get::<u32>(&runtime_io::blake2_256(&k)), Some(2u32));
|
|
|
|
Map2::insert(1, 2);
|
|
let mut k = b"FinalKeys Map2".to_vec();
|
|
k.extend(1u32.encode());
|
|
assert_eq!(unhashed::get::<u32>(&runtime_io::twox_128(&k)), Some(2u32));
|
|
|
|
LinkedMap::insert(1, 2);
|
|
let mut k = b"FinalKeys LinkedMap".to_vec();
|
|
k.extend(1u32.encode());
|
|
assert_eq!(unhashed::get::<u32>(&runtime_io::blake2_256(&k)), Some(2u32));
|
|
|
|
LinkedMap2::insert(1, 2);
|
|
let mut k = b"FinalKeys LinkedMap2".to_vec();
|
|
k.extend(1u32.encode());
|
|
assert_eq!(unhashed::get::<u32>(&runtime_io::twox_128(&k)), Some(2u32));
|
|
|
|
DoubleMap::insert(&1, &2, &3);
|
|
let mut k = b"FinalKeys DoubleMap".to_vec();
|
|
k.extend(1u32.encode());
|
|
let mut k = runtime_io::blake2_256(&k).to_vec();
|
|
k.extend(&runtime_io::blake2_256(&2u32.encode()));
|
|
assert_eq!(unhashed::get::<u32>(&k), Some(3u32));
|
|
|
|
DoubleMap2::insert(&1, &2, &3);
|
|
let mut k = b"FinalKeys DoubleMap2".to_vec();
|
|
k.extend(1u32.encode());
|
|
let mut k = runtime_io::twox_128(&k).to_vec();
|
|
k.extend(&runtime_io::blake2_128(&2u32.encode()));
|
|
assert_eq!(unhashed::get::<u32>(&k), Some(3u32));
|
|
});
|
|
}
|