Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Logic for the (Core) Fellowship #13503

Merged
merged 97 commits into from
Mar 11, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
97 commits
Select commit Hold shift + click to select a range
e3a5bb2
More drafting
gavofyork Oct 7, 2022
3ff9ce8
Merge remote-tracking branch 'origin/master' into gav-paymaster
gavofyork Oct 7, 2022
07ab87a
Paymaster pallet
gavofyork Oct 11, 2022
88e11ce
Merge remote-tracking branch 'origin/master' into gav-paymaster
gavofyork Nov 30, 2022
8200850
Merge remote-tracking branch 'origin/master' into gav-paymaster
gavofyork Feb 12, 2023
958d34f
Fix build
gavofyork Feb 13, 2023
91cb1f5
More tests
gavofyork Feb 13, 2023
c53d372
Rename
gavofyork Feb 13, 2023
0806559
Rename
gavofyork Feb 13, 2023
5cadabf
Renaming
gavofyork Feb 13, 2023
712118b
Revert old changes
gavofyork Feb 13, 2023
07b785c
Multi-phase payouts to avoid bank-runs
gavofyork Feb 15, 2023
7fb95d0
Tests
gavofyork Feb 15, 2023
5c38814
Tests
gavofyork Feb 16, 2023
bfdf333
Allow payment to be targeted elsewhere
gavofyork Feb 16, 2023
807a3c9
Proper ssync payment failure handling
gavofyork Feb 16, 2023
cf1f365
Test for repayment
gavofyork Feb 22, 2023
d829078
Docs
gavofyork Feb 22, 2023
7162964
Impl RankedMembers for RankedCollective
gavofyork Feb 26, 2023
2e299f4
Implement Pay for Pot (i.e. basic account).
gavofyork Feb 26, 2023
5995eeb
Benchmarks
gavofyork Feb 26, 2023
c9c2ce8
Weights
gavofyork Feb 26, 2023
16bc55a
Introduce Salary benchmark into node
gavofyork Feb 26, 2023
2fc7fab
Fix warning
gavofyork Feb 26, 2023
575f426
Merge branch 'master' of https://github.com/paritytech/substrate into…
Feb 26, 2023
42a7927
".git/.scripts/commands/bench/bench.sh" pallet dev pallet_salary
Feb 26, 2023
7dc1529
Update primitives/arithmetic/src/traits.rs
gavofyork Feb 27, 2023
366267c
Update frame/salary/src/lib.rs
gavofyork Feb 27, 2023
26f1ab0
Update lib.rs
gavofyork Feb 27, 2023
872a047
Update frame/salary/src/lib.rs
gavofyork Feb 27, 2023
e2fd134
Docs
gavofyork Feb 27, 2023
8d8a5bf
Update frame/salary/src/lib.rs
gavofyork Feb 27, 2023
9849a65
Update frame/salary/src/lib.rs
gavofyork Feb 27, 2023
0b4aafa
Fix
gavofyork Feb 27, 2023
03199ae
Merge branch 'gav-paymaster' of github.com:paritytech/substrate into …
gavofyork Feb 27, 2023
a21b1bc
Fixes
gavofyork Feb 27, 2023
4c85f02
Fixes
gavofyork Feb 27, 2023
d5696c1
Move some salary traits stuff to a shared location
gavofyork Mar 1, 2023
199b1fe
Merge branch 'gav-paymaster' into gav-core-fellowship
gavofyork Mar 1, 2023
caaf99e
Initial draft
gavofyork Mar 1, 2023
3d70833
Comment out bits
gavofyork Mar 2, 2023
ddd4d3e
Fix
gavofyork Mar 2, 2023
26aa188
Merge branch 'gav-paymaster' into gav-core-fellowship
gavofyork Mar 2, 2023
3fcc590
First couple of tests
gavofyork Mar 2, 2023
f60ed83
One more test
gavofyork Mar 2, 2023
3704efe
Update frame/salary/src/lib.rs
gavofyork Mar 3, 2023
93a845d
Update frame/salary/src/lib.rs
gavofyork Mar 3, 2023
2ef3e14
Mul floor
gavofyork Mar 3, 2023
d992c0d
Tests
gavofyork Mar 3, 2023
e5c0733
Mul floor
gavofyork Mar 3, 2023
5d24050
Merge branch 'gav-paymaster' of github.com:paritytech/substrate into …
gavofyork Mar 3, 2023
b3d160e
Fix warnings
gavofyork Mar 3, 2023
b9623a4
Fix test
gavofyork Mar 3, 2023
b051049
Merge branch 'gav-paymaster' into gav-core-fellowship
gavofyork Mar 3, 2023
3580ea2
Tests
gavofyork Mar 3, 2023
31bf7b6
Last tests
gavofyork Mar 3, 2023
c08c010
Docs
gavofyork Mar 3, 2023
8782190
Merge branch 'gav-paymaster' into gav-core-fellowship
gavofyork Mar 3, 2023
a3f2026
Merge branch 'master' into gav-core-fellowship
gavofyork Mar 4, 2023
392c74d
Merge branch 'gav-core-fellowship' of github.com:paritytech/substrate…
gavofyork Mar 4, 2023
6c15f61
Fix warnings
gavofyork Mar 4, 2023
6fec0d2
Merge branch 'master' into gav-core-fellowship
gavofyork Mar 4, 2023
9d947a5
Benchmarks
gavofyork Mar 4, 2023
65f3570
Merge branch 'gav-core-fellowship' of github.com:paritytech/substrate…
gavofyork Mar 4, 2023
10e30b3
Weights
gavofyork Mar 4, 2023
bda6348
Integrate benchmark
gavofyork Mar 4, 2023
47ad52c
Fixes
gavofyork Mar 4, 2023
6752c18
Fix
gavofyork Mar 5, 2023
5b8e221
Merge branch 'master' of https://github.com/paritytech/substrate into…
Mar 5, 2023
3116351
".git/.scripts/commands/bench/bench.sh" pallet dev pallet_core_fellow…
Mar 5, 2023
032f7c1
Better process flow
gavofyork Mar 5, 2023
1f69d45
Fix benchmarks & tests
gavofyork Mar 5, 2023
b1868e0
Docs
gavofyork Mar 5, 2023
ec0f7db
Fixes
gavofyork Mar 5, 2023
59d70c9
Fixes
gavofyork Mar 5, 2023
cdb8022
docs
gavofyork Mar 5, 2023
308510a
".git/.scripts/commands/bench/bench.sh" pallet dev pallet_core_fellow…
Mar 5, 2023
8c60756
Docs and allow custom evidence size
gavofyork Mar 5, 2023
958edf6
Merge branch 'gav-core-fellowship' of github.com:paritytech/substrate…
gavofyork Mar 5, 2023
dd07d0c
".git/.scripts/commands/bench/bench.sh" pallet dev pallet_core_fellow…
Mar 5, 2023
8233b71
Update frame/core-fellowship/src/lib.rs
gavofyork Mar 6, 2023
1261201
Update frame/core-fellowship/src/tests.rs
gavofyork Mar 6, 2023
8e524e9
Update frame/core-fellowship/src/benchmarking.rs
gavofyork Mar 6, 2023
063f1d7
Update frame/core-fellowship/src/benchmarking.rs
gavofyork Mar 6, 2023
76e521b
Apply suggestions from code review
gavofyork Mar 6, 2023
a86c095
Rename
gavofyork Mar 6, 2023
c9de385
Update primitives/arithmetic/src/traits.rs
gavofyork Mar 7, 2023
8684952
Reduce magic numbers
gavofyork Mar 7, 2023
4fc96dd
Merge branch 'gav-core-fellowship' of github.com:paritytech/substrate…
gavofyork Mar 7, 2023
091c6af
Update frame/core-fellowship/src/lib.rs
gavofyork Mar 7, 2023
ecd0c46
Update frame/core-fellowship/src/lib.rs
gavofyork Mar 7, 2023
749f9ac
Benchmark result
gavofyork Mar 7, 2023
122df7c
Merge branch 'gav-core-fellowship' of github.com:paritytech/substrate…
gavofyork Mar 7, 2023
04da40e
Remove dependency
gavofyork Mar 8, 2023
ae5a5e2
set_params should pay
gavofyork Mar 8, 2023
554ac7d
induct should pay
gavofyork Mar 8, 2023
cc9f07c
Remove some other free calls
gavofyork Mar 8, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fix benchmarks & tests
  • Loading branch information
gavofyork committed Mar 5, 2023
commit 1f69d4511e6eaea5ee325a6370cb6188e7b98ac9
66 changes: 25 additions & 41 deletions frame/core-fellowship/src/benchmarking.rs
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,16 @@ mod benchmarks {
assert!(MemberEvidence::<T, I>::contains_key(who));
}

fn make_member<T: Config<I>, I: 'static>(rank: u16) -> T::AccountId {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
for _ in 0..rank {
T::Members::promote(&member).unwrap();
}
CoreFellowship::<T, I>::sync(RawOrigin::Signed(member.clone()).into()).unwrap();
member
}

#[benchmark]
fn set_params() {
let params = ParamsType {
Expand All @@ -60,10 +70,7 @@ mod benchmarks {

#[benchmark]
fn bump_offboard() {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
T::Members::promote(&member).unwrap();
CoreFellowship::<T, I>::prove(RawOrigin::Root.into(), member.clone(), 1u8.into()).unwrap();
let member = make_member::<T, I>(0);

// Set it to the max value to ensure that any possible auto-demotion period has passed.
frame_system::Pallet::<T>::set_block_number(T::BlockNumber::max_value());
Expand All @@ -79,11 +86,7 @@ mod benchmarks {

#[benchmark]
fn bump_demote() {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
T::Members::promote(&member).unwrap();
T::Members::promote(&member).unwrap();
CoreFellowship::<T, I>::prove(RawOrigin::Root.into(), member.clone(), 2u8.into()).unwrap();
let member = make_member::<T, I>(2);

// Set it to the max value to ensure that any possible auto-demotion period has passed.
frame_system::Pallet::<T>::set_block_number(T::BlockNumber::max_value());
Expand All @@ -101,10 +104,7 @@ mod benchmarks {

#[benchmark]
fn set_active() {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
T::Members::promote(&member).unwrap();
CoreFellowship::<T, I>::prove(RawOrigin::Root.into(), member.clone(), 1u8.into()).unwrap();
let member = make_member::<T, I>(1);
assert!(Member::<T, I>::get(&member).unwrap().is_active);

#[extrinsic_call]
Expand All @@ -115,25 +115,18 @@ mod benchmarks {

#[benchmark]
fn induct() {
let candidate = account("candidate", 0, SEED);
T::Members::induct(&candidate).unwrap();
assert_eq!(T::Members::rank_of(&candidate), Some(0));
ensure_evidence::<T, I>(&candidate);
let candidate: T::AccountId = account("candidate", 0, SEED);

#[extrinsic_call]
_(RawOrigin::Root, candidate.clone());

assert_eq!(T::Members::rank_of(&candidate), Some(1));
assert!(!MemberEvidence::<T, I>::contains_key(&candidate));
assert_eq!(T::Members::rank_of(&candidate), Some(0));
assert!(Member::<T, I>::contains_key(&candidate));
}

#[benchmark]
fn promote() {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
T::Members::promote(&member).unwrap();
CoreFellowship::<T, I>::prove(RawOrigin::Root.into(), member.clone(), 1u8.into()).unwrap();
assert_eq!(T::Members::rank_of(&member), Some(1));
let member = make_member::<T, I>(1);
ensure_evidence::<T, I>(&member);

#[extrinsic_call]
Expand All @@ -145,13 +138,10 @@ mod benchmarks {

#[benchmark]
fn offboard() {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
T::Members::promote(&member).unwrap();
CoreFellowship::<T, I>::prove(RawOrigin::Root.into(), member.clone(), 1u8.into()).unwrap();
let member = make_member::<T, I>(0);
T::Members::demote(&member).unwrap();
gavofyork marked this conversation as resolved.
Show resolved Hide resolved

assert_eq!(T::Members::rank_of(&member), Some(0));
assert!(T::Members::rank_of(&member).is_none());
assert!(Member::<T, I>::contains_key(&member));

#[extrinsic_call]
Expand All @@ -161,25 +151,22 @@ mod benchmarks {
}

#[benchmark]
fn prove_new() {
fn sync() {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
T::Members::promote(&member).unwrap();

assert!(!Member::<T, I>::contains_key(&member));

#[extrinsic_call]
CoreFellowship::<T, I>::prove(RawOrigin::Root, member.clone(), 1u8.into());
_(RawOrigin::Signed(member.clone()));

assert!(Member::<T, I>::contains_key(&member));
}

#[benchmark]
fn prove_existing() {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
T::Members::promote(&member).unwrap();
CoreFellowship::<T, I>::prove(RawOrigin::Root.into(), member.clone(), 1u8.into()).unwrap();
fn approve() {
let member = make_member::<T, I>(1);

let then = frame_system::Pallet::<T>::block_number();
let now = then.saturating_plus_one();
Expand All @@ -190,18 +177,15 @@ mod benchmarks {
assert_eq!(Member::<T, I>::get(&member).unwrap().last_proof, then);

#[extrinsic_call]
CoreFellowship::<T, I>::prove(RawOrigin::Root, member.clone(), 1u8.into());
_(RawOrigin::Root, member.clone(), 1u8.into());

assert_eq!(Member::<T, I>::get(&member).unwrap().last_proof, now);
assert!(!MemberEvidence::<T, I>::contains_key(&member));
}

#[benchmark]
fn submit_evidence() {
let member = account("member", 0, SEED);
T::Members::induct(&member).unwrap();
T::Members::promote(&member).unwrap();
CoreFellowship::<T, I>::prove(RawOrigin::Root.into(), member.clone(), 1u8.into()).unwrap();
let member = make_member::<T, I>(1);
let evidence = vec![0; Evidence::bound()].try_into().unwrap();

assert!(!MemberEvidence::<T, I>::contains_key(&member));
Expand Down
35 changes: 17 additions & 18 deletions frame/core-fellowship/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -188,8 +188,10 @@ pub mod pallet {
who: T::AccountId,
wish: Wish,
evidence: Evidence,
/// The old rank, prior to this change.
old_rank: u16,
new_rank: u16,
/// New rank. If `None` then candidate record was removed entirely.
new_rank: Option<u16>,
},
/// Pre-ranked account has been inducted at their current rank.
Synced { who: T::AccountId, rank: RankOf<T, I> },
Expand Down Expand Up @@ -254,18 +256,16 @@ pub mod pallet {
// Ensure enough time has passed.
let now = frame_system::Pallet::<T>::block_number();
if now >= demotion_block {
let to_rank = rank.clone().saturating_less_one();
Self::dispose_evidence(who.clone(), rank, to_rank);
if rank > 0 {
T::Members::demote(&who)?;
}
let event = if to_rank.is_zero() {
Member::<T, I>::remove(&who);
Event::<T, I>::Offboarded { who }
} else {
T::Members::demote(&who)?;
let maybe_to_rank = T::Members::rank_of(&who);
Self::dispose_evidence(who.clone(), rank, maybe_to_rank);
let event = if let Some(to_rank) = maybe_to_rank {
member.last_proof = now;
Member::<T, I>::insert(&who, &member);
Event::<T, I>::Demoted { who, to_rank }
} else {
Member::<T, I>::remove(&who);
Event::<T, I>::Offboarded { who }
};
Self::deposit_event(event);
return Ok(Pays::No.into())
Expand Down Expand Up @@ -319,10 +319,9 @@ pub mod pallet {
/// - `origin`: An origin which satisfies `ProofOrigin` or root.
/// - `who`: A member (i.e. of non-zero rank).
/// - `at_rank`: The rank of member.
#[pallet::weight(T::WeightInfo::prove_existing().max(T::WeightInfo::prove_new()))]
#[pallet::weight(T::WeightInfo::approve())]
#[pallet::call_index(3)]
// TODO: Rename to approve
pub fn prove(
pub fn approve(
origin: OriginFor<T>,
who: T::AccountId,
at_rank: RankOf<T, I>,
Expand All @@ -339,7 +338,7 @@ pub mod pallet {
member.last_proof = frame_system::Pallet::<T>::block_number();
Member::<T, I>::insert(&who, &member);

Self::dispose_evidence(who.clone(), at_rank, at_rank);
Self::dispose_evidence(who.clone(), at_rank, Some(at_rank));
Self::deposit_event(Event::<T, I>::Proven { who, at_rank });

Ok(Pays::No.into())
gavofyork marked this conversation as resolved.
Show resolved Hide resolved
Expand Down Expand Up @@ -408,7 +407,7 @@ pub mod pallet {
member.last_promotion = now;
member.last_proof = now;
Member::<T, I>::insert(&who, &member);
Self::dispose_evidence(who.clone(), rank, to_rank);
Self::dispose_evidence(who.clone(), rank, Some(to_rank));

Self::deposit_event(Event::<T, I>::Promoted { who, to_rank });

Expand Down Expand Up @@ -436,7 +435,7 @@ pub mod pallet {
/// - `origin`: A `Signed` origin of an inducted and ranked account.
/// - `wish`: The stated desire of the member.
/// - `evidence`: A freeform dump of evidence to be considered.
#[pallet::weight(T::WeightInfo::offboard())]
#[pallet::weight(T::WeightInfo::submit_evidence())]
#[pallet::call_index(7)]
pub fn submit_evidence(
origin: OriginFor<T>,
Expand All @@ -462,7 +461,7 @@ pub mod pallet {
/// - `origin`: A signed origin of a ranked but not yet inducted account.
/// - `who`: A member (i.e. of non-zero rank).
/// - `at_rank`: The rank of member.
#[pallet::weight(T::WeightInfo::offboard())]
#[pallet::weight(T::WeightInfo::sync())]
#[pallet::call_index(8)]
pub fn sync(origin: OriginFor<T>) -> DispatchResultWithPostInfo {
let who = ensure_signed(origin)?;
Expand Down Expand Up @@ -492,7 +491,7 @@ pub mod pallet {
}
}

fn dispose_evidence(who: T::AccountId, old_rank: u16, new_rank: u16) {
fn dispose_evidence(who: T::AccountId, old_rank: u16, new_rank: Option<u16>) {
if let Some((wish, evidence)) = MemberEvidence::<T, I>::take(&who) {
let e = Event::<T, I>::EvidenceJudged { who, wish, evidence, old_rank, new_rank };
Self::deposit_event(e);
Expand Down
9 changes: 6 additions & 3 deletions frame/core-fellowship/src/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -253,8 +253,8 @@ fn promote_works() {
fn sync_works() {
new_test_ext().execute_with(|| {
set_rank(10, 5);
assert_noop!(CoreFellowship::prove(signed(4), 10, 5), Error::<Test>::NoPermission);
assert_noop!(CoreFellowship::prove(signed(6), 10, 6), Error::<Test>::UnexpectedRank);
assert_noop!(CoreFellowship::approve(signed(4), 10, 5), Error::<Test>::NoPermission);
assert_noop!(CoreFellowship::approve(signed(6), 10, 6), Error::<Test>::UnexpectedRank);
assert_ok!(CoreFellowship::sync(signed(10)));
assert!(Member::<Test>::contains_key(10));
assert_eq!(next_demotion(10), 11);
Expand Down Expand Up @@ -286,6 +286,9 @@ fn auto_demote_offboard_works() {
run_to(3);
assert_ok!(CoreFellowship::bump(signed(0), 10));
assert_eq!(TestClub::rank_of(&10), Some(0));
assert_noop!(CoreFellowship::bump(signed(0), 10), Error::<Test>::NothingDoing);
run_to(4);
assert_ok!(CoreFellowship::bump(signed(0), 10));
assert_noop!(CoreFellowship::bump(signed(0), 10), Error::<Test>::NotProved);
});
}
Expand Down Expand Up @@ -314,7 +317,7 @@ fn proof_postpones_auto_demote() {
assert_ok!(CoreFellowship::sync(signed(10)));

run_to(11);
assert_ok!(CoreFellowship::prove(signed(5), 10, 5));
assert_ok!(CoreFellowship::approve(signed(5), 10, 5));
assert_eq!(next_demotion(10), 21);
assert_noop!(CoreFellowship::bump(signed(0), 10), Error::<Test>::NothingDoing);
});
Expand Down
19 changes: 13 additions & 6 deletions frame/core-fellowship/src/weights.rs
Original file line number Diff line number Diff line change
Expand Up @@ -56,8 +56,9 @@ pub trait WeightInfo {
fn induct() -> Weight;
fn promote() -> Weight;
fn offboard() -> Weight;
fn prove_new() -> Weight;
fn prove_existing() -> Weight;
fn sync() -> Weight;
fn approve() -> Weight;
fn submit_evidence() -> Weight;
}

/// Weights for pallet_core_fellowship using the Substrate node and recommended hardware.
Expand Down Expand Up @@ -181,7 +182,7 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
/// Proof: RankedCollective Members (max_values: None, max_size: Some(42), added: 2517, mode: MaxEncodedLen)
/// Storage: CoreFellowship Member (r:1 w:1)
/// Proof: CoreFellowship Member (max_values: None, max_size: Some(49), added: 2524, mode: MaxEncodedLen)
fn prove_new() -> Weight {
fn sync() -> Weight {
// Proof Size summary in bytes:
// Measured: `280`
// Estimated: `7021`
Expand All @@ -194,7 +195,7 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
/// Proof: RankedCollective Members (max_values: None, max_size: Some(42), added: 2517, mode: MaxEncodedLen)
/// Storage: CoreFellowship Member (r:1 w:1)
/// Proof: CoreFellowship Member (max_values: None, max_size: Some(49), added: 2524, mode: MaxEncodedLen)
fn prove_existing() -> Weight {
fn approve() -> Weight {
// Proof Size summary in bytes:
// Measured: `355`
// Estimated: `7021`
Expand All @@ -203,6 +204,9 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
.saturating_add(T::DbWeight::get().reads(2_u64))
.saturating_add(T::DbWeight::get().writes(1_u64))
}
fn submit_evidence() -> Weight {
Weight::from_parts(0, 0)
}
}

// For backwards compatibility and tests
Expand Down Expand Up @@ -325,7 +329,7 @@ impl WeightInfo for () {
/// Proof: RankedCollective Members (max_values: None, max_size: Some(42), added: 2517, mode: MaxEncodedLen)
/// Storage: CoreFellowship Member (r:1 w:1)
/// Proof: CoreFellowship Member (max_values: None, max_size: Some(49), added: 2524, mode: MaxEncodedLen)
fn prove_new() -> Weight {
fn sync() -> Weight {
// Proof Size summary in bytes:
// Measured: `280`
// Estimated: `7021`
Expand All @@ -338,7 +342,7 @@ impl WeightInfo for () {
/// Proof: RankedCollective Members (max_values: None, max_size: Some(42), added: 2517, mode: MaxEncodedLen)
/// Storage: CoreFellowship Member (r:1 w:1)
/// Proof: CoreFellowship Member (max_values: None, max_size: Some(49), added: 2524, mode: MaxEncodedLen)
fn prove_existing() -> Weight {
fn approve() -> Weight {
// Proof Size summary in bytes:
// Measured: `355`
// Estimated: `7021`
Expand All @@ -347,4 +351,7 @@ impl WeightInfo for () {
.saturating_add(RocksDbWeight::get().reads(2_u64))
.saturating_add(RocksDbWeight::get().writes(1_u64))
}
fn submit_evidence() -> Weight {
Weight::from_parts(0, 0)
}
}