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

[FRAME] Simple multi block migrations #14275

Draft
wants to merge 66 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
66 commits
Select commit Hold shift + click to select a range
dc35acf
Add stepped migrations and pallet
ggwpez May 30, 2023
283d51c
Cleanup
ggwpez May 30, 2023
7c53a74
Comment
ggwpez May 30, 2023
edb005c
Suspension and benches
ggwpez May 31, 2023
8331fbe
Add generic to Executive
ggwpez May 31, 2023
c23259f
Cleanup
ggwpez May 31, 2023
9ffd3d7
Merge remote-tracking branch 'origin/master' into oty-multi-step-migr…
ggwpez May 31, 2023
3afdf0a
Add Executed
ggwpez May 31, 2023
104fd6d
Add events
ggwpez May 31, 2023
1e18cae
Fixes
ggwpez May 31, 2023
7ab621a
Make cursor generic
ggwpez Jun 1, 2023
acd99bb
Fix kitchensink
ggwpez Jun 1, 2023
d217589
Add testing
ggwpez Jun 1, 2023
3351a54
Tests
ggwpez Jun 1, 2023
4eeb47e
Use default configs for System
ggwpez Jun 1, 2023
80922c9
Tests
ggwpez Jun 1, 2023
4ae8fbf
Fixes
ggwpez Jun 1, 2023
e6beda5
Add status handling
ggwpez Jun 2, 2023
fa20468
Refactor
ggwpez Jun 2, 2023
ad98b43
Fixes
ggwpez Jun 2, 2023
5c3a90d
Clippy
ggwpez Jun 2, 2023
357fa47
Update frame/support/src/migrations.rs
ggwpez Jun 2, 2023
da04876
Update frame/migrations/src/mock.rs
ggwpez Jun 2, 2023
2e86915
Update frame/migrations/src/tests.rs
ggwpez Jun 2, 2023
99691a3
fmt
ggwpez Jun 2, 2023
e44c902
Add timeout checking
ggwpez Jun 3, 2023
5f512e6
Fix stuff
ggwpez Jun 5, 2023
c72c7b7
Add docs
ggwpez Jun 5, 2023
790914d
Fix docs and kitchensink
ggwpez Jun 5, 2023
642d65a
Format Cargo.toml
ggwpez Jun 5, 2023
a2b3194
Docs
ggwpez Jun 5, 2023
60c1322
Now it sounds like English 😂
ggwpez Jun 11, 2023
17be927
Fix test
ggwpez Jun 11, 2023
741c476
fmt
ggwpez Jun 11, 2023
6a1438e
Benches still WIP
ggwpez Jun 11, 2023
0e4f8a6
Move code
ggwpez Jun 13, 2023
97b58e1
Docs review fixes
ggwpez Jun 13, 2023
87ac850
Add tests
ggwpez Jun 13, 2023
b8c8559
Rename to OnMigrationUpdate
ggwpez Jun 13, 2023
3b27c4f
Fix bugs
ggwpez Jun 14, 2023
07f6889
More fixes
ggwpez Jun 14, 2023
f202a80
Fixes
ggwpez Jun 14, 2023
1249955
Undo changes to frame-executive
ggwpez Jun 14, 2023
717b30e
Fix executive
ggwpez Jun 14, 2023
c7e8384
Fix
ggwpez Jun 14, 2023
a1589a3
Fix docs
ggwpez Jun 15, 2023
4fd5d93
Add log target to sc-basic-authorship
ggwpez Jun 15, 2023
e75d0c1
Merge remote-tracking branch 'origin/master' into oty-multi-step-migr…
ggwpez Jun 15, 2023
37cf9b8
Add mock_helpers
ggwpez Jun 15, 2023
69fddc3
Add progress_mbms to BlockBuilder
ggwpez Jun 15, 2023
7435788
Add log target
ggwpez Jun 16, 2023
6b1d6b1
Factor out apply_inherents
ggwpez Jun 16, 2023
0b7dddc
Factor out apply_extrinsics
ggwpez Jun 16, 2023
648e005
Factor out print_summary
ggwpez Jun 16, 2023
24c8bf6
Pimp print_summary
ggwpez Jun 16, 2023
4b99c6e
Cleanup
ggwpez Jun 16, 2023
93f0d32
Fixes
ggwpez Jun 16, 2023
c57bbf5
Backup
ggwpez Jun 16, 2023
30c302e
Merge branch 'oty-refactor-block-builder' into oty-multi-step-migration
ggwpez Jun 16, 2023
4101e82
Fix stuff
ggwpez Jun 16, 2023
8f7bda1
Works
ggwpez Jun 16, 2023
e430d57
Fix template
ggwpez Jun 17, 2023
89313b3
Fix test
ggwpez Jun 18, 2023
999b0f0
WIP
ggwpez Jun 27, 2023
f87a8e4
Use impl trait for tuples
bkchr Jun 29, 2023
f3f76b6
Simplify
bkchr Jun 29, 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
26 changes: 26 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,7 @@ members = [
"frame/lottery",
"frame/membership",
"frame/merkle-mountain-range",
"frame/migrations",
"frame/multisig",
"frame/nicks",
"frame/node-authorization",
Expand Down
4 changes: 4 additions & 0 deletions bin/node-template/runtime/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -392,6 +392,10 @@ impl_runtime_apis! {
) -> sp_inherents::CheckInherentsResult {
data.check_extrinsics(&block)
}

fn after_inherents() -> sp_runtime::BlockAfterInherentsMode {
Executive::after_inherents()
}
}

impl sp_transaction_pool::runtime_api::TaggedTransactionQueue<Block> for Runtime {
Expand Down
4 changes: 4 additions & 0 deletions bin/node/runtime/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,7 @@ pallet-identity = { version = "4.0.0-dev", default-features = false, path = "../
pallet-lottery = { version = "4.0.0-dev", default-features = false, path = "../../../frame/lottery" }
pallet-membership = { version = "4.0.0-dev", default-features = false, path = "../../../frame/membership" }
pallet-message-queue = { version = "7.0.0-dev", default-features = false, path = "../../../frame/message-queue" }
pallet-migrations = { version = "1.0.0", default-features = false, path = "../../../frame/migrations" }
pallet-mmr = { version = "4.0.0-dev", default-features = false, path = "../../../frame/merkle-mountain-range" }
pallet-multisig = { version = "4.0.0-dev", default-features = false, path = "../../../frame/multisig" }
pallet-nfts = { version = "4.0.0-dev", default-features = false, path = "../../../frame/nfts" }
Expand Down Expand Up @@ -171,6 +172,7 @@ std = [
"pallet-lottery/std",
"pallet-membership/std",
"pallet-message-queue/std",
"pallet-migrations/std",
"pallet-mmr/std",
"pallet-multisig/std",
"pallet-nomination-pools/std",
Expand Down Expand Up @@ -265,6 +267,7 @@ runtime-benchmarks = [
"pallet-lottery/runtime-benchmarks",
"pallet-membership/runtime-benchmarks",
"pallet-message-queue/runtime-benchmarks",
"pallet-migrations/runtime-benchmarks",
"pallet-mmr/runtime-benchmarks",
"pallet-multisig/runtime-benchmarks",
"pallet-nomination-pools-benchmarking/runtime-benchmarks",
Expand Down Expand Up @@ -328,6 +331,7 @@ try-runtime = [
"pallet-lottery/try-runtime",
"pallet-membership/try-runtime",
"pallet-message-queue/try-runtime",
"pallet-migrations/try-runtime",
"pallet-mmr/try-runtime",
"pallet-multisig/try-runtime",
"pallet-nomination-pools/try-runtime",
Expand Down
36 changes: 36 additions & 0 deletions bin/node/runtime/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1860,6 +1860,35 @@ impl pallet_statement::Config for Runtime {
type MaxAllowedBytes = MaxAllowedBytes;
}

parameter_types! {
pub MbmServiceWeight: Weight = Perbill::from_percent(80) * RuntimeBlockWeights::get().max_block;
// FAIL-CI remove
pub Mbms: pallet_migrations::MigrationsOf<Runtime> = vec![
Box::new(pallet_migrations::mock_helpers::MockedMigration(
pallet_migrations::mock_helpers::MockedMigrationKind::SucceedAfter, 0
)),
Box::new(pallet_migrations::mock_helpers::MockedMigration(
pallet_migrations::mock_helpers::MockedMigrationKind::SucceedAfter, 2
)),
Box::new(pallet_migrations::mock_helpers::MockedMigration(
pallet_migrations::mock_helpers::MockedMigrationKind::SucceedAfter, 3
)),
Box::new(pallet_migrations::mock_helpers::MockedMigration(
pallet_migrations::mock_helpers::MockedMigrationKind::SucceedAfter, 20
))
];
}

impl pallet_migrations::Config for Runtime {
type RuntimeEvent = RuntimeEvent;
type Migrations = Mbms;
type Cursor = pallet_migrations::mock_helpers::MockedCursor;
type Identifier = pallet_migrations::mock_helpers::MockedIdentifier;
type OnMigrationUpdate = ();
type ServiceWeight = MbmServiceWeight;
type WeightInfo = pallet_migrations::weights::SubstrateWeight<Runtime>;
}

construct_runtime!(
pub struct Runtime where
Block = Block,
Expand Down Expand Up @@ -1935,6 +1964,7 @@ construct_runtime!(
MessageQueue: pallet_message_queue,
Pov: frame_benchmarking_pallet_pov,
Statement: pallet_statement,
MultiBlockMigrations: pallet_migrations,
}
);

Expand Down Expand Up @@ -1979,6 +2009,7 @@ pub type Executive = frame_executive::Executive<
Runtime,
AllPalletsWithSystem,
Migrations,
MultiBlockMigrations,
>;

// All migrations executed on runtime upgrade as a nested tuple of types implementing
Expand Down Expand Up @@ -2034,6 +2065,7 @@ mod benches {
[pallet_lottery, Lottery]
[pallet_membership, TechnicalMembership]
[pallet_message_queue, MessageQueue]
[pallet_migrations, MultiBlockMigrations]
[pallet_mmr, Mmr]
[pallet_multisig, Multisig]
[pallet_nomination_pools, NominationPoolsBench::<Runtime>]
Expand Down Expand Up @@ -2111,6 +2143,10 @@ impl_runtime_apis! {
fn check_inherents(block: Block, data: InherentData) -> CheckInherentsResult {
data.check_extrinsics(&block)
}

fn after_inherents() -> sp_runtime::BlockAfterInherentsMode {
Executive::after_inherents()
}
}

impl sp_transaction_pool::runtime_api::TaggedTransactionQueue<Block> for Runtime {
Expand Down
Loading