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

Add "run to block" tools #7109

Merged
merged 9 commits into from
Jan 15, 2025
Merged

Add "run to block" tools #7109

merged 9 commits into from
Jan 15, 2025

Conversation

aurexav
Copy link
Contributor

@aurexav aurexav commented Jan 10, 2025

Introduce frame_system::Pallet::run_to_block, frame_system::Pallet::run_to_block_with, and frame_system::RunToBlockHooks to establish a generic run_to_block mechanism for mock tests, minimizing redundant implementations across various pallets.

Closes #299.


Polkadot address: 156HGo9setPcU2qhFMVWLkcmtCEGySLwNqa3DaEiYSWtte4Y

@aurexav aurexav requested review from cheme and a team as code owners January 10, 2025 08:24
Signed-off-by: Xavier Lau <[email protected]>
@aurexav aurexav changed the title Add RunToBlockHooks Add "run to block" tools Jan 10, 2025
Copy link
Member

@bkchr bkchr left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice work! Left some minor things to fix up :)

substrate/frame/system/src/lib.rs Show resolved Hide resolved
substrate/frame/system/src/lib.rs Show resolved Hide resolved
after_initialize: Box<dyn 'a + FnMut(BlockNumberFor<T>)>,
before_finalize: Box<dyn 'a + FnMut(BlockNumberFor<T>)>,
after_finalize: Box<dyn 'a + FnMut(BlockNumberFor<T>)>,
_marker: PhantomData<&'a T>,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As we are using T, this should not be required.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yep, did a refactor and forgot about this.

/// provided closures at each block.
///
/// These hooks allows custom logic to be executed at each block at specific location.
/// For example, you might use one of them to set a timestamp for each block.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe mentioning that finalize_block is called before each on_initialize.

Comment on lines 548 to 549
// having `timestamp::on_initialize` called before `staking::on_initialize`. Also, if
// session length is 1, then it is already triggered.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The comment doesn't really hold? :D

Comment on lines 648 to 664
// Revert the `Authorship::OnInitialize`'s `note_author` reward for easy testing.
for i in start_session_idx..end_session_idx {
let blocks_per_session = if i == 0 {
// Skip block 0.
period - 1
} else {
period
};
let extra_reward_points = blocks_per_session as RewardPoint * 20;

ErasRewardPoints::<Test>::mutate(i / sessions_per_era, |p| {
if let Some(author_11) = p.individual.get_mut(&11) {
p.total = p.total.saturating_sub(extra_reward_points);
*author_11 = (*author_11).saturating_sub(extra_reward_points);
}
});
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we not just set the EventHandler to () to prevent this from happening?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Aha, missed this one.

Comment on lines 551 to 556
System::run_to_block_with::<AllPalletsWithSystem>(
1,
frame_system::RunToBlockHooks::default().after_initialize(|_| {
Timestamp::set_timestamp(INIT_TIMESTAMP);
}),
);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we not just call the run_to_block function here? (I know that the timestamp would be different, but the current setting here is wrong any way)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But the origin code appears to be equivalent to running to block 1?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What I mean is to use run_to_block from this file and not call System::run_to_block manually.

Copy link
Contributor Author

@aurexav aurexav Jan 11, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Okay, then reset the timestamp.

Make sense, to keep logic in a single place.

@bkchr bkchr added the T1-FRAME This PR/Issue is related to core FRAME, the framework. label Jan 10, 2025
@paritytech-review-bot paritytech-review-bot bot requested a review from a team January 10, 2025 17:23
@aurexav aurexav requested a review from bkchr January 11, 2025 01:17
Comment on lines 551 to 556
System::run_to_block_with::<AllPalletsWithSystem>(
1,
frame_system::RunToBlockHooks::default().after_initialize(|_| {
Timestamp::set_timestamp(INIT_TIMESTAMP);
}),
);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What I mean is to use run_to_block from this file and not call System::run_to_block manually.

@bkchr
Copy link
Member

bkchr commented Jan 11, 2025

/tip medium

Copy link

@bkchr A referendum for a medium (80 DOT) tip was successfully submitted for @aurexav (156HGo9setPcU2qhFMVWLkcmtCEGySLwNqa3DaEiYSWtte4Y on polkadot).

Referendum number: 1379.
tip

@bkchr bkchr requested review from ggwpez and gui1117 January 11, 2025 07:57
Copy link
Contributor

@gui1117 gui1117 left a 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, thank you

@gui1117
Copy link
Contributor

gui1117 commented Jan 15, 2025

/cmd prdoc --audience runtime_dev --bump patch

prdoc/pr_7109.prdoc Outdated Show resolved Hide resolved
@gui1117 gui1117 enabled auto-merge January 15, 2025 10:00
@gui1117 gui1117 added this pull request to the merge queue Jan 15, 2025
Merged via the queue into paritytech:master with commit b72e76f Jan 15, 2025
193 of 204 checks passed
ordian added a commit that referenced this pull request Jan 16, 2025
* master: (33 commits)
  Implement `pallet-asset-rewards` (#3926)
  [pallet-revive] Add host function `to_account_id` (#7091)
  [pallet-revive] Remove revive events (#7164)
  [pallet-revive] Remove debug buffer (#7163)
  litep2p: Provide partial results to speedup GetRecord queries (#7099)
  [pallet-revive] Bump asset-hub westend spec version (#7176)
  Remove 0 as a special case in gas/storage meters (#6890)
  [pallet-revive] Fix `caller_is_root` return value (#7086)
  req-resp/litep2p: Reject inbound requests from banned peers (#7158)
  Add "run to block" tools (#7109)
  Fix reversed error message in DispatchInfo (#7170)
  approval-voting: Make importing of duplicate assignment idempotent (#6971)
  Parachains: Use relay chain slot for velocity measurement (#6825)
  PRDOC: Document `validate: false` (#7117)
  xcm: convert properly assets in xcmpayment apis (#7134)
  CI: Only format umbrella crate during umbrella check (#7139)
  approval-voting: Fix sending of assignments after restart (#6973)
  Retry approval on availability failure if the check is still needed (#6807)
  [pallet-revive-eth-rpc] persist eth transaction hash (#6836)
  litep2p: Sufix litep2p to the identify agent version for visibility (#7133)
  ...
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
T1-FRAME This PR/Issue is related to core FRAME, the framework.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Ease implementation of mock for pallets.
3 participants