// This file is part of Bizinikiwi. // 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. //! Tests and test utilities for transaction pause pezpallet. #![cfg(test)] use super::*; use crate as pezpallet_tx_pause; use frame::testing_prelude::*; #[derive_impl(pezframe_system::config_preludes::TestDefaultConfig)] impl pezframe_system::Config for Test { type BaseCallFilter = InsideBoth; type Block = Block; type AccountData = pezpallet_balances::AccountData; } #[derive_impl(pezpallet_balances::config_preludes::TestDefaultConfig)] impl pezpallet_balances::Config for Test { type AccountStore = System; } impl pezpallet_utility::Config for Test { type RuntimeEvent = RuntimeEvent; type RuntimeCall = RuntimeCall; type PalletsOrigin = OriginCaller; type WeightInfo = (); } /// Mocked proxies to check that tx-pause also works with the proxy pezpallet. #[derive( Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Encode, Decode, DecodeWithMemTracking, RuntimeDebug, MaxEncodedLen, scale_info::TypeInfo, )] pub enum ProxyType { Any, JustTransfer, JustUtility, } impl Default for ProxyType { fn default() -> Self { Self::Any } } impl InstanceFilter for ProxyType { fn filter(&self, c: &RuntimeCall) -> bool { match self { ProxyType::Any => true, ProxyType::JustTransfer => { matches!( c, RuntimeCall::Balances(pezpallet_balances::Call::transfer_allow_death { .. }) ) }, ProxyType::JustUtility => matches!(c, RuntimeCall::Utility { .. }), } } fn is_superset(&self, o: &Self) -> bool { self == &ProxyType::Any || self == o } } impl pezpallet_proxy::Config for Test { type RuntimeEvent = RuntimeEvent; type RuntimeCall = RuntimeCall; type Currency = Balances; type ProxyType = ProxyType; type ProxyDepositBase = ConstU64<1>; type ProxyDepositFactor = ConstU64<1>; type MaxProxies = ConstU32<4>; type WeightInfo = (); type CallHasher = BlakeTwo256; type MaxPending = ConstU32<2>; type AnnouncementDepositBase = ConstU64<1>; type AnnouncementDepositFactor = ConstU64<1>; type BlockNumberProvider = pezframe_system::Pezpallet; } parameter_types! { pub const MaxNameLen: u32 = 50; } ord_parameter_types! { pub const PauseOrigin: u64 = 1; pub const UnpauseOrigin: u64 = 2; } /// Calls that are never allowed to be paused. pub struct WhitelistedCalls; impl Contains> for WhitelistedCalls { fn contains(full_name: &RuntimeCallNameOf) -> bool { match (full_name.0.as_slice(), full_name.1.as_slice()) { (b"Balances", b"transfer_keep_alive") => true, _ => false, } } } impl Config for Test { type RuntimeEvent = RuntimeEvent; type RuntimeCall = RuntimeCall; type PauseOrigin = EnsureSignedBy; type UnpauseOrigin = EnsureSignedBy; type WhitelistedCalls = WhitelistedCalls; type MaxNameLen = MaxNameLen; type WeightInfo = (); } type Block = pezframe_system::mocking::MockBlock; construct_runtime!( pub enum Test { System: pezframe_system, Balances: pezpallet_balances, Utility: pezpallet_utility, Proxy: pezpallet_proxy, TxPause: pezpallet_tx_pause, } ); pub fn new_test_ext() -> TestExternalities { let mut t = pezframe_system::GenesisConfig::::default().build_storage().unwrap(); pezpallet_balances::GenesisConfig:: { // The 0 account is NOT a special origin. The rest may be: balances: vec![(0, 1234), (1, 5678), (2, 5678), (3, 5678), (4, 5678)], ..Default::default() } .assimilate_storage(&mut t) .unwrap(); pezpallet_tx_pause::GenesisConfig:: { paused: vec![] } .assimilate_storage(&mut t) .unwrap(); let mut ext = TestExternalities::new(t); ext.execute_with(|| { System::set_block_number(1); }); ext } pub fn next_block() { TxPause::on_finalize(System::block_number()); Balances::on_finalize(System::block_number()); System::on_finalize(System::block_number()); System::set_block_number(System::block_number() + 1); System::on_initialize(System::block_number()); Balances::on_initialize(System::block_number()); TxPause::on_initialize(System::block_number()); } pub fn run_to(n: u64) { while System::block_number() < n { next_block(); } }