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

Upgrade to latest polkadot-sdk@1.6 release #159

Merged
merged 137 commits into from
Feb 27, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
137 commits
Select commit Hold shift + click to select a range
c1cec95
Upgrade to latest: `cargo upgrade -v --pinned --incompatible`
bkontur Jan 9, 2024
93f136b
[FeeManager] fix for XcmFeesToAccount
bkontur Jan 9, 2024
3c88719
[pallet_identity] adapt https://github.com/paritytech/polkadot-sdk/pu…
bkontur Jan 9, 2024
fd6bffa
[pallet_staking] removed benchmark `payout_stakers_dead_controller`
bkontur Jan 9, 2024
41fd521
[pallet_nomination_pools] change import `versioned_migrations` to `ve…
bkontur Jan 9, 2024
aef83c9
[pallet_staking] adapt https://github.com/paritytech/polkadot-sdk/pul…
bkontur Jan 9, 2024
53f6f9e
[pallet-staking] adapt https://github.com/paritytech/polkadot-sdk/pul…
bkontur Jan 10, 2024
68f77f8
[runtime_api::ParachainHost] removed `Hash, BlockNumber` types
bkontur Jan 9, 2024
e23218f
[pallet_nomination_pools] adapt https://github.com/paritytech/polkado…
bkontur Jan 10, 2024
045deca
[pallet-vesting] adapt https://github.com/paritytech/polkadot-sdk/pul…
bkontur Jan 10, 2024
0e32f9f
[ParachainHost] adapt https://github.com/paritytech/polkadot-sdk/pull…
bkontur Jan 10, 2024
3e19b99
[pallet_xcm] adapt https://github.com/paritytech/polkadot-sdk/pull/20…
bkontur Jan 10, 2024
a78ffe8
[pallet_xcm] adapt https://github.com/paritytech/polkadot-sdk/pull/16…
bkontur Jan 10, 2024
3449ef8
[pallet_xcm] adapt https://github.com/paritytech/polkadot-sdk/pull/23…
bkontur Jan 10, 2024
739170a
[pallet_collator_selection] adapt https://github.com/paritytech/polka…
bkontur Jan 10, 2024
a7a1cfc
[dmp,xcmp,message_queue] adapt https://github.com/paritytech/polkadot…
bkontur Jan 11, 2024
f7a557e
[simple-mermaid] bump
bkontur Jan 11, 2024
cb24674
[bridges] adapt https://github.com/paritytech/polkadot-sdk/pull/2602
bkontur Jan 11, 2024
ee13de8
[integration-tests] align integration tests with latest vogue + split…
bkontur Jan 12, 2024
1ccd0f7
chore: fmt for all
bkontur Jan 12, 2024
ca13c92
fix: "Warning: Error parsing Cargo.toml manifest, fallback to caching…
bkontur Jan 12, 2024
4b496df
fix: added `rust-src` to the stable toolchain components
bkontur Jan 12, 2024
e2564af
fix: added `rust-src` to check-migrations
bkontur Jan 13, 2024
e7c1da1
[migrations] added `cumulus_pallet_xcmp_queue::migration::v4::Migrati…
bkontur Jan 15, 2024
200f154
[migrations] `pallet_nomination_pools::migration::versioned::V7ToV8` …
bkontur Jan 15, 2024
5a13a8c
WIP: (DNM) Oliver's migration fix for `pallet-nominations-pools` (fix…
bkontur Jan 16, 2024
58e3ad8
[migrations] added `pallet_grandpa::migrations::MigrateV4ToV5<Runtime…
bkontur Jan 17, 2024
ab047b0
fix Cargo.lock after rebase
bkontur Jan 19, 2024
ce7edfa
[chain-specs] Updated relay+paras (except encointer)
bkontur Jan 22, 2024
dcee99c
[chain-specs] Updated encointer to `polkadot-sdk@1.5`
bkontur Jan 22, 2024
0196f28
Fix tests
bkontur Jan 22, 2024
6423781
Update relay/polkadot/src/lib.rs
bkontur Jan 22, 2024
70dbf93
Added CHANGELOG.md entry
bkontur Jan 23, 2024
97de24b
Removed `TODO:(PR#137)`
bkontur Jan 23, 2024
5b9047d
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Jan 25, 2024
f61c49b
Fix constants stuff after rebase
bkontur Jan 25, 2024
d1055fb
WIP: test final version of pallet-nomination-pools migration fix: htt…
bkontur Jan 26, 2024
85a3b8d
Fix constants stuff for Encointer (not compatible deps)
bkontur Jan 26, 2024
46e66de
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Jan 26, 2024
f1d0814
Merge branch 'main' into bko-bump-to-1.5
bkontur Jan 26, 2024
0a77426
Set the correct EDs of SPs for inegration-tests and chain-spec-builder
bkontur Jan 29, 2024
01ce707
Unneeded import
bkontur Jan 30, 2024
3568f3c
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 2, 2024
10883da
WIP: temporary disabled `TransactionalProcessor` - missing patch for …
bkontur Feb 2, 2024
2e4a790
nit
bkontur Feb 2, 2024
cbe2e0b
WIP: revert for encointer
bkontur Feb 2, 2024
597f9d6
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 3, 2024
7b52a6e
WIP: update TODOs with patch
bkontur Feb 5, 2024
7fc05c1
[bridges] Changed order/index for `MessageQueue` on BridgeHubs
bkontur Feb 6, 2024
767f903
Upgrade to latest polkadot@1.6.0: `cargo upgrade -v --pinned --incomp…
bkontur Jan 24, 2024
5a8595c
[frame_system] adapt https://github.com/paritytech/polkadot-sdk/pull/…
bkontur Jan 25, 2024
f36b197
[frame_system] adapt https://github.com/paritytech/polkadot-sdk/pull/…
bkontur Jan 25, 2024
7d03f8a
[asset_conversion] adapt https://github.com/paritytech/polkadot-sdk/p…
bkontur Jan 25, 2024
ded3fad
[asset_conversion] adapt https://github.com/paritytech/polkadot-sdk/p…
bkontur Jan 25, 2024
01bdd99
[bridges/xcm] adapt https://github.com/paritytech/polkadot-sdk/pull/2…
bkontur Jan 25, 2024
7796a1f
Cargo.lock
bkontur Jan 26, 2024
773ad07
[pallet_uniques] adapt https://github.com/paritytech/polkadot-sdk/pul…
bkontur Jan 29, 2024
c9a5b0b
[pallet_identity] adapt https://github.com/paritytech/polkadot-sdk/pu…
bkontur Jan 29, 2024
6fb51da
[pallet-vesting] adapt https://github.com/paritytech/polkadot-sdk/pul…
bkontur Jan 29, 2024
a10717d
[pallet-staking] adapt https://github.com/paritytech/polkadot-sdk/pul…
bkontur Jan 29, 2024
f139499
[pallet-election-provider-multi-phase] adapt https://github.com/parit…
bkontur Jan 29, 2024
b8dd1b9
[coretime] adapt https://github.com/paritytech/polkadot-sdk/pull/1694…
bkontur Jan 29, 2024
48f1255
[parachains_configuration] add `parachains_configuration::migration::…
bkontur Jan 29, 2024
e76af9b
[emulated-tests] Added `MessageOrigin` to SP chain definitions + fixes
bkontur Jan 30, 2024
1ba0c11
[xcm-builder] allow(deprecated) xcm_builder::CurrencyAdapter + TODO
bkontur Feb 12, 2024
3e55fe6
Finally patched `pallet-nomination-pools` + removed tmp migration
bkontur Feb 12, 2024
288f0a1
Finally patched `pallet-nomination-pools` + removed tmp migration
bkontur Feb 13, 2024
c6b16fa
[xcm-executor/builder] Patch with transactional fix
bkontur Feb 13, 2024
975c08d
Fix patch for penpal-runtime
bkontur Feb 13, 2024
be53230
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 13, 2024
e7dffea
[collectives] Removed older TODOs - addresing https://github.com/polk…
bkontur Feb 13, 2024
35f0e51
Merge remote-tracking branch 'origin/bko-bump-to-1.5' into bko-bump-t…
bkontur Feb 14, 2024
97f81f9
Updated TODO for removing DMPQueue
bkontur Feb 14, 2024
01d2344
[collectives-polkadot] Fixed benchmarks (expcept payout)
bkontur Feb 14, 2024
73af5ea
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 14, 2024
f82cc05
[bridges] Added code comment for `MessageExportPrice`
bkontur Feb 14, 2024
c2c7e8e
Merge remote-tracking branch 'origin/bko-bump-to-1.5' into bko-bump-t…
bkontur Feb 14, 2024
359dab8
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 14, 2024
2d6d3ac
chore(xcm): Replace deprecated CurrencyAdapter with FungibleAdapter
franciscoaguirre Feb 14, 2024
be4ceb4
chore(encointer): Remove ConstU64 import
franciscoaguirre Feb 15, 2024
3864204
chore: fmt
franciscoaguirre Feb 15, 2024
3bda4f8
Merge pull request #1 from franciscoaguirre/pr/159
bkontur Feb 15, 2024
012e57e
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 15, 2024
c624232
Added changelog
bkontur Feb 15, 2024
2b19718
Update relay/kusama/src/lib.rs
bkontur Feb 16, 2024
54e8b05
Update relay/polkadot/src/lib.rs
bkontur Feb 16, 2024
36e8020
[xcm] adapt https://github.com/paritytech/polkadot-sdk/pull/2422 (IsC…
bkontur Feb 16, 2024
44eefcc
[xcm] adapt https://github.com/paritytech/polkadot-sdk/pull/2428 (Par…
bkontur Feb 15, 2024
3170733
Change TreasuryArguments for collectives
bkontur Feb 16, 2024
a0a61ae
[bridges] Removed older TODO for bridges fees estimation
bkontur Feb 16, 2024
b987e8d
Updated TODOs
bkontur Feb 16, 2024
4cb2d2a
Update relay/kusama/src/lib.rs
bkontur Feb 16, 2024
c724e91
Update relay/polkadot/src/lib.rs
bkontur Feb 16, 2024
b6293a7
Update relay/polkadot/src/lib.rs
bkontur Feb 16, 2024
e3a80b5
Update relay/kusama/src/lib.rs
bkontur Feb 16, 2024
99bf501
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 19, 2024
996e199
upgrade encointer to 1.6.0
brenzi Feb 20, 2024
97f81a8
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 20, 2024
437115e
fix novelties
brenzi Feb 20, 2024
3d11911
[glutton-kusama] set `SystemWeightInfo` with unused weight `frame_sys…
bkontur Feb 21, 2024
1c9262a
fix accidental paste
brenzi Feb 21, 2024
620db80
[pallet-xcm-benchmarks] Apply patch 7.0.4
bkontur Feb 21, 2024
49e0e85
[cleaning] Removed unused stuff
bkontur Feb 21, 2024
81839b5
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 22, 2024
178592c
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 22, 2024
6bc0346
add migration for XcmpQueue pallet
brenzi Feb 23, 2024
b743b79
touch Cargo.lock
brenzi Feb 23, 2024
ff86df6
[pallet_asset_conversion] Fix correct value for MaxSwapPathLength (wh…
bkontur Feb 23, 2024
321578f
Tuples-96 feature.
Feb 23, 2024
8b59085
Add Broker para ID.
Feb 23, 2024
8ce508d
Enable coretime on Kusama.
Feb 23, 2024
7f83cd8
Add changelog entry.
Feb 23, 2024
5f39fc8
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 23, 2024
220a28c
Merge branch 'bko-bump-to-1.6' into rk-coretime
bkontur Feb 24, 2024
1bbbe73
Merge pull request #3 from eskimor/rk-coretime
bkontur Feb 24, 2024
7f848dd
Revert (Para)AssignmentProvider + remove TODO for Polkadot
bkontur Feb 24, 2024
be8ba38
Merge remote-tracking branch 'polkadot-fellows/main' into bko-bump-to…
bkontur Feb 24, 2024
5ab0968
Merge branch 'bko-bump-to-1.6-encointer' into ab/upgrade-polkadot-v1.6.0
bkontur Feb 26, 2024
bac111a
Merge pull request #2 from brenzi/ab/upgrade-polkadot-v1.6.0
bkontur Feb 26, 2024
af1de27
Accomadate Encointer
bkontur Feb 26, 2024
88e2f24
fnt
bkontur Feb 26, 2024
8ed52d8
More fixes
bkontur Feb 26, 2024
8cc5074
Replace CurrencyAdapter for FungibleAdapter
bkontur Feb 26, 2024
9490a1b
Removed `cumulus-primitives-timestamp` from Encointer
bkontur Feb 26, 2024
498d078
Fix taplo format for Cargo.toml for encointer
bkontur Feb 26, 2024
804bfc1
Revert new line
bkontur Feb 26, 2024
3a88996
Unify `IsTeleporter`
bkontur Feb 26, 2024
111f5c9
Add P<>K emulated bridge tests
acatangiu Feb 12, 2024
598ae51
fmt
bkontur Feb 26, 2024
06cd27b
Version nits
bkontur Feb 26, 2024
12fd695
Merge remote-tracking branch 'origin/bko-bump-to-1.6' into bko-bump-t…
bkontur Feb 26, 2024
ee69480
Forgotten new integration tests to the matrix
bkontur Feb 26, 2024
3319aba
Merge pull request #4 from bkontur/bko-bump-to-1.6-encointer
bkontur Feb 26, 2024
bbf7c5b
Replaced Encointer hack with fix to avoid potential collisions caused…
bkontur Feb 27, 2024
157788c
CI fix compilation for encointer?
bkontur Feb 27, 2024
5e336f6
Added `Based on Polkadot-SDK` to Changelog.md
bkontur Feb 27, 2024
359b9f8
Merge branch 'main' into bko-bump-to-1.6
fellowship-merge-bot[bot] Feb 27, 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
WIP: (DNM) Oliver's migration fix for pallet-nominations-pools (fix…
  • Loading branch information
bkontur committed Jan 23, 2024
commit 5a13a8cc9696d35fb552cfc419c911b9ac287009
209 changes: 206 additions & 3 deletions relay/kusama/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1685,11 +1685,15 @@ pub mod migrations {

/// Unreleased migrations. Add new ones here:
pub type Unreleased = (
pallet_nomination_pools::migration::versioned::V5toV6<Runtime>,
pallet_nomination_pools::migration::versioned::V6ToV7<Runtime>,
pallet_staking::migrations::v14::MigrateToV14<Runtime>,
parachains_configuration::migration::v10::MigrateToV10<Runtime>,
pallet_nomination_pools::migration::versioned::V7ToV8<Runtime>,
pallet_nomination_pools::migration::versioned::V5toV6<Runtime>,
// TODO:(PR#137) - replace with fixed/released version
crate::test_oliverfix_migration::V6ToV7<Runtime>,
// pallet_nomination_pools::migration::versioned::V6ToV7<Runtime>,
// TODO:(PR#137) - replace with fixed/released version
crate::test_oliverfix_migration::V7ToV8<Runtime>,
// pallet_nomination_pools::migration::versioned::V7ToV8<Runtime>,
);
}

Expand Down Expand Up @@ -2781,3 +2785,202 @@ mod init_state_migration {
}
}
}

// TODO:(PR#137) - replace with fixed/released version
mod test_oliverfix_migration {
use super::*;
use frame_support::{
traits::OnRuntimeUpgrade, DebugNoBound, RuntimeDebugNoBound, Twox64Concat,
};
use frame_system::pallet_prelude::BlockNumberFor;
use pallet_nomination_pools::*;
use sp_runtime::Saturating;

pub type V7ToV8<T> = frame_support::migrations::VersionedMigration<
7,
8,
v8::VersionUncheckedMigrateV7ToV8<T>,
pallet_nomination_pools::pallet::Pallet<T>,
<T as frame_system::Config>::DbWeight,
>;

pub type V6ToV7<T> = frame_support::migrations::VersionedMigration<
6,
7,
v7::VersionUncheckedMigrateV6ToV7<T>,
pallet_nomination_pools::pallet::Pallet<T>,
<T as frame_system::Config>::DbWeight,
>;

pub mod v8 {
use super::*;

use super::v7::BondedPoolInner as OldBondedPoolInner;

impl<T: Config> OldBondedPoolInner<T> {
fn migrate_to_v8(self) -> BondedPoolInner<T> {
BondedPoolInner {
commission: Commission {
current: self.commission.current,
max: self.commission.max,
change_rate: self.commission.change_rate,
throttle_from: self.commission.throttle_from,
// `claim_permission` is a new field.
claim_permission: None,
},
member_counter: self.member_counter,
points: self.points,
roles: self.roles,
state: self.state,
}
}
}

pub struct VersionUncheckedMigrateV7ToV8<T>(sp_std::marker::PhantomData<T>);

impl<T: Config> OnRuntimeUpgrade for VersionUncheckedMigrateV7ToV8<T> {
#[cfg(feature = "try-runtime")]
fn pre_upgrade() -> Result<Vec<u8>, sp_runtime::TryRuntimeError> {
Ok(Vec::new())
}

fn on_runtime_upgrade() -> Weight {
let mut translated = 0u64;
BondedPools::<T>::translate::<OldBondedPoolInner<T>, _>(|_key, old_value| {
translated.saturating_inc();
Some(old_value.migrate_to_v8())
});
T::DbWeight::get().reads_writes(translated, translated + 1)
}

#[cfg(feature = "try-runtime")]
fn post_upgrade(_: Vec<u8>) -> Result<(), sp_runtime::TryRuntimeError> {
// Check new `claim_permission` field is present.
frame_support::ensure!(
BondedPools::<T>::iter()
.all(|(_, inner)| inner.commission.claim_permission.is_none()),
"`claim_permission` value has not been set correctly."
);
Ok(())
}
}
}

mod v7 {
use super::*;

use sp_staking::StakingInterface;
// use frame_support::traits::GetStorageVersion;

#[derive(Encode, Decode, MaxEncodedLen, TypeInfo, DebugNoBound, PartialEq, Clone)]
#[codec(mel_bound(T: Config))]
#[scale_info(skip_type_params(T))]
pub struct Commission<T: Config> {
pub current: Option<(Perbill, T::AccountId)>,
pub max: Option<Perbill>,
pub change_rate: Option<CommissionChangeRate<BlockNumberFor<T>>>,
pub throttle_from: Option<BlockNumberFor<T>>,
}

#[derive(Encode, Decode, MaxEncodedLen, TypeInfo, DebugNoBound, PartialEq, Clone)]
#[codec(mel_bound(T: Config))]
#[scale_info(skip_type_params(T))]
pub struct BondedPoolInner<T: Config> {
pub commission: Commission<T>,
pub member_counter: u32,
pub points: BalanceOf<T>,
pub roles: PoolRoles<T::AccountId>,
pub state: PoolState,
}

#[derive(RuntimeDebugNoBound)]
#[cfg_attr(feature = "std", derive(Clone, PartialEq))]
pub struct BondedPool<T: Config> {
/// The identifier of the pool.
id: PoolId,
/// The inner fields.
inner: BondedPoolInner<T>,
}

impl<T: Config> BondedPool<T> {
fn bonded_account(&self) -> T::AccountId {
Pallet::<T>::create_bonded_account(self.id)
}
}

#[frame_support::storage_alias]
pub type BondedPools<T: Config> =
CountedStorageMap<Pallet<T>, Twox64Concat, PoolId, BondedPoolInner<T>>;

pub struct VersionUncheckedMigrateV6ToV7<T>(sp_std::marker::PhantomData<T>);
impl<T: Config> VersionUncheckedMigrateV6ToV7<T> {
fn calculate_tvl_by_total_stake() -> BalanceOf<T> {
BondedPools::<T>::iter()
.map(|(id, inner)| {
T::Staking::total_stake(
&BondedPool { id, inner: inner.clone() }.bonded_account(),
)
.unwrap_or_default()
})
.reduce(|acc, total_balance| acc + total_balance)
.unwrap_or_default()
}
}

impl<T: Config> OnRuntimeUpgrade for VersionUncheckedMigrateV6ToV7<T> {
fn on_runtime_upgrade() -> Weight {
let migrated = BondedPools::<T>::count();
// The TVL should be the sum of all the funds that are actively staked and in the
// unbonding process of the account of each pool.
let tvl: BalanceOf<T> = Self::calculate_tvl_by_total_stake();

TotalValueLocked::<T>::set(tvl);

log!(info, "Upgraded {} pools with a TVL of {:?}", migrated, tvl);

// reads: migrated * (BondedPools + Staking::total_stake) + count + onchain
// version
//
// writes: current version + TVL
T::DbWeight::get()
.reads_writes(migrated.saturating_mul(2).saturating_add(2).into(), 2)
}

#[cfg(feature = "try-runtime")]
fn pre_upgrade() -> Result<Vec<u8>, sp_runtime::TryRuntimeError> {
Ok(Vec::new())
}

#[cfg(feature = "try-runtime")]
fn post_upgrade(_data: Vec<u8>) -> Result<(), sp_runtime::TryRuntimeError> {
// check that the `TotalValueLocked` written is actually the sum of `total_stake` of
// the `BondedPools``
let tvl: BalanceOf<T> = Self::calculate_tvl_by_total_stake();
frame_support::ensure!(
TotalValueLocked::<T>::get() == tvl,
"TVL written is not equal to `Staking::total_stake` of all `BondedPools`."
);

// TODO: skip for now
// calculate the sum of `total_balance` of all `PoolMember` as the upper bound for
// the `TotalValueLocked`.
// let total_balance_members: BalanceOf<T> = PoolMembers::<T>::iter()
// .map(|(_, member)| member.total_balance())
// .reduce(|acc, total_balance| acc + total_balance)
// .unwrap_or_default();
//
// frame_support::ensure!(
// TotalValueLocked::<T>::get() <= total_balance_members,
// "TVL is greater than the balance of all PoolMembers."
// );
//
// frame_support::ensure!(
// Pallet::<T>::on_chain_storage_version() >= 7,
// "nomination-pools::migration::v7: wrong storage version"
// );

Ok(())
}
}
}
}
Loading