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

Implements a variable deposit base calculation for EPM signed submissions #13983

Open
wants to merge 63 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
63 commits
Select commit Hold shift + click to select a range
cda7c0e
Implements a variable deposit base calculation in EPM
gpestana Apr 23, 2023
cf5cd81
Implements geometric increase of base deposit based on the number of …
gpestana Apr 26, 2023
8b7e455
Finishes implementation and test
gpestana Apr 27, 2023
b9d90aa
More docs
gpestana Apr 27, 2023
95217b7
fixes docs
gpestana Apr 27, 2023
66a0bfb
Update frame/election-provider-multi-phase/src/signed.rs
gpestana May 4, 2023
a1636ca
Update bin/node/runtime/src/lib.rs
gpestana May 4, 2023
cb33150
Adds force_origin support (#13845)
gupnik Apr 24, 2023
0591d11
Vote locks for all reasons except RESERVE (#13914)
muharem Apr 24, 2023
1a14c52
[ci] Update buildah command and version (#13989)
alvicsam Apr 24, 2023
1c781d6
Bump enumflags2 from 0.7.5 to 0.7.7 (#13995)
dependabot[bot] Apr 24, 2023
e5a9709
frame-support-procedural: Fix detection of the tuples feature (#13996)
bkchr Apr 24, 2023
2d277ad
pallet-democracy: Do not request the proposal when scheduling (#13827)
bkchr Apr 25, 2023
db79585
[ci] Add message to cargo-deny (#14001)
alvicsam Apr 25, 2023
e34ab81
refactor(cli): Make some run params reusable (#13870)
yjhmelody Apr 25, 2023
c463fb0
contracts Add LOG_TARGET constant (#14002)
pgherveou Apr 25, 2023
316bced
frame-support: migrate some tests from `decl_*` macros to the new `pa…
koushiro Apr 25, 2023
4286a74
Removes ReportsByKindIndex (#13936)
gupnik Apr 25, 2023
f05447f
Allow missing docs for autogen weights. (#14011)
gilescope Apr 25, 2023
5ca19ef
[contracts] Port host functions to Weight V2 and storage deposit limi…
agryaznov Apr 26, 2023
7ddac2d
sp-core: remove useless bounded module (#13865)
koushiro Apr 26, 2023
4df1a87
fix a test (#14021)
agryaznov Apr 26, 2023
df3a709
Various minor fixes (#13945)
gavofyork Apr 26, 2023
941de8e
contracts Add storage_deposit test (#14003)
pgherveou Apr 27, 2023
76c802e
remote-externalities: batch insert key/values (#14004)
liamaharon Apr 27, 2023
9b487cd
collective pallet: sort genesis members and enforce max len constrain…
liamaharon Apr 27, 2023
db806ea
sc-network-sync: Improve error reporting (#14025)
bkchr Apr 27, 2023
5c320d3
contracts Fix store-call test path (#14028)
pgherveou Apr 27, 2023
49f69e4
chore(cli): make cli display docs correctly (#14017)
yjhmelody Apr 27, 2023
3b05747
improve staking interface methods (#14023)
kianenigma Apr 27, 2023
a5c6264
try-runtime-cli: improve ci stability (#14030)
liamaharon Apr 27, 2023
a6aa272
FRAME: inherited call weight syntax (#13932)
ggwpez Apr 27, 2023
07b1541
Implements `try_state` hook in elections and EPM pallets (#13979)
gpestana Apr 27, 2023
be73ca3
Bump wasmtime from 6.0.1 to 6.0.2 (#14037)
dependabot[bot] Apr 27, 2023
d20deb0
Improve contribution guidelines (#13902)
bkchr Apr 28, 2023
063b3b0
CI: Remove crate publish check (#14044)
ggwpez Apr 28, 2023
9ad2b40
fix(in_mem): fix the clone logic (#14038)
yjhmelody Apr 29, 2023
476ebd4
Contracts: runtime_call and storage_deposit (#13990)
pgherveou Apr 29, 2023
0e3c6b5
Fix bags-list tests execution (#14047)
bkchr May 1, 2023
513463b
CI: migrate to Google Cloud (#13994)
rcny May 2, 2023
f541d16
rpc: Use the blocks pinning API for chainHead methods (#13233)
lexnv May 2, 2023
2b3e750
contracts: Make Origin information available (#13708)
juangirini May 2, 2023
6ebcadd
Bump clap to 4.2.5 (#14061)
May 2, 2023
e296263
Manual seal delayed finalize (#13999)
shunsukew May 2, 2023
7eeb77d
Don't run `check-crates-publishing` job on prs (#14064)
May 3, 2023
dcaebbe
Only calculate tree route during finalization when there are multiple…
skunert May 3, 2023
4b7f99b
test-staking-e2e: Add to main `Cargo.toml`. (#14062)
bkchr May 3, 2023
89acf47
contracts: add events to ContractResult (#13807)
juangirini May 3, 2023
5f8f249
rpc server: break legacy CLI options and remove "backward compatible …
niklasad1 May 3, 2023
2668e9a
Makes DepositCalculator trait more generic
gpestana May 4, 2023
792ecc4
Merge branch 'master' into gpestana/epm_variable_deposit_base
gpestana May 4, 2023
1960329
Fixed runtime configs
gpestana May 4, 2023
afb016d
Merge remote-tracking branch 'origin/master' into gpestana/epm_variab…
May 4, 2023
1558456
Updates e2e integration tests mock
gpestana May 4, 2023
310a116
Merge remote-tracking branch 'origin/master' into gpestana/epm_variab…
May 17, 2023
0098612
Refactors the traits
gpestana May 17, 2023
99622a5
Update frame/election-provider-multi-phase/src/signed.rs
gpestana May 21, 2023
49e053b
Merge branch 'master' into gpestana/epm_variable_deposit_base
gpestana Jun 9, 2023
f053577
Nits and addresses review comments
gpestana Jun 9, 2023
f11d312
Merge branch 'master' into gpestana/epm_variable_deposit_base
gpestana Jun 9, 2023
856828e
".git/.scripts/commands/fmt/fmt.sh"
Jun 9, 2023
fe49a49
Parameterize GeometricProgression instead of using dedicated associat…
gpestana Jun 12, 2023
a51a3eb
Merge branch 'master' into gpestana/epm_variable_deposit_base
gpestana Aug 10, 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
Next Next commit
Implements a variable deposit base calculation in EPM
  • Loading branch information
gpestana committed Apr 23, 2023
commit cda7c0eb081857fcb307572350063b5f782be13d
7 changes: 4 additions & 3 deletions frame/election-provider-multi-phase/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -564,7 +564,9 @@ pub use pallet::*;
#[frame_support::pallet]
pub mod pallet {
use super::*;
use frame_election_provider_support::{InstantElectionProvider, NposSolver};
use frame_election_provider_support::{
traits::DepositBase, InstantElectionProvider, NposSolver,
};
use frame_support::{pallet_prelude::*, traits::EstimateCallFee};
use frame_system::pallet_prelude::*;

Expand Down Expand Up @@ -645,8 +647,7 @@ pub mod pallet {
type SignedRewardBase: Get<BalanceOf<Self>>;

/// Base deposit for a signed solution.
#[pallet::constant]
type SignedDepositBase: Get<BalanceOf<Self>>;
type SignedDepositBase: DepositBase<BalanceOf<Self>>;

/// Per-byte deposit for a signed solution.
#[pallet::constant]
Expand Down
15 changes: 14 additions & 1 deletion frame/election-provider-multi-phase/src/mock.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ use crate::{self as multi_phase, unsigned::MinerConfig};
use frame_election_provider_support::{
data_provider,
onchain::{self},
traits::DepositBase,
ElectionDataProvider, NposSolution, SequentialPhragmen,
};
pub use frame_support::{assert_noop, assert_ok, pallet_prelude::GetDefault};
Expand Down Expand Up @@ -287,6 +288,8 @@ parameter_types! {
pub static UnsignedPhase: BlockNumber = 5;
pub static SignedMaxSubmissions: u32 = 5;
pub static SignedMaxRefunds: u32 = 1;
// when the solution queue has more than 7 submissions, the base deposit is 2 * `SignedDepositBase`.
pub static QueueLenghtDoubleDeposit: usize = 7;
pub static SignedDepositBase: Balance = 5;
pub static SignedDepositByte: Balance = 0;
pub static SignedDepositWeight: Balance = 0;
Expand Down Expand Up @@ -393,7 +396,7 @@ impl crate::Config for Runtime {
type OffchainRepeat = OffchainRepeat;
type MinerTxPriority = MinerTxPriority;
type SignedRewardBase = SignedRewardBase;
type SignedDepositBase = SignedDepositBase;
type SignedDepositBase = Self;
type SignedDepositByte = ();
type SignedDepositWeight = ();
type SignedMaxWeight = SignedMaxWeight;
Expand All @@ -415,6 +418,16 @@ impl crate::Config for Runtime {
type Solver = SequentialPhragmen<AccountId, SolutionAccuracyOf<Runtime>, Balancing>;
}

impl DepositBase<Balance> for Runtime {
fn calculate(queue_len: usize) -> Balance {
if queue_len < QueueLenghtDoubleDeposit::get() {
SignedDepositBase::get()
} else {
SignedDepositBase::get() * 2
}
}
}

impl<LocalCall> frame_system::offchain::SendTransactionTypes<LocalCall> for Runtime
where
RuntimeCall: From<LocalCall>,
Expand Down
32 changes: 30 additions & 2 deletions frame/election-provider-multi-phase/src/signed.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ use crate::{
SolutionOf, SolutionOrSnapshotSize, Weight, WeightInfo,
};
use codec::{Decode, Encode, HasCompact};
use frame_election_provider_support::NposSolution;
use frame_election_provider_support::{traits::DepositBase, NposSolution};
use frame_support::traits::{
defensive_prelude::*, Currency, Get, OnUnbalanced, ReservableCurrency,
};
Expand Down Expand Up @@ -528,7 +528,7 @@ impl<T: Config> Pallet<T> {
let weight_deposit = T::SignedDepositWeight::get()
.saturating_mul(feasibility_weight.ref_time().saturated_into());

T::SignedDepositBase::get()
T::SignedDepositBase::calculate(Self::signed_submissions().len())
.saturating_add(len_deposit)
.saturating_add(weight_deposit)
}
Expand Down Expand Up @@ -770,6 +770,34 @@ mod tests {
})
}

#[test]
fn variable_deposit_base_works() {
ExtBuilder::default().build_and_execute(|| {
roll_to_signed();
assert!(MultiPhase::current_phase().is_signed());
assert_eq!(QueueLenghtDoubleDeposit::get(), 7);
SignedMaxSubmissions::set(10);

for s in 0..SignedMaxSubmissions::get() {
let account = 99 + s as u64;
Balances::make_free_balance_be(&account, 100);
// score is always decreasing
let mut solution = raw_solution();
solution.score.minimal_stake -= s as u128;

assert_ok!(MultiPhase::submit(RuntimeOrigin::signed(account), Box::new(solution)));

// checlk if the deposit base is being calculated according to the `DepositBase`
// implementation.
if MultiPhase::signed_submissions().len() <= QueueLenghtDoubleDeposit::get() {
assert_eq!(balances(&account), (95, 5));
} else {
assert_eq!(balances(&account), (90, 10));
}
}
})
}

#[test]
fn call_fee_refund_is_limited_by_signed_max_refunds() {
ExtBuilder::default().build_and_execute(|| {
Expand Down
6 changes: 6 additions & 0 deletions frame/election-provider-support/src/traits.rs
Original file line number Diff line number Diff line change
Expand Up @@ -123,3 +123,9 @@ where
target_at: impl Fn(Self::TargetIndex) -> Option<A>,
) -> Result<Vec<Assignment<A, Self::Accuracy>>, Error>;
}

/// A type that calculates the deposit base for signed election submissions.
pub trait DepositBase<Balance> {
/// Returns the value of the deposit base given a number of queued signed solutions.
fn calculate(queue_len: usize) -> Balance;
}