Skip to content

Commit

Permalink
Scheduler pre block limit note (paritytech#13231)
Browse files Browse the repository at this point in the history
Co-authored-by: parity-processbot <>
  • Loading branch information
muharem authored and nathanwhit committed Jul 19, 2023
1 parent be82359 commit da36e2a
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 8 deletions.
3 changes: 3 additions & 0 deletions bin/node/runtime/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -364,7 +364,10 @@ impl pallet_scheduler::Config for Runtime {
type RuntimeCall = RuntimeCall;
type MaximumWeight = MaximumSchedulerWeight;
type ScheduleOrigin = EnsureRoot<AccountId>;
#[cfg(feature = "runtime-benchmarks")]
type MaxScheduledPerBlock = ConstU32<512>;
#[cfg(not(feature = "runtime-benchmarks"))]
type MaxScheduledPerBlock = ConstU32<50>;
type WeightInfo = pallet_scheduler::weights::SubstrateWeight<Runtime>;
type OriginPrivilegeCmp = EqualPrivilegeOnly;
type Preimages = Preimage;
Expand Down
15 changes: 7 additions & 8 deletions frame/referenda/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -874,22 +874,21 @@ impl<T: Config<I>, I: 'static> Pallet<T, I> {
let when = (when.saturating_add(alarm_interval.saturating_sub(One::one())) /
alarm_interval)
.saturating_mul(alarm_interval);
let maybe_result = T::Scheduler::schedule(
let result = T::Scheduler::schedule(
DispatchTime::At(when),
None,
128u8,
frame_system::RawOrigin::Root.into(),
call,
)
.ok()
.map(|x| (when, x));
);
debug_assert!(
maybe_result.is_some(),
"Unable to schedule a new alarm at #{:?} (now: #{:?})?!",
result.is_ok(),
"Unable to schedule a new alarm at #{:?} (now: #{:?}), scheduler error: `{:?}`",
when,
frame_system::Pallet::<T>::block_number()
frame_system::Pallet::<T>::block_number(),
result.unwrap_err(),
);
maybe_result
result.ok().map(|x| (when, x))
}

/// Mutate a referendum's `status` into the correct deciding state.
Expand Down
4 changes: 4 additions & 0 deletions frame/scheduler/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,10 @@ pub mod pallet {
type OriginPrivilegeCmp: PrivilegeCmp<Self::PalletsOrigin>;

/// The maximum number of scheduled calls in the queue for a single block.
///
/// NOTE:
/// + Dependent pallets' benchmarks might require a higher limit for the setting. Set a
/// higher limit under `runtime-benchmarks` feature.
#[pallet::constant]
type MaxScheduledPerBlock: Get<u32>;

Expand Down

0 comments on commit da36e2a

Please sign in to comment.