-
Notifications
You must be signed in to change notification settings - Fork 798
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
Add BlockNumberProvider to salary pallet config #7000
base: master
Are you sure you want to change the base?
Add BlockNumberProvider to salary pallet config #7000
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me, with the pre and post upgrade implementation
cumulus/parachains/runtimes/collectives/collectives-westend/Cargo.toml
Outdated
Show resolved
Hide resolved
cumulus/parachains/runtimes/collectives/collectives-westend/src/lib.rs
Outdated
Show resolved
Hide resolved
where | ||
BC: ConvertBlockNumber<LocalBlockNumberFor<T>, NewBlockNumberFor<T, I>>, | ||
{ | ||
fn on_runtime_upgrade() -> frame_support::weights::Weight { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could be better to implement some pre_upgrade
and post_upgrade
ensuring that Status
value is some if it was some, and claimant count is same before and after the migration.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added. Though out of curiosity, is it possible for this not to be the case given the on_runtime_upgrade code? May be missing something about rust or substrate here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You mean it is impossible that something is missed here?
Yes I think the code is good. But sometimes when a type is wrong, then the take
function can't actually decode the value, then the upgrade could silently do nothing. It is just to be extra careful.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks very clean, thanks. Only had some minor comments, going to take a closer look after that.
cumulus/parachains/runtimes/collectives/collectives-westend/src/lib.rs
Outdated
Show resolved
Hide resolved
@@ -177,7 +177,7 @@ pub const VERSION: RuntimeVersion = RuntimeVersion { | |||
// implementation changes and behavior does not, then leave spec_version as | |||
// is and increment impl_version. | |||
spec_version: 268, | |||
impl_version: 0, | |||
impl_version: 1, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
impl_version: 1, | |
impl_version: 0, |
The kitchensink runtime needs to bumping.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The kitchensink runtime needs to bumping.
Assuming 'no' bumping was meant - is this because its also bumped automatically on release like the spec_version or because the change to the runtime was sufficient to warrant a bump?
In any case, will revert. Just curious!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
impl_version
is when it is a change in the code without a change in the specification in the runtime.
I guess, both spec_version
and impl_version
will be bumped automatically using the prdoc information, but I can't confirm
use super::{BlockNumberFor as NewBlockNumberFor, *}; | ||
use frame_system::pallet_prelude::BlockNumberFor as LocalBlockNumberFor; | ||
|
||
/// Converts previous (local) block number into the new one. May just be identity functions |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
/// Converts previous (local) block number into the new one. May just be identity functions | |
/// Converts old block number into the new one. May just be identity functions |
Is there an inherent local/remote duality, or is it just old/new?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Inherent local -> whatever you've now decided (new)
In the context of this migration because the salary pallet previously did not allow selection of a block provider, it defaulted to frame_system's, which is always local I believe. However, @gui1117 did point out this code may be copy pasted so if you think generalizing it is best, I can make the change 👍 Just let me know.
EDIT: Upon thinking on this, and looking forward towards #6297 and Tracking list, I think it'd be best to both generalize this and move it down the dep tree into frame-support::migrations. Though I would suggest I do this in a followup PR.
/// | ||
/// For instance - if your new version uses the relay chain number, you'll want to | ||
/// use relay current - ((current local - local) * equivalent_block_duration) | ||
fn equivalent_moment_in_time(local: L) -> N; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you put some example in the doc of this please? Just some pseudo code of how it is supposed to be called.
I can imagine it is easy to call it the other way around of how its meant to be 🙈
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Have updated the docs for each function. Let me know if sufficient
Fixing some errors, hold off on re-review EDIT: Alright should be good to go now 👍 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me
@@ -42,15 +45,15 @@ pub type Cycle = u32; | |||
#[derive(Encode, Decode, Eq, PartialEq, Clone, TypeInfo, MaxEncodedLen, RuntimeDebug)] | |||
pub struct StatusType<CycleIndex, BlockNumber, Balance> { | |||
/// The index of the "current cycle" (i.e. the last cycle being processed). | |||
cycle_index: CycleIndex, | |||
pub cycle_index: CycleIndex, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
as a note we could have used pub(crate)
Following #3617, salary pallet is to be made async backing friendly. This PR adds the block number provider config parameter to pallet-salary.
In addition it
TODO:
Once Westend is updated I will write the migration for polkadot collectives.
@xlc
@gupnik Tracking list