Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adds multi-block election types and refactors current pallets to support new interfaces and types #6034

Open
wants to merge 86 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
86 commits
Select commit Hold shift + click to select a range
3f6bf3f
init: adds EPM-MB, multipaged types and primitives
gpestana Oct 13, 2024
8a682b8
refactors staking pallet with new paginated types
gpestana Oct 13, 2024
94ff073
refactors election-multiphase pallet with new paginated types
gpestana Oct 13, 2024
1527bd6
nits for dependent pallets and runtimes
gpestana Oct 13, 2024
5cb1de1
adds ElectionProvider::ongoing to trait and impls
gpestana Oct 14, 2024
50d9698
Merge branch 'master' into gpestana/epm-mb
Ank4n Oct 15, 2024
43eec4b
clean up sp-staking
gpestana Oct 18, 2024
11dd785
clean up and rustdoc for epm-support
gpestana Oct 18, 2024
d446ed0
Merge branch 'gpestana/epm-mb' of github.com:paritytech/polkadot-sdk …
gpestana Oct 18, 2024
5c17573
nits onchain election provider
gpestana Oct 18, 2024
ee7bdd4
EPM nits and rustdoc improvements
gpestana Oct 18, 2024
f30b548
clean up and rustdocs for EPM core and sub pallets
gpestana Oct 18, 2024
e7bf7dc
rustdocs and nits
gpestana Oct 18, 2024
f810692
Merge branch 'master' into gpestana/epm-mb
gpestana Oct 18, 2024
bf67a3e
adds prdoc
gpestana Oct 18, 2024
345840d
fixes prdoc
gpestana Oct 18, 2024
52dcee9
removes from all pallets
gpestana Oct 18, 2024
6d506e2
Adds new tests for verifier pallet
gpestana Oct 18, 2024
430532a
implements hold logic in signed pallet; finishes implementing bail call
gpestana Oct 19, 2024
068e0fd
finishes signed pallet
gpestana Oct 21, 2024
5ca0bab
Merge branch 'master' into gpestana/epm-mb-merge
gpestana Oct 22, 2024
385500d
updates inherent call in unsigned phase to new interfaces
gpestana Oct 22, 2024
b4019bb
licence header nit
gpestana Oct 22, 2024
9f30e2d
Merge branch 'master' into gpestana/epm-mb
gpestana Oct 23, 2024
82abba1
removes epm-mb
gpestana Oct 24, 2024
1034653
nit fix in bags list remote tests
gpestana Oct 24, 2024
7248960
nit fix prdoc
gpestana Oct 24, 2024
18813c9
Merge branch 'master' into gpestana/epm-mb
gpestana Oct 25, 2024
a92d44a
Addresses PR reviews (removes all paged types/configs from epm and nits)
gpestana Oct 25, 2024
3d1a330
improve memory efficiency of try into bounded supports; tests
gpestana Oct 25, 2024
1757c91
a few nits in the staking pallet; handles exposures better (do not le…
gpestana Oct 28, 2024
7022467
updates electable stashes to allow for multiple adds across pages
gpestana Nov 1, 2024
b49684e
Adds staking pallet rustdocs; nits
gpestana Nov 1, 2024
7851c6e
Refactors the snapshot cursors of staking pallet and adds more tests
gpestana Nov 5, 2024
3ff9914
Adds e2e tests to staking pallet
gpestana Nov 7, 2024
bc7b200
adds exposure collection checks to multi page election tests
gpestana Nov 7, 2024
2e71ab2
EPM-MB: Supports only single page target snapshot (#6414)
gpestana Nov 8, 2024
e9854fc
Adds try-state checks for election prep metadata and tests
gpestana Nov 8, 2024
9f4b6a3
more tests
gpestana Nov 11, 2024
612886f
Merge branch 'master' into gpestana/epm-mb
gpestana Nov 12, 2024
fb31d1b
".git/.scripts/commands/fmt/fmt.sh"
Nov 12, 2024
01e09c6
Update substrate/frame/election-provider-multi-phase/src/lib.rs
gpestana Nov 12, 2024
b4c900c
Update substrate/frame/election-provider-multi-phase/src/lib.rs
gpestana Nov 12, 2024
628ae67
Update prdoc/pr_6034.prdoc
gpestana Nov 12, 2024
d05a002
Update substrate/frame/staking/src/lib.rs
gpestana Nov 12, 2024
07796d9
Update substrate/frame/staking/src/lib.rs
gpestana Nov 12, 2024
23b9c21
Update substrate/frame/election-provider-multi-phase/src/lib.rs
gpestana Nov 12, 2024
2570c23
Update substrate/frame/election-provider-multi-phase/src/lib.rs
gpestana Nov 12, 2024
808e2ba
Update substrate/frame/election-provider-multi-phase/src/lib.rs
gpestana Nov 12, 2024
2092d2c
Update substrate/frame/election-provider-multi-phase/src/unsigned.rs
gpestana Nov 12, 2024
f2fe960
Update substrate/frame/election-provider-support/src/onchain.rs
gpestana Nov 12, 2024
bca81c2
Update substrate/frame/election-provider-support/src/lib.rs
gpestana Nov 12, 2024
df729a0
addresses PR review comments
gpestana Nov 12, 2024
0774cc4
Merge branch 'master' into gpestana/epm-mb
gpestana Nov 12, 2024
51329d7
ensures only collected electable stashes have exposures collectede
gpestana Nov 12, 2024
64d3ab3
comment nits
gpestana Nov 12, 2024
2082723
adds type alias to ensure bounds are in order
gpestana Nov 12, 2024
d720e5a
integrity test
gpestana Nov 12, 2024
a88361a
Update substrate/frame/election-provider-multi-phase/src/lib.rs
gpestana Nov 12, 2024
ea5aa9e
Update substrate/frame/election-provider-multi-phase/src/lib.rs
gpestana Nov 12, 2024
d140b1f
removes the lockable election provider and other nits
gpestana Nov 12, 2024
d64068b
Merge branch 'gpestana/epm-mb' of github.com:paritytech/polkadot-sdk …
gpestana Nov 12, 2024
1a2ddfc
removes unecessary last_page_empty_slots
gpestana Nov 13, 2024
2117056
docs and tests for exposures.split_others
gpestana Nov 14, 2024
e568248
Merge branch 'master' into gpestana/epm-mb
gpestana Nov 14, 2024
83c7288
nits and removes sp-std dependency from staking primitives
gpestana Nov 14, 2024
6705e0f
Update substrate/frame/election-provider-multi-phase/src/lib.rs
gpestana Nov 14, 2024
4e13e4f
Update prdoc/pr_6034.prdoc
gpestana Nov 14, 2024
825984b
fixes epm test case
gpestana Nov 14, 2024
93d6bda
removes TryIntoBoundedSupports trait and impl coversion directly in S…
gpestana Nov 14, 2024
69b38e5
Adds max backers per winner bounds check in the phragmen implementati…
gpestana Nov 14, 2024
f6be182
Merge branch 'master' into gpestana/epm-mb
gpestana Nov 22, 2024
442a64e
Merge branch 'master' into gpestana/epm-mb
gpestana Dec 3, 2024
e43e885
addresses PR comments
gpestana Dec 3, 2024
676db53
Revert "Adds max backers per winner bounds check in the phragmen impl…
gpestana Dec 3, 2024
fe8b9ae
adds max backers per winner trimming test
gpestana Dec 3, 2024
84eea26
Ensures max backers per winner bounds are met in Staking miner (#6771)
gpestana Dec 5, 2024
4788579
fixes overflowing tests
gpestana Dec 9, 2024
b792a6d
adds benchs and nits
gpestana Dec 11, 2024
61ef83e
Merge branch 'master' into gpestana/epm-mb
gpestana Dec 11, 2024
5ce51ea
pr review refactors and improvements
gpestana Dec 11, 2024
39e5c3d
improves add_electables and tests
gpestana Dec 11, 2024
65cf87f
improves add_electables
gpestana Dec 11, 2024
7d33c5c
remove unecessary cloning
gpestana Dec 12, 2024
d7817e0
migrations
gpestana Dec 17, 2024
0edb158
Merge branch 'master' into gpestana/epm-mb
gpestana Dec 17, 2024
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
a few nits in the staking pallet; handles exposures better (do not le…
…ave exposure gaps in pages)
  • Loading branch information
gpestana committed Oct 31, 2024
commit 1757c91631f31291f962b279366208dd312c043e
117 changes: 82 additions & 35 deletions substrate/frame/staking/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -352,10 +352,12 @@ macro_rules! log {
/// config.
pub type MaxWinnersOf<T> = <T as Config>::MaxValidatorSet;

/// Maximum number of exposures (validators) that each page of [`Config::ElectionProvider`] might
/// might return.
pub type MaxExposuresPerPageOf<T> =
<<T as Config>::ElectionProvider as ElectionProvider>::MaxWinnersPerPage;
/// Maximum number of exposures that can fit into an exposure page, as defined by this pallet's
/// config.
/// TODO: needed? maybe use the type directly.
pub type MaxExposuresPerPageOf<T> = <T as Config>::MaxExposurePageSize;

pub type MaxWinnersPerPageOf<P> = <P as ElectionProvider>::MaxWinnersPerPage;

/// Maximum number of nominations per nominator.
pub type MaxNominationsOf<T> =
Expand Down Expand Up @@ -787,6 +789,8 @@ impl<AccountId, Balance: HasCompact + Copy + AtLeast32BitUnsigned + codec::MaxEn
own: exposure.own,
nominator_count: exposure.others.len() as u32,
page_count: 1,
// set to default for legacy compat.
last_page_empty_slots: Default::default(),
gpestana marked this conversation as resolved.
Show resolved Hide resolved
},
exposure_page: ExposurePage { page_total: exposure.total, others: exposure.others },
}
Expand Down Expand Up @@ -1251,45 +1255,88 @@ impl<T: Config> EraInfo<T> {
}

/// Store exposure for elected validators at start of an era.
pub fn set_exposure(
///
/// If the exposure does not exist yet for the tuple (era, validator), it sets it. Otherwise,
/// it updates the existing record by ensuring *intermediate* exposure pages are filled up with
/// `T::MaxExposurePageSize` number of backiers per page.
gpestana marked this conversation as resolved.
Show resolved Hide resolved
pub fn upsert_exposure(
era: EraIndex,
validator: &T::AccountId,
exposure: Exposure<T::AccountId, BalanceOf<T>>,
mut exposure: Exposure<T::AccountId, BalanceOf<T>>,
) {
let page_size = T::MaxExposurePageSize::get().defensive_max(1);

let nominator_count = exposure.others.len();
// expected page count is the number of nominators divided by the page size, rounded up.
let expected_page_count = nominator_count
.defensive_saturating_add((page_size as usize).defensive_saturating_sub(1))
.saturating_div(page_size as usize);

let (exposure_metadata, exposure_pages) = exposure.into_pages(page_size);
defensive_assert!(exposure_pages.len() == expected_page_count, "unexpected page count");

// insert or update validator's overview.
let append_from = ErasStakersOverview::<T>::mutate(era, &validator, |stored| {
if let Some(stored_overview) = stored {
let append_from = stored_overview.page_count;
*stored = Some(stored_overview.merge(exposure_metadata));
append_from
} else {
*stored = Some(exposure_metadata);
Zero::zero()
}
});

exposure_pages.iter().enumerate().for_each(|(idx, paged_exposure)| {
let append_at = (append_from + idx as u32) as Page;
<ErasStakersPaged<T>>::insert((era, &validator, append_at), &paged_exposure);
});
}
if let Some(stored_overview) = ErasStakersOverview::<T>::get(era, &validator) {
let exposures_append = exposure.split_others(stored_overview.last_page_empty_slots);
let last_page_idx = stored_overview.page_count.saturating_sub(1);

let last_page_idx = ErasStakersOverview::<T>::mutate(era, &validator, |stored| {
// new metadata is updated based on 3 different set of exposures: the
// current one, the exposure split to be "fitted" into the current last page and
// the exposure set that will be appended from the new page onwards.
let new_metadata =
stored.defensive_unwrap_or_default().update_with::<T::MaxExposurePageSize>(
[&exposures_append, &exposure]
.iter()
.fold(Default::default(), |total, expo| {
total.saturating_add(expo.total.saturating_sub(expo.own))
}),
[&exposures_append, &exposure]
.iter()
.fold(Default::default(), |count, expo| {
count.saturating_add(expo.others.len() as u32)
}),
);
*stored = new_metadata.into();

last_page_idx
});

/// Store total exposure for all the elected validators in the era.
pub(crate) fn set_total_stake(era: EraIndex, total_stake: BalanceOf<T>) {
<ErasTotalStake<T>>::insert(era, total_stake);
// fill up last page with exposures.
let mut last_page =
ErasStakersPaged::<T>::get((era, validator, last_page_idx)).unwrap_or_default();

last_page.page_total = last_page
.page_total
.saturating_add(exposures_append.total)
.saturating_sub(exposures_append.own);
last_page.others.extend(exposures_append.others);
ErasStakersPaged::<T>::insert((era, &validator, last_page_idx), last_page);

// now handle the remainig exposures and append the exposure pages. The metadata update
gpestana marked this conversation as resolved.
Show resolved Hide resolved
// has been already handled above.
let (_, exposure_pages) = exposure.into_pages(page_size);

exposure_pages.iter().enumerate().for_each(|(idx, paged_exposure)| {
let append_at =
(last_page_idx.saturating_add(1).saturating_add(idx as u32)) as Page;
<ErasStakersPaged<T>>::insert((era, &validator, append_at), &paged_exposure);
});
} else {
// expected page count is the number of nominators divided by the page size, rounded up.
let expected_page_count = exposure
.others
.len()
.defensive_saturating_add((page_size as usize).defensive_saturating_sub(1))
.saturating_div(page_size as usize);

// no exposures yet for this (era, validator) tuple, calculate paged exposure pages and
// metadata from a blank slate.
let (exposure_metadata, exposure_pages) = exposure.into_pages(page_size);
defensive_assert!(exposure_pages.len() == expected_page_count, "unexpected page count");

// insert metadata.
ErasStakersOverview::<T>::insert(era, &validator, exposure_metadata);

// insert or update validator's overview.
exposure_pages.iter().enumerate().for_each(|(idx, paged_exposure)| {
let append_at = idx as Page;
<ErasStakersPaged<T>>::insert((era, &validator, append_at), &paged_exposure);
});
};
}

/// Update the total exposure for all the elected validators in the era.
pub(crate) fn add_total_stake(era: EraIndex, stake: BalanceOf<T>) {
<ErasTotalStake<T>>::mutate(era, |total_stake| {
*total_stake += stake;
Expand Down
3 changes: 2 additions & 1 deletion substrate/frame/staking/src/mock.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@
use crate::{self as pallet_staking, *};
use frame_election_provider_support::{
bounds::{ElectionBounds, ElectionBoundsBuilder},
onchain, BoundedSupports, SequentialPhragmen, Support, TryIntoBoundedSupports, VoteWeight,
onchain, BoundedSupports, ElectionProvider, SequentialPhragmen, Support,
TryIntoBoundedSupports, VoteWeight,
};
use frame_support::{
assert_ok, derive_impl, ord_parameter_types, parameter_types,
Expand Down
Loading