From d1cb5d1a8ec42d22b11664b89ad5ff80fab9fe8b Mon Sep 17 00:00:00 2001 From: Svyatoslav Nikolsky Date: Wed, 14 Dec 2022 10:56:14 +0300 Subject: [PATCH] fix parachains benchmarks (#1717) --- bin/millau/runtime/src/lib.rs | 5 +++++ modules/parachains/src/benchmarking.rs | 11 +++++++---- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/bin/millau/runtime/src/lib.rs b/bin/millau/runtime/src/lib.rs index 19a8770430a..4513e50121b 100644 --- a/bin/millau/runtime/src/lib.rs +++ b/bin/millau/runtime/src/lib.rs @@ -1066,6 +1066,11 @@ impl_runtime_apis! { } impl ParachainsConfig for Runtime { + fn parachains() -> Vec { + use bp_runtime::Parachain; + vec![bp_polkadot_core::parachains::ParaId(bp_rialto_parachain::RialtoParachain::PARACHAIN_ID)] + } + fn prepare_parachain_heads_proof( parachains: &[bp_polkadot_core::parachains::ParaId], parachain_head_size: u32, diff --git a/modules/parachains/src/benchmarking.rs b/modules/parachains/src/benchmarking.rs index aba296dfc1d..29e48132890 100644 --- a/modules/parachains/src/benchmarking.rs +++ b/modules/parachains/src/benchmarking.rs @@ -32,6 +32,8 @@ pub struct Pallet, I: 'static>(crate::Pallet); /// Trait that must be implemented by runtime to benchmark the parachains finality pallet. pub trait Config: crate::Config { + /// Returns vector of supported parachains. + fn parachains() -> Vec; /// Generate parachain heads proof and prepare environment for verifying this proof. fn prepare_parachain_heads_proof( parachains: &[ParaId], @@ -53,10 +55,11 @@ benchmarks_instance_pallet! { // Benchmark `submit_parachain_heads` extrinsic with different number of parachains. submit_parachain_heads_with_n_parachains { - let p in 1..1024; + let p in 1..(T::parachains().len() + 1) as u32; let sender = account("sender", 0, 0); - let parachains = (1..=p).map(ParaId).collect::>(); + let mut parachains = T::parachains(); + let _ = parachains.split_off(p as usize - 1); let (relay_block_number, relay_block_hash, parachain_heads_proof, parachains_heads) = T::prepare_parachain_heads_proof( ¶chains, DEFAULT_PARACHAIN_HEAD_SIZE, @@ -73,7 +76,7 @@ benchmarks_instance_pallet! { // Benchmark `submit_parachain_heads` extrinsic with 1kb proof size. submit_parachain_heads_with_1kb_proof { let sender = account("sender", 0, 0); - let parachains = vec![ParaId(1)]; + 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, @@ -90,7 +93,7 @@ benchmarks_instance_pallet! { // Benchmark `submit_parachain_heads` extrinsic with 16kb proof size. submit_parachain_heads_with_16kb_proof { let sender = account("sender", 0, 0); - let parachains = vec![ParaId(1)]; + 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,