mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-29 10:17:57 +00:00
9e56e1acdd
* Deprecate Weight::from_{ref_time, proof_size}
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
* Update templates
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
* Use from_parts
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
* Use from_parts
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
* Dont revert comment 🤦
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
* ".git/.scripts/commands/bench/bench.sh" pallet dev pallet_balances
* Update weight files
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
* More fixes
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
* Adapt to Master changes
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
---------
Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io>
Co-authored-by: command-bot <>
139 lines
4.1 KiB
Rust
139 lines
4.1 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
use crate::{self as frame_system, *};
|
|
use frame_support::{
|
|
parameter_types,
|
|
traits::{ConstU32, ConstU64},
|
|
};
|
|
use sp_core::H256;
|
|
use sp_runtime::{
|
|
testing::Header,
|
|
traits::{BlakeTwo256, IdentityLookup},
|
|
BuildStorage, Perbill,
|
|
};
|
|
|
|
type UncheckedExtrinsic = mocking::MockUncheckedExtrinsic<Test>;
|
|
type Block = mocking::MockBlock<Test>;
|
|
|
|
frame_support::construct_runtime!(
|
|
pub enum Test where
|
|
Block = Block,
|
|
NodeBlock = Block,
|
|
UncheckedExtrinsic = UncheckedExtrinsic,
|
|
{
|
|
System: frame_system::{Pallet, Call, Config, Storage, Event<T>},
|
|
}
|
|
);
|
|
|
|
const NORMAL_DISPATCH_RATIO: Perbill = Perbill::from_percent(75);
|
|
const MAX_BLOCK_WEIGHT: Weight = Weight::from_parts(1024, u64::MAX);
|
|
|
|
parameter_types! {
|
|
pub Version: RuntimeVersion = RuntimeVersion {
|
|
spec_name: sp_version::create_runtime_str!("test"),
|
|
impl_name: sp_version::create_runtime_str!("system-test"),
|
|
authoring_version: 1,
|
|
spec_version: 1,
|
|
impl_version: 1,
|
|
apis: sp_version::create_apis_vec!([]),
|
|
transaction_version: 1,
|
|
state_version: 1,
|
|
};
|
|
pub const DbWeight: RuntimeDbWeight = RuntimeDbWeight {
|
|
read: 10,
|
|
write: 100,
|
|
};
|
|
pub RuntimeBlockWeights: limits::BlockWeights = limits::BlockWeights::builder()
|
|
.base_block(Weight::from_parts(10, 0))
|
|
.for_class(DispatchClass::all(), |weights| {
|
|
weights.base_extrinsic = Weight::from_parts(5, 0);
|
|
})
|
|
.for_class(DispatchClass::Normal, |weights| {
|
|
weights.max_total = Some(NORMAL_DISPATCH_RATIO * MAX_BLOCK_WEIGHT);
|
|
})
|
|
.for_class(DispatchClass::Operational, |weights| {
|
|
weights.base_extrinsic = Weight::from_parts(10, 0);
|
|
weights.max_total = Some(MAX_BLOCK_WEIGHT);
|
|
weights.reserved = Some(
|
|
MAX_BLOCK_WEIGHT - NORMAL_DISPATCH_RATIO * MAX_BLOCK_WEIGHT
|
|
);
|
|
})
|
|
.avg_block_initialization(Perbill::from_percent(0))
|
|
.build_or_panic();
|
|
pub RuntimeBlockLength: limits::BlockLength =
|
|
limits::BlockLength::max_with_normal_ratio(1024, NORMAL_DISPATCH_RATIO);
|
|
}
|
|
|
|
parameter_types! {
|
|
pub static Killed: Vec<u64> = vec![];
|
|
}
|
|
|
|
pub struct RecordKilled;
|
|
impl OnKilledAccount<u64> for RecordKilled {
|
|
fn on_killed_account(who: &u64) {
|
|
Killed::mutate(|r| r.push(*who))
|
|
}
|
|
}
|
|
|
|
impl Config for Test {
|
|
type BaseCallFilter = frame_support::traits::Everything;
|
|
type BlockWeights = RuntimeBlockWeights;
|
|
type BlockLength = RuntimeBlockLength;
|
|
type RuntimeOrigin = RuntimeOrigin;
|
|
type RuntimeCall = RuntimeCall;
|
|
type Index = u64;
|
|
type BlockNumber = u64;
|
|
type Hash = H256;
|
|
type Hashing = BlakeTwo256;
|
|
type AccountId = u64;
|
|
type Lookup = IdentityLookup<Self::AccountId>;
|
|
type Header = Header;
|
|
type RuntimeEvent = RuntimeEvent;
|
|
type BlockHashCount = ConstU64<10>;
|
|
type DbWeight = DbWeight;
|
|
type Version = Version;
|
|
type PalletInfo = PalletInfo;
|
|
type AccountData = u32;
|
|
type OnNewAccount = ();
|
|
type OnKilledAccount = RecordKilled;
|
|
type SystemWeightInfo = ();
|
|
type SS58Prefix = ();
|
|
type OnSetCode = ();
|
|
type MaxConsumers = ConstU32<16>;
|
|
}
|
|
|
|
pub type SysEvent = frame_system::Event<Test>;
|
|
|
|
/// A simple call, which one doesn't matter.
|
|
pub const CALL: &<Test as Config>::RuntimeCall =
|
|
&RuntimeCall::System(frame_system::Call::set_heap_pages { pages: 0u64 });
|
|
|
|
/// Create new externalities for `System` module tests.
|
|
pub fn new_test_ext() -> sp_io::TestExternalities {
|
|
let mut ext: sp_io::TestExternalities =
|
|
GenesisConfig::default().build_storage().unwrap().into();
|
|
// Add to each test the initial weight of a block
|
|
ext.execute_with(|| {
|
|
System::register_extra_weight_unchecked(
|
|
<Test as crate::Config>::BlockWeights::get().base_block,
|
|
DispatchClass::Mandatory,
|
|
)
|
|
});
|
|
ext
|
|
}
|