-
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
Migrating salary pallet to use umbrella crate #7048
Changes from 13 commits
1bf72c4
81ef8c3
12b5035
9b5c229
6a6a009
b015e26
53675b3
3291d1e
3dc4d8b
bf3302b
5397c4c
8db080b
c0b15a1
b8c1985
52a019b
f1e1408
023c3fe
6e83954
eeb1fc5
e539109
efeb7e6
3f30ef6
4595acf
49fb576
63b251c
8da372e
a2cf833
dcf3995
5900660
b427d2a
557bc71
de1b02f
4399f35
ae9b6e2
22ff507
9302fdc
e472261
9116f5a
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
# Schema: Polkadot SDK PRDoc Schema (prdoc) v1.0.0 | ||
# See doc at https://raw.githubusercontent.com/paritytech/polkadot-sdk/master/prdoc/schema_user.json | ||
|
||
title: '[pallet-salary] Migrate to using frame umbrella crate' | ||
|
||
doc: | ||
- audience: Runtime Dev | ||
description: | ||
This PR migrates the pallet-salary to use the frame umbrella crate. | ||
This is part of the ongoing effort to migrate all pallets to use the frame umbrella crate. | ||
The effort is tracked [here](https://github.com/paritytech/polkadot-sdk/issues/6504). | ||
|
||
|
||
crates: | ||
- name: pallet-salary | ||
bump: minor | ||
- name: polkadot-sdk-frame | ||
bump: minor | ||
- name: traits-misc | ||
bump: minor | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -17,43 +17,22 @@ targets = ["x86_64-unknown-linux-gnu"] | |
|
||
[dependencies] | ||
codec = { features = ["derive"], workspace = true } | ||
frame-benchmarking = { optional = true, workspace = true } | ||
frame-support = { workspace = true } | ||
frame-system = { workspace = true } | ||
log = { workspace = true } | ||
pallet-ranked-collective = { optional = true, workspace = true } | ||
scale-info = { features = ["derive"], workspace = true } | ||
sp-arithmetic = { workspace = true } | ||
sp-core = { workspace = true } | ||
sp-io = { workspace = true } | ||
sp-runtime = { workspace = true } | ||
frame = { workspace = true, features = ["experimental", "runtime"] } | ||
|
||
[features] | ||
default = ["std"] | ||
std = [ | ||
"codec/std", | ||
"frame-benchmarking?/std", | ||
"frame-support/experimental", | ||
"frame-support/std", | ||
"frame-system/std", | ||
"log/std", | ||
"pallet-ranked-collective/std", | ||
"scale-info/std", | ||
"sp-arithmetic/std", | ||
"sp-core/std", | ||
"sp-io/std", | ||
"sp-runtime/std", | ||
"codec/std", | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The taplo workflow is failing indicating that the formatting is indeed not needed / incorrect here. You need to check all failed workflows before merging. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. taplo workflow is failing yes, but not for this file. let me revert it anyway, to a version before the taplo format |
||
"log/std", | ||
"pallet-ranked-collective/std", | ||
"scale-info/std", | ||
"frame/std", | ||
] | ||
runtime-benchmarks = [ | ||
"frame-benchmarking/runtime-benchmarks", | ||
"frame-support/runtime-benchmarks", | ||
"frame-system/runtime-benchmarks", | ||
"pallet-ranked-collective/runtime-benchmarks", | ||
"sp-runtime/runtime-benchmarks", | ||
] | ||
try-runtime = [ | ||
"frame-support/try-runtime", | ||
"frame-system/try-runtime", | ||
"pallet-ranked-collective?/try-runtime", | ||
"sp-runtime/try-runtime", | ||
"pallet-ranked-collective/runtime-benchmarks", | ||
"frame/runtime-benchmarks", | ||
] | ||
try-runtime = ["pallet-ranked-collective?/try-runtime", "frame/try-runtime"] |
Original file line number | Diff line number | Diff line change | ||
---|---|---|---|---|
|
@@ -19,16 +19,11 @@ | |||
|
||||
#![cfg_attr(not(feature = "std"), no_std)] | ||||
|
||||
use codec::{Decode, Encode, MaxEncodedLen}; | ||||
use core::marker::PhantomData; | ||||
use scale_info::TypeInfo; | ||||
use sp_arithmetic::traits::{Saturating, Zero}; | ||||
use sp_runtime::{Perbill, RuntimeDebug}; | ||||
|
||||
use frame_support::{ | ||||
defensive, | ||||
dispatch::DispatchResultWithPostInfo, | ||||
ensure, | ||||
|
||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. personal nits, separating imports in categories is a not needed overhead IMHO.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Automatic change by fmt There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The trick is that if you don't have any extra newlines between |
||||
use frame::{ | ||||
arithmetic::Perbill, | ||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Arithmetic is already in prelude. - arithmetic::Perbill, |
||||
prelude::*, | ||||
traits::{ | ||||
tokens::{GetSalary, Pay, PaymentStatus}, | ||||
RankedMembers, RankedMembersSwapHandler, | ||||
|
@@ -85,11 +80,9 @@ pub struct ClaimantStatus<CycleIndex, Balance, Id> { | |||
status: ClaimState<Balance, Id>, | ||||
} | ||||
|
||||
#[frame_support::pallet] | ||||
#[frame::pallet] | ||||
pub mod pallet { | ||||
use super::*; | ||||
use frame_support::{dispatch::Pays, pallet_prelude::*}; | ||||
use frame_system::pallet_prelude::*; | ||||
|
||||
#[pallet::pallet] | ||||
pub struct Pallet<T, I = ()>(PhantomData<(T, I)>); | ||||
|
@@ -460,15 +453,15 @@ impl<T: Config<I>, I: 'static> | |||
) { | ||||
if who == new_who { | ||||
defensive!("Should not try to swap with self"); | ||||
return | ||||
return; | ||||
} | ||||
if Claimant::<T, I>::contains_key(new_who) { | ||||
defensive!("Should not try to overwrite existing claimant"); | ||||
return | ||||
return; | ||||
} | ||||
|
||||
let Some(claimant) = Claimant::<T, I>::take(who) else { | ||||
frame_support::defensive!("Claimant should exist when swapping"); | ||||
defensive!("Claimant should exist when swapping"); | ||||
return; | ||||
}; | ||||
|
||||
|
Original file line number | Diff line number | Diff line change | ||
---|---|---|---|---|
|
@@ -19,25 +19,21 @@ | |||
|
||||
use crate as pallet_salary; | ||||
use crate::*; | ||||
use frame_support::{ | ||||
assert_noop, assert_ok, derive_impl, hypothetically, | ||||
pallet_prelude::Weight, | ||||
parameter_types, | ||||
traits::{ConstU64, EitherOf, MapSuccess, NoOpPoll}, | ||||
|
||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||
use frame::{ | ||||
deps::{ | ||||
sp_io::{self, MultiRemovalResults}, | ||||
sp_runtime, | ||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why do you need
|
||||
}, | ||||
testing_prelude::*, | ||||
seemantaggarwal marked this conversation as resolved.
Show resolved
Hide resolved
|
||||
}; | ||||
use pallet_ranked_collective::{EnsureRanked, Geometric}; | ||||
use sp_core::{ConstU16, Get}; | ||||
use sp_runtime::{ | ||||
traits::{Convert, ReduceBy, ReplaceWithDefault}, | ||||
BuildStorage, | ||||
}; | ||||
|
||||
type Rank = u16; | ||||
type Block = frame_system::mocking::MockBlock<Test>; | ||||
|
||||
frame_support::construct_runtime!( | ||||
pub enum Test | ||||
{ | ||||
construct_runtime!( | ||||
pub struct Test { | ||||
System: frame_system, | ||||
Salary: pallet_salary, | ||||
Club: pallet_ranked_collective, | ||||
|
@@ -145,9 +141,9 @@ impl pallet_ranked_collective::Config for Test { | |||
type BenchmarkSetup = Salary; | ||||
} | ||||
|
||||
pub fn new_test_ext() -> sp_io::TestExternalities { | ||||
pub fn new_test_ext() -> TestState { | ||||
let t = frame_system::GenesisConfig::<Test>::default().build_storage().unwrap(); | ||||
let mut ext = sp_io::TestExternalities::new(t); | ||||
let mut ext = TestState::new(t); | ||||
ext.execute_with(|| System::set_block_number(1)); | ||||
ext | ||||
} | ||||
|
Original file line number | Diff line number | Diff line change | ||
---|---|---|---|---|
|
@@ -20,20 +20,14 @@ | |||
use std::collections::BTreeMap; | ||||
|
||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||
use core::cell::RefCell; | ||||
use frame_support::{ | ||||
assert_noop, assert_ok, derive_impl, | ||||
pallet_prelude::Weight, | ||||
parameter_types, | ||||
traits::{tokens::ConvertRank, ConstU64}, | ||||
}; | ||||
use sp_runtime::{traits::Identity, BuildStorage, DispatchResult}; | ||||
use frame::testing_prelude::*; | ||||
|
||||
use crate as pallet_salary; | ||||
use crate::*; | ||||
|
||||
type Block = frame_system::mocking::MockBlock<Test>; | ||||
type Block = MockBlock<Test>; | ||||
|
||||
frame_support::construct_runtime!( | ||||
construct_runtime!( | ||||
pub enum Test | ||||
{ | ||||
System: frame_system, | ||||
|
@@ -124,7 +118,7 @@ impl RankedMembers for TestClub { | |||
} | ||||
fn demote(who: &Self::AccountId) -> DispatchResult { | ||||
CLUB.with(|club| match club.borrow().get(who) { | ||||
None => Err(sp_runtime::DispatchError::Unavailable), | ||||
None => Err(DispatchError::Unavailable), | ||||
Some(&0) => { | ||||
club.borrow_mut().remove(&who); | ||||
Ok(()) | ||||
|
@@ -156,9 +150,9 @@ impl Config for Test { | |||
type Budget = Budget; | ||||
} | ||||
|
||||
pub fn new_test_ext() -> sp_io::TestExternalities { | ||||
pub fn new_test_ext() -> TestState { | ||||
let t = frame_system::GenesisConfig::<Test>::default().build_storage().unwrap(); | ||||
let mut ext = sp_io::TestExternalities::new(t); | ||||
let mut ext = TestState::new(t); | ||||
ext.execute_with(|| System::set_block_number(1)); | ||||
ext | ||||
} | ||||
|
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -203,8 +203,12 @@ pub mod prelude { | |
/// Dispatch types from `frame-support`, other fundamental traits | ||
#[doc(no_inline)] | ||
pub use frame_support::dispatch::{GetDispatchInfo, PostDispatchInfo}; | ||
pub use frame_support::traits::{ | ||
Contains, EstimateNextSessionRotation, IsSubType, OnRuntimeUpgrade, OneSessionHandler, | ||
pub use frame_support::{ | ||
defensive, defensive_assert, | ||
traits::{ | ||
tokens::ConvertRank, Contains, EitherOf, EstimateNextSessionRotation, IsSubType, | ||
MapSuccess, NoOpPoll, OnRuntimeUpgrade, OneSessionHandler, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I am not sure There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Our rule here from other reviews was that if a trait is used in 3 or more pallets, it can be in prelude, if not directly imported in the migration. |
||
}, | ||
}; | ||
|
||
/// Pallet prelude of `frame-system`. | ||
|
@@ -228,11 +232,10 @@ pub mod prelude { | |
/// Runtime traits | ||
#[doc(no_inline)] | ||
pub use sp_runtime::traits::{ | ||
BlockNumberProvider, Bounded, DispatchInfoOf, Dispatchable, SaturatedConversion, | ||
Saturating, StaticLookup, TrailingZeroInput, | ||
BlockNumberProvider, Bounded, Convert, DispatchInfoOf, Dispatchable, ReduceBy, | ||
ReplaceWithDefault, SaturatedConversion, Saturating, StaticLookup, TrailingZeroInput, | ||
}; | ||
|
||
/// Other runtime types and traits | ||
/// Other error/result types for runtime | ||
#[doc(no_inline)] | ||
pub use sp_runtime::{ | ||
BoundToRuntimeAppPublic, DispatchErrorWithPostInfo, DispatchResultWithInfo, TokenError, | ||
|
@@ -319,7 +322,7 @@ pub mod testing_prelude { | |
/// Other helper macros from `frame_support` that help with asserting in tests. | ||
pub use frame_support::{ | ||
assert_err, assert_err_ignore_postinfo, assert_error_encoded_size, assert_noop, assert_ok, | ||
assert_storage_noop, storage_alias, | ||
assert_storage_noop, construct_runtime, storage_alias, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Are you sure There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. +1, it is also there in |
||
}; | ||
|
||
pub use frame_system::{self, mocking::*}; | ||
|
@@ -505,7 +508,7 @@ pub mod runtime { | |
#[cfg(feature = "std")] | ||
pub mod testing_prelude { | ||
pub use sp_core::storage::Storage; | ||
pub use sp_runtime::BuildStorage; | ||
pub use sp_runtime::{BuildStorage, DispatchError::Unavailable}; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I am not sure There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. thanks for the comments @gui1117 I added a new commit for PRdoc, can you re review? additionally, for the current pallet only Unavailable was needed, I can have a separate PR for modifying this There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah, I do think it is a bit too much to import enum If a code wants to use Please add this (among other guidelines) to |
||
} | ||
} | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -66,15 +66,15 @@ impl<T: VariantCount> Get<u32> for VariantCountOf<T> { | |
#[macro_export] | ||
macro_rules! defensive { | ||
() => { | ||
frame_support::__private::log::error!( | ||
$crate::__private::log::error!( | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. very good! |
||
target: "runtime::defensive", | ||
"{}", | ||
$crate::traits::DEFENSIVE_OP_PUBLIC_ERROR | ||
); | ||
debug_assert!(false, "{}", $crate::traits::DEFENSIVE_OP_INTERNAL_ERROR); | ||
}; | ||
($error:expr $(,)?) => { | ||
frame_support::__private::log::error!( | ||
$crate::__private::log::error!( | ||
target: "runtime::defensive", | ||
"{}: {:?}", | ||
$crate::traits::DEFENSIVE_OP_PUBLIC_ERROR, | ||
|
@@ -83,7 +83,7 @@ macro_rules! defensive { | |
debug_assert!(false, "{}: {:?}", $crate::traits::DEFENSIVE_OP_INTERNAL_ERROR, $error); | ||
}; | ||
($error:expr, $proof:expr $(,)?) => { | ||
frame_support::__private::log::error!( | ||
$crate::__private::log::error!( | ||
target: "runtime::defensive", | ||
"{}: {:?}: {:?}", | ||
$crate::traits::DEFENSIVE_OP_PUBLIC_ERROR, | ||
|
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 shouldn't change the indentation here, it also makes it harder to review. Probably it's a matter of the toml formatter you set up
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.
yup this is from taplo format