mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 01:07:57 +00:00
[FRAME] Make MQ pallet re-entrancy safe (#2356)
Closes https://github.com/paritytech/polkadot-sdk/issues/2319 Changes: - Ensure that only `enqueue_message(s)` is callable from within the message processor. This prevents messed up storage that can currently happen when the pallet is called into recursively. - Use `H256` instead of `[u8; 32]` for clearer API. ## Details The re-entracy check is done with the `environmental` crate by adding a `with_service_mutex(f)` function that runs the closure exclusively. This works since the MQ pallet is not instantiable. --------- Signed-off-by: Oliver Tale-Yazdi <oliver.tale-yazdi@parity.io> Co-authored-by: Francisco Aguirre <franciscoaguirreperez@gmail.com>
This commit is contained in:
committed by
GitHub
parent
95c3ee10bc
commit
7e7fe99047
@@ -25,6 +25,7 @@ use super::{mock_helpers::*, Pallet as MessageQueue, *};
|
||||
use frame_benchmarking::v2::*;
|
||||
use frame_support::traits::Get;
|
||||
use frame_system::RawOrigin;
|
||||
use sp_io::hashing::blake2_256;
|
||||
use sp_std::prelude::*;
|
||||
|
||||
#[benchmarks(
|
||||
@@ -142,7 +143,7 @@ mod benchmarks {
|
||||
// Check that it was processed.
|
||||
assert_last_event::<T>(
|
||||
Event::Processed {
|
||||
id: sp_io::hashing::blake2_256(&msg),
|
||||
id: blake2_256(&msg).into(),
|
||||
origin: 0.into(),
|
||||
weight_used: 1.into_weight(),
|
||||
success: true,
|
||||
@@ -227,7 +228,7 @@ mod benchmarks {
|
||||
|
||||
assert_last_event::<T>(
|
||||
Event::Processed {
|
||||
id: sp_io::hashing::blake2_256(&((msgs - 1) as u32).encode()),
|
||||
id: blake2_256(&((msgs - 1) as u32).encode()).into(),
|
||||
origin: 0.into(),
|
||||
weight_used: Weight::from_parts(1, 1),
|
||||
success: true,
|
||||
@@ -264,7 +265,7 @@ mod benchmarks {
|
||||
|
||||
assert_last_event::<T>(
|
||||
Event::Processed {
|
||||
id: sp_io::hashing::blake2_256(&((msgs - 1) as u32).encode()),
|
||||
id: blake2_256(&((msgs - 1) as u32).encode()).into(),
|
||||
origin: 0.into(),
|
||||
weight_used: Weight::from_parts(1, 1),
|
||||
success: true,
|
||||
|
||||
Reference in New Issue
Block a user