mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-09 14:07:58 +00:00
142a11ad95
* Move the bridges subtree under root * Squashed 'bridges/' changes from 277f0d5496..e50398d1c5 e50398d1c5 bridges subtree fixes (#2528) 99af07522d Markdown linter (#1309) (#2526) 733ff0fe7a `polkadot-staging` branch: Use polkadot-sdk dependencies (#2524) e8a59f141e Fix benchmark with new XCM::V3 `MAX_INSTRUCTIONS_TO_DECODE` (#2514) 62b185de15 Backport `polkadot-sdk` changes to `polkadot-staging` (#2518) d9658f4d5b Fix equivocation detection containers startup (#2516) (#2517) d65db28a8f Backport: building images from locally built binaries (#2513) 5fdbaf45f6 Start the equivocation detection loop from the complex relayer (#2507) (#2512) 7fbb67de46 Backport: Implement basic equivocations detection loop (#2375) cb7efe245c Manually update deps in polkadot staging (#2371) d17981fc33 #2351 to polkadot-staging (#2359) git-subtree-dir: bridges git-subtree-split: e50398d1c594e4e96df70b0bd376e565d17e8558 * Reapply diener workspacify * Fix Cargo.toml * Fix test * Adjustments
117 lines
4.4 KiB
Rust
117 lines
4.4 KiB
Rust
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// This file is part of Parity Bridges Common.
|
|
|
|
// Parity Bridges Common is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Parity Bridges Common is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Parachains finality pallet benchmarking.
|
|
|
|
use crate::{
|
|
weights_ext::DEFAULT_PARACHAIN_HEAD_SIZE, Call, RelayBlockHash, RelayBlockHasher,
|
|
RelayBlockNumber,
|
|
};
|
|
|
|
use bp_polkadot_core::parachains::{ParaHash, ParaHeadsProof, ParaId};
|
|
use bp_runtime::StorageProofSize;
|
|
use frame_benchmarking::{account, benchmarks_instance_pallet};
|
|
use frame_system::RawOrigin;
|
|
use sp_std::prelude::*;
|
|
|
|
/// Pallet we're benchmarking here.
|
|
pub struct Pallet<T: Config<I>, I: 'static = ()>(crate::Pallet<T, I>);
|
|
|
|
/// Trait that must be implemented by runtime to benchmark the parachains finality pallet.
|
|
pub trait Config<I: 'static>: crate::Config<I> {
|
|
/// Returns vector of supported parachains.
|
|
fn parachains() -> Vec<ParaId>;
|
|
/// Generate parachain heads proof and prepare environment for verifying this proof.
|
|
fn prepare_parachain_heads_proof(
|
|
parachains: &[ParaId],
|
|
parachain_head_size: u32,
|
|
proof_size: StorageProofSize,
|
|
) -> (RelayBlockNumber, RelayBlockHash, ParaHeadsProof, Vec<(ParaId, ParaHash)>);
|
|
}
|
|
|
|
benchmarks_instance_pallet! {
|
|
where_clause {
|
|
where
|
|
<T as pallet_bridge_grandpa::Config<T::BridgesGrandpaPalletInstance>>::BridgedChain:
|
|
bp_runtime::Chain<
|
|
BlockNumber = RelayBlockNumber,
|
|
Hash = RelayBlockHash,
|
|
Hasher = RelayBlockHasher,
|
|
>,
|
|
}
|
|
|
|
// Benchmark `submit_parachain_heads` extrinsic with different number of parachains.
|
|
submit_parachain_heads_with_n_parachains {
|
|
let p in 1..(T::parachains().len() + 1) as u32;
|
|
|
|
let sender = account("sender", 0, 0);
|
|
let mut parachains = T::parachains();
|
|
let _ = if p <= parachains.len() as u32 {
|
|
parachains.split_off(p as usize)
|
|
} else {
|
|
Default::default()
|
|
};
|
|
log::trace!(target: crate::LOG_TARGET, "=== {:?}", parachains.len());
|
|
let (relay_block_number, relay_block_hash, parachain_heads_proof, parachains_heads) = T::prepare_parachain_heads_proof(
|
|
¶chains,
|
|
DEFAULT_PARACHAIN_HEAD_SIZE,
|
|
StorageProofSize::Minimal(0),
|
|
);
|
|
let at_relay_block = (relay_block_number, relay_block_hash);
|
|
}: submit_parachain_heads(RawOrigin::Signed(sender), at_relay_block, parachains_heads, parachain_heads_proof)
|
|
verify {
|
|
for parachain in parachains {
|
|
assert!(crate::Pallet::<T, I>::best_parachain_head(parachain).is_some());
|
|
}
|
|
}
|
|
|
|
// Benchmark `submit_parachain_heads` extrinsic with 1kb proof size.
|
|
submit_parachain_heads_with_1kb_proof {
|
|
let sender = account("sender", 0, 0);
|
|
let parachains = vec![T::parachains()[0]];
|
|
let (relay_block_number, relay_block_hash, parachain_heads_proof, parachains_heads) = T::prepare_parachain_heads_proof(
|
|
¶chains,
|
|
DEFAULT_PARACHAIN_HEAD_SIZE,
|
|
StorageProofSize::HasLargeLeaf(1024),
|
|
);
|
|
let at_relay_block = (relay_block_number, relay_block_hash);
|
|
}: submit_parachain_heads(RawOrigin::Signed(sender), at_relay_block, parachains_heads, parachain_heads_proof)
|
|
verify {
|
|
for parachain in parachains {
|
|
assert!(crate::Pallet::<T, I>::best_parachain_head(parachain).is_some());
|
|
}
|
|
}
|
|
|
|
// Benchmark `submit_parachain_heads` extrinsic with 16kb proof size.
|
|
submit_parachain_heads_with_16kb_proof {
|
|
let sender = account("sender", 0, 0);
|
|
let parachains = vec![T::parachains()[0]];
|
|
let (relay_block_number, relay_block_hash, parachain_heads_proof, parachains_heads) = T::prepare_parachain_heads_proof(
|
|
¶chains,
|
|
DEFAULT_PARACHAIN_HEAD_SIZE,
|
|
StorageProofSize::HasLargeLeaf(16 * 1024),
|
|
);
|
|
let at_relay_block = (relay_block_number, relay_block_hash);
|
|
}: submit_parachain_heads(RawOrigin::Signed(sender), at_relay_block, parachains_heads, parachain_heads_proof)
|
|
verify {
|
|
for parachain in parachains {
|
|
assert!(crate::Pallet::<T, I>::best_parachain_head(parachain).is_some());
|
|
}
|
|
}
|
|
|
|
impl_benchmark_test_suite!(Pallet, crate::mock::new_test_ext(), crate::mock::TestRuntime)
|
|
}
|