Files
pezkuwi-sdk/bizinikiwi/pezframe/asset-rewards/src/mock.rs
T

229 lines
7.0 KiB
Rust

// 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.
//! Test environment for Asset Rewards pezpallet.
use super::*;
use crate as pezpallet_asset_rewards;
use core::default::Default;
use pezframe_support::{
construct_runtime, derive_impl,
instances::Instance1,
parameter_types,
traits::{
tokens::fungible::{HoldConsideration, NativeFromLeft, NativeOrWithId, UnionOf},
AsEnsureOriginWithArg, ConstU128, ConstU32, EnsureOrigin, LinearStoragePrice,
},
PalletId,
};
use pezframe_system::EnsureSigned;
use pezsp_runtime::{traits::IdentityLookup, BuildStorage};
#[cfg(feature = "runtime-benchmarks")]
use self::benchmarking::BenchmarkHelper;
type Block = pezframe_system::mocking::MockBlock<MockRuntime>;
construct_runtime!(
pub enum MockRuntime
{
System: pezframe_system,
Balances: pezpallet_balances,
Assets: pezpallet_assets::<Instance1>,
AssetsFreezer: pezpallet_assets_freezer::<Instance1>,
StakingRewards: pezpallet_asset_rewards,
}
);
#[derive_impl(pezframe_system::config_preludes::TestDefaultConfig)]
impl pezframe_system::Config for MockRuntime {
type AccountId = u128;
type Lookup = IdentityLookup<Self::AccountId>;
type Block = Block;
type AccountData = pezpallet_balances::AccountData<u128>;
}
impl pezpallet_balances::Config for MockRuntime {
type Balance = u128;
type DustRemoval = ();
type RuntimeEvent = RuntimeEvent;
type ExistentialDeposit = ConstU128<100>;
type AccountStore = System;
type WeightInfo = ();
type MaxLocks = ();
type MaxReserves = ConstU32<50>;
type ReserveIdentifier = [u8; 8];
type FreezeIdentifier = RuntimeFreezeReason;
type MaxFreezes = ConstU32<50>;
type RuntimeHoldReason = RuntimeHoldReason;
type RuntimeFreezeReason = RuntimeFreezeReason;
type DoneSlashHandler = ();
}
impl pezpallet_assets::Config<Instance1> for MockRuntime {
type RuntimeEvent = RuntimeEvent;
type Balance = u128;
type RemoveItemsLimit = ConstU32<1000>;
type AssetId = u32;
type AssetIdParameter = u32;
type ReserveData = ();
type Currency = Balances;
type CreateOrigin = AsEnsureOriginWithArg<EnsureSigned<Self::AccountId>>;
type ForceOrigin = pezframe_system::EnsureRoot<Self::AccountId>;
type AssetDeposit = ConstU128<1>;
type AssetAccountDeposit = ConstU128<10>;
type MetadataDepositBase = ConstU128<1>;
type MetadataDepositPerByte = ConstU128<1>;
type ApprovalDeposit = ConstU128<1>;
type StringLimit = ConstU32<50>;
type Freezer = AssetsFreezer;
type Holder = ();
type Extra = ();
type WeightInfo = ();
type CallbackHandle = ();
pezpallet_assets::runtime_benchmarks_enabled! {
type BenchmarkHelper = ();
}
}
parameter_types! {
pub const StakingRewardsPalletId: PalletId = PalletId(*b"py/stkrd");
pub const Native: NativeOrWithId<u32> = NativeOrWithId::Native;
pub const PermissionedAccountId: u128 = 0;
}
/// Give Root Origin permission to create pools.
pub struct MockPermissionedOrigin;
impl EnsureOrigin<RuntimeOrigin> for MockPermissionedOrigin {
type Success = <MockRuntime as pezframe_system::Config>::AccountId;
fn try_origin(origin: RuntimeOrigin) -> Result<Self::Success, RuntimeOrigin> {
match origin.clone().into() {
Ok(pezframe_system::RawOrigin::Root) => Ok(PermissionedAccountId::get()),
_ => Err(origin),
}
}
#[cfg(feature = "runtime-benchmarks")]
fn try_successful_origin() -> Result<RuntimeOrigin, ()> {
Ok(RuntimeOrigin::root())
}
}
/// Allow Freezes for the `Assets` pezpallet
impl pezpallet_assets_freezer::Config<pezpallet_assets_freezer::Instance1> for MockRuntime {
type RuntimeFreezeReason = RuntimeFreezeReason;
type RuntimeEvent = RuntimeEvent;
}
pub type NativeAndAssets = UnionOf<Balances, Assets, NativeFromLeft, NativeOrWithId<u32>, u128>;
pub type NativeAndAssetsFreezer =
UnionOf<Balances, AssetsFreezer, NativeFromLeft, NativeOrWithId<u32>, u128>;
#[cfg(feature = "runtime-benchmarks")]
pub struct AssetRewardsBenchmarkHelper;
#[cfg(feature = "runtime-benchmarks")]
impl BenchmarkHelper<NativeOrWithId<u32>> for AssetRewardsBenchmarkHelper {
fn staked_asset() -> NativeOrWithId<u32> {
NativeOrWithId::<u32>::WithId(101)
}
fn reward_asset() -> NativeOrWithId<u32> {
NativeOrWithId::<u32>::WithId(102)
}
}
parameter_types! {
pub const CreationHoldReason: RuntimeHoldReason =
RuntimeHoldReason::StakingRewards(pezpallet_asset_rewards::HoldReason::PoolCreation);
}
impl Config for MockRuntime {
type RuntimeEvent = RuntimeEvent;
type AssetId = NativeOrWithId<u32>;
type Balance = <Self as pezpallet_balances::Config>::Balance;
type Assets = NativeAndAssets;
type AssetsFreezer = NativeAndAssetsFreezer;
type PalletId = StakingRewardsPalletId;
type CreatePoolOrigin = MockPermissionedOrigin;
type WeightInfo = ();
type RuntimeFreezeReason = RuntimeFreezeReason;
type Consideration = HoldConsideration<
u128,
Balances,
CreationHoldReason,
LinearStoragePrice<ConstU128<100>, ConstU128<0>, u128>,
>;
type BlockNumberProvider = pezframe_system::Pezpallet<Self>;
#[cfg(feature = "runtime-benchmarks")]
type BenchmarkHelper = AssetRewardsBenchmarkHelper;
}
pub(crate) fn new_test_ext() -> pezsp_io::TestExternalities {
let mut t = pezframe_system::GenesisConfig::<MockRuntime>::default()
.build_storage()
.unwrap();
pezpallet_assets::GenesisConfig::<MockRuntime, Instance1> {
// Genesis assets: id, owner, is_sufficient, min_balance
// pub assets: Vec<(T::AssetId, T::AccountId, bool, T::Balance)>,
assets: vec![(1, 1, true, 1), (10, 1, true, 1), (20, 1, true, 1)],
// Genesis metadata: id, name, symbol, decimals
// pub metadata: Vec<(T::AssetId, Vec<u8>, Vec<u8>, u8)>,
metadata: vec![
(1, b"test".to_vec(), b"TST".to_vec(), 18),
(10, b"test10".to_vec(), b"T10".to_vec(), 18),
(20, b"test20".to_vec(), b"T20".to_vec(), 18),
],
// Genesis accounts: id, account_id, balance
// pub accounts: Vec<(T::AssetId, T::AccountId, T::Balance)>,
accounts: vec![
(1, 1, 10000),
(1, 2, 20000),
(1, 3, 30000),
(1, 4, 40000),
(1, 10, 40000),
(1, 20, 40000),
],
next_asset_id: None,
reserves: vec![],
}
.assimilate_storage(&mut t)
.unwrap();
let pool_zero_account_id = 31086825966906540362769395565;
pezpallet_balances::GenesisConfig::<MockRuntime> {
balances: vec![
(0, 10000),
(1, 10000),
(2, 20000),
(3, 30000),
(4, 40000),
(10, 40000),
(20, 40000),
(pool_zero_account_id, 100_000), // Top up the default pool account id
],
..Default::default()
}
.assimilate_storage(&mut t)
.unwrap();
let mut ext = pezsp_io::TestExternalities::new(t);
ext.execute_with(|| System::set_block_number(1));
ext
}