mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-13 16:21:06 +00:00
33a6536299
* New Society * More logic drafting * More work * Building * Some tests * Fixes * Improvements to the voting process * More tests * Test number 20 * Tests * 30 tests * Another test] * All tests enabled * Minor stuff * generate_storage_alias: Rewrite as proc macro attribute This rewrites the `generate_storage_alias!` declarative macro as proc-macro attribute. While doing this the name is changed to `storage_alias`. The prefix can now also be the name of a pallet. This makes storage aliases work in migrations for all kind of chains and not just for the ones that use predefined prefixes. * Maintenance operations don't pay fee * Fix compilation and FMT * Moare fixes * Migrations * Fix tests and add migration testing * Introduce lazy-cleanup and avoid unbounded prefix removal * Fixes * Fixes * [WIP][Society] Adding benchmarking to the v2. (#11776) * [Society] Adding benchmarking to the v2. * [Society] Code review. * [Society] Better code. * Using clear() + clear_prefix() and adding more tests. * Benchmarking again... * Fix Cargo * Fixes * Fixes * Spelling * Fix benchmarks * Another fix * Remove println --------- Co-authored-by: Bastian Köcher <info@kchr.de> Co-authored-by: Artur Gontijo <arturgontijo@users.noreply.github.com>
309 lines
8.3 KiB
Rust
309 lines
8.3 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.
|
|
|
|
//! Test utilities
|
|
|
|
use super::*;
|
|
use crate as pallet_society;
|
|
|
|
use frame_support::{
|
|
assert_noop, assert_ok, ord_parameter_types, parameter_types,
|
|
traits::{ConstU32, ConstU64},
|
|
};
|
|
use frame_support_test::TestRandomness;
|
|
use frame_system::EnsureSignedBy;
|
|
use sp_core::H256;
|
|
use sp_runtime::{
|
|
testing::Header,
|
|
traits::{BlakeTwo256, IdentityLookup},
|
|
};
|
|
|
|
use RuntimeOrigin as Origin;
|
|
|
|
type UncheckedExtrinsic = frame_system::mocking::MockUncheckedExtrinsic<Test>;
|
|
type Block = frame_system::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>},
|
|
Balances: pallet_balances::{Pallet, Call, Storage, Config<T>, Event<T>},
|
|
Society: pallet_society::{Pallet, Call, Storage, Event<T>, Config<T>},
|
|
}
|
|
);
|
|
|
|
parameter_types! {
|
|
pub const SocietyPalletId: PalletId = PalletId(*b"py/socie");
|
|
}
|
|
|
|
ord_parameter_types! {
|
|
pub const ChallengePeriod: u64 = 8;
|
|
pub const ClaimPeriod: u64 = 1;
|
|
pub const FounderSetAccount: u128 = 1;
|
|
pub const SuspensionJudgementSetAccount: u128 = 2;
|
|
pub const MaxPayouts: u32 = 10;
|
|
pub const MaxBids: u32 = 10;
|
|
}
|
|
|
|
impl frame_system::Config for Test {
|
|
type BaseCallFilter = frame_support::traits::Everything;
|
|
type BlockWeights = ();
|
|
type BlockLength = ();
|
|
type DbWeight = ();
|
|
type RuntimeOrigin = RuntimeOrigin;
|
|
type Index = u64;
|
|
type BlockNumber = u64;
|
|
type Hash = H256;
|
|
type RuntimeCall = RuntimeCall;
|
|
type Hashing = BlakeTwo256;
|
|
type AccountId = u128;
|
|
type Lookup = IdentityLookup<Self::AccountId>;
|
|
type Header = Header;
|
|
type RuntimeEvent = RuntimeEvent;
|
|
type BlockHashCount = ConstU64<250>;
|
|
type Version = ();
|
|
type PalletInfo = PalletInfo;
|
|
type OnNewAccount = ();
|
|
type OnKilledAccount = ();
|
|
type AccountData = pallet_balances::AccountData<u64>;
|
|
type SystemWeightInfo = ();
|
|
type SS58Prefix = ();
|
|
type OnSetCode = ();
|
|
type MaxConsumers = ConstU32<16>;
|
|
}
|
|
|
|
impl pallet_balances::Config for Test {
|
|
type MaxLocks = ();
|
|
type MaxReserves = ();
|
|
type ReserveIdentifier = [u8; 8];
|
|
type Balance = u64;
|
|
type RuntimeEvent = RuntimeEvent;
|
|
type DustRemoval = ();
|
|
type ExistentialDeposit = ConstU64<1>;
|
|
type AccountStore = System;
|
|
type WeightInfo = ();
|
|
type FreezeIdentifier = ();
|
|
type MaxFreezes = ();
|
|
type RuntimeHoldReason = ();
|
|
type MaxHolds = ();
|
|
}
|
|
|
|
impl Config for Test {
|
|
type RuntimeEvent = RuntimeEvent;
|
|
type PalletId = SocietyPalletId;
|
|
type Currency = pallet_balances::Pallet<Self>;
|
|
type Randomness = TestRandomness<Self>;
|
|
type GraceStrikes = ConstU32<1>;
|
|
type PeriodSpend = ConstU64<1000>;
|
|
type VotingPeriod = ConstU64<3>;
|
|
type ClaimPeriod = ClaimPeriod;
|
|
type MaxLockDuration = ConstU64<100>;
|
|
type FounderSetOrigin = EnsureSignedBy<FounderSetAccount, u128>;
|
|
type ChallengePeriod = ChallengePeriod;
|
|
type MaxPayouts = MaxPayouts;
|
|
type MaxBids = MaxBids;
|
|
type WeightInfo = ();
|
|
}
|
|
|
|
pub struct EnvBuilder {
|
|
balance: u64,
|
|
balances: Vec<(u128, u64)>,
|
|
pot: u64,
|
|
founded: bool,
|
|
}
|
|
|
|
impl EnvBuilder {
|
|
pub fn new() -> Self {
|
|
Self {
|
|
balance: 10_000,
|
|
balances: vec![
|
|
(10, 50),
|
|
(20, 50),
|
|
(30, 50),
|
|
(40, 50),
|
|
(50, 50),
|
|
(60, 50),
|
|
(70, 50),
|
|
(80, 50),
|
|
(90, 50),
|
|
],
|
|
pot: 0,
|
|
founded: true,
|
|
}
|
|
}
|
|
|
|
pub fn execute<R, F: FnOnce() -> R>(mut self, f: F) -> R {
|
|
let mut t = frame_system::GenesisConfig::default().build_storage::<Test>().unwrap();
|
|
self.balances.push((Society::account_id(), self.balance.max(self.pot)));
|
|
pallet_balances::GenesisConfig::<Test> { balances: self.balances }
|
|
.assimilate_storage(&mut t)
|
|
.unwrap();
|
|
pallet_society::GenesisConfig::<Test> { pot: self.pot }
|
|
.assimilate_storage(&mut t)
|
|
.unwrap();
|
|
let mut ext: sp_io::TestExternalities = t.into();
|
|
ext.execute_with(|| {
|
|
if self.founded {
|
|
let r = b"be cool".to_vec();
|
|
assert!(Society::found_society(Origin::signed(1), 10, 10, 8, 2, 25, r).is_ok());
|
|
}
|
|
let r = f();
|
|
migrations::assert_internal_consistency::<Test, ()>();
|
|
r
|
|
})
|
|
}
|
|
pub fn founded(mut self, f: bool) -> Self {
|
|
self.founded = f;
|
|
self
|
|
}
|
|
}
|
|
|
|
/// Run until a particular block.
|
|
pub fn run_to_block(n: u64) {
|
|
while System::block_number() < n {
|
|
if System::block_number() > 1 {
|
|
System::on_finalize(System::block_number());
|
|
}
|
|
System::set_block_number(System::block_number() + 1);
|
|
System::on_initialize(System::block_number());
|
|
Society::on_initialize(System::block_number());
|
|
}
|
|
}
|
|
|
|
/// Creates a bid struct using input parameters.
|
|
pub fn bid<AccountId, Balance>(
|
|
who: AccountId,
|
|
kind: BidKind<AccountId, Balance>,
|
|
value: Balance,
|
|
) -> Bid<AccountId, Balance> {
|
|
Bid { who, kind, value }
|
|
}
|
|
|
|
/// Creates a candidate struct using input parameters.
|
|
pub fn candidacy<AccountId, Balance>(
|
|
round: RoundIndex,
|
|
bid: Balance,
|
|
kind: BidKind<AccountId, Balance>,
|
|
approvals: VoteCount,
|
|
rejections: VoteCount,
|
|
) -> Candidacy<AccountId, Balance> {
|
|
Candidacy { round, kind, bid, tally: Tally { approvals, rejections }, skeptic_struck: false }
|
|
}
|
|
|
|
pub fn next_challenge() {
|
|
let challenge_period: u64 = <Test as Config>::ChallengePeriod::get();
|
|
let now = System::block_number();
|
|
run_to_block(now + challenge_period - now % challenge_period);
|
|
}
|
|
|
|
pub fn next_voting() {
|
|
if let Period::Voting { more, .. } = Society::period() {
|
|
run_to_block(System::block_number() + more);
|
|
}
|
|
}
|
|
|
|
pub fn conclude_intake(allow_resignation: bool, judge_intake: Option<bool>) {
|
|
next_voting();
|
|
let round = RoundCount::<Test>::get();
|
|
for (who, candidacy) in Candidates::<Test>::iter() {
|
|
if candidacy.tally.clear_approval() {
|
|
assert_ok!(Society::claim_membership(Origin::signed(who)));
|
|
assert_noop!(
|
|
Society::claim_membership(Origin::signed(who)),
|
|
Error::<Test>::NotCandidate
|
|
);
|
|
continue
|
|
}
|
|
if candidacy.tally.clear_rejection() && allow_resignation {
|
|
assert_noop!(
|
|
Society::claim_membership(Origin::signed(who)),
|
|
Error::<Test>::NotApproved
|
|
);
|
|
assert_ok!(Society::resign_candidacy(Origin::signed(who)));
|
|
continue
|
|
}
|
|
if let (Some(founder), Some(approve)) = (Founder::<Test>::get(), judge_intake) {
|
|
if !candidacy.tally.clear_approval() && !approve {
|
|
// can be rejected by founder
|
|
assert_ok!(Society::kick_candidate(Origin::signed(founder), who));
|
|
continue
|
|
}
|
|
if !candidacy.tally.clear_rejection() && approve {
|
|
// can be rejected by founder
|
|
assert_ok!(Society::bestow_membership(Origin::signed(founder), who));
|
|
continue
|
|
}
|
|
}
|
|
if candidacy.tally.clear_rejection() && round > candidacy.round + 1 {
|
|
assert_noop!(
|
|
Society::claim_membership(Origin::signed(who)),
|
|
Error::<Test>::NotApproved
|
|
);
|
|
assert_ok!(Society::drop_candidate(Origin::signed(0), who));
|
|
assert_noop!(
|
|
Society::drop_candidate(Origin::signed(0), who),
|
|
Error::<Test>::NotCandidate
|
|
);
|
|
continue
|
|
}
|
|
if !candidacy.skeptic_struck {
|
|
assert_ok!(Society::punish_skeptic(Origin::signed(who)));
|
|
}
|
|
}
|
|
}
|
|
|
|
pub fn next_intake() {
|
|
let claim_period: u64 = <Test as Config>::ClaimPeriod::get();
|
|
match Society::period() {
|
|
Period::Voting { more, .. } => run_to_block(System::block_number() + more + claim_period),
|
|
Period::Claim { more, .. } => run_to_block(System::block_number() + more),
|
|
}
|
|
}
|
|
|
|
pub fn place_members(members: impl AsRef<[u128]>) {
|
|
for who in members.as_ref() {
|
|
assert_ok!(Society::insert_member(who, 0));
|
|
}
|
|
}
|
|
|
|
pub fn members() -> Vec<u128> {
|
|
let mut r = Members::<Test>::iter_keys().collect::<Vec<_>>();
|
|
r.sort();
|
|
r
|
|
}
|
|
|
|
pub fn membership() -> Vec<(u128, MemberRecord)> {
|
|
let mut r = Members::<Test>::iter().collect::<Vec<_>>();
|
|
r.sort_by_key(|x| x.0);
|
|
r
|
|
}
|
|
|
|
pub fn candidacies() -> Vec<(u128, Candidacy<u128, u64>)> {
|
|
let mut r = Candidates::<Test>::iter().collect::<Vec<_>>();
|
|
r.sort_by_key(|x| x.0);
|
|
r
|
|
}
|
|
|
|
pub fn candidates() -> Vec<u128> {
|
|
let mut r = Candidates::<Test>::iter_keys().collect::<Vec<_>>();
|
|
r.sort();
|
|
r
|
|
}
|