mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-31 21:31:02 +00:00
Benchmarks for new relayers pallet calls (#2040)
* slash relayer balance for invalid transactions * require some gap before unstake is possible * more clippy * log priority boost * add issue ref to TODO * fix typo * is_message_delivery_call -> is_receive_messages_proof_call * moved is_receive_messages_proof_call above * only slash relayers for priority transactions * benchmarks for new relayers pallet calls * generated weights * regenerated weights afer master merge * actually use weights
This commit is contained in:
committed by
Bastian Köcher
parent
f7cc060d9b
commit
1f738f1389
@@ -24,6 +24,7 @@ use bp_messages::LaneId;
|
||||
use bp_relayers::RewardsAccountOwner;
|
||||
use frame_benchmarking::{benchmarks, whitelisted_caller};
|
||||
use frame_system::RawOrigin;
|
||||
use sp_runtime::traits::One;
|
||||
|
||||
/// Reward amount that is (hopefully) is larger than existential deposit across all chains.
|
||||
const REWARD_AMOUNT: u32 = u32::MAX;
|
||||
@@ -34,7 +35,9 @@ pub struct Pallet<T: Config>(crate::Pallet<T>);
|
||||
/// Trait that must be implemented by runtime.
|
||||
pub trait Config: crate::Config {
|
||||
/// Prepare environment for paying given reward for serving given lane.
|
||||
fn prepare_environment(account_params: RewardsAccountParams, reward: Self::Reward);
|
||||
fn prepare_rewards_account(account_params: RewardsAccountParams, reward: Self::Reward);
|
||||
/// Give enough balance to given account.
|
||||
fn deposit_account(account: Self::AccountId, balance: Self::Reward);
|
||||
}
|
||||
|
||||
benchmarks! {
|
||||
@@ -46,7 +49,7 @@ benchmarks! {
|
||||
let relayer: T::AccountId = whitelisted_caller();
|
||||
let reward = T::Reward::from(REWARD_AMOUNT);
|
||||
|
||||
T::prepare_environment(account_params, reward);
|
||||
T::prepare_rewards_account(account_params, reward);
|
||||
RelayerRewards::<T>::insert(&relayer, account_params, reward);
|
||||
}: _(RawOrigin::Signed(relayer), account_params)
|
||||
verify {
|
||||
@@ -55,5 +58,35 @@ benchmarks! {
|
||||
// also completed successfully
|
||||
}
|
||||
|
||||
// Benchmark `register` call.
|
||||
register {
|
||||
let relayer: T::AccountId = whitelisted_caller();
|
||||
let valid_till = frame_system::Pallet::<T>::block_number()
|
||||
.saturating_add(crate::Pallet::<T>::required_registration_lease())
|
||||
.saturating_add(One::one())
|
||||
.saturating_add(One::one());
|
||||
|
||||
T::deposit_account(relayer.clone(), crate::Pallet::<T>::required_stake());
|
||||
}: _(RawOrigin::Signed(relayer.clone()), valid_till)
|
||||
verify {
|
||||
assert!(crate::Pallet::<T>::is_registration_active(&relayer));
|
||||
}
|
||||
|
||||
// Benchmark `deregister` call.
|
||||
deregister {
|
||||
let relayer: T::AccountId = whitelisted_caller();
|
||||
let valid_till = frame_system::Pallet::<T>::block_number()
|
||||
.saturating_add(crate::Pallet::<T>::required_registration_lease())
|
||||
.saturating_add(One::one())
|
||||
.saturating_add(One::one());
|
||||
T::deposit_account(relayer.clone(), crate::Pallet::<T>::required_stake());
|
||||
crate::Pallet::<T>::register(RawOrigin::Signed(relayer.clone()).into(), valid_till).unwrap();
|
||||
|
||||
frame_system::Pallet::<T>::set_block_number(valid_till.saturating_add(One::one()));
|
||||
}: _(RawOrigin::Signed(relayer.clone()))
|
||||
verify {
|
||||
assert!(!crate::Pallet::<T>::is_registration_active(&relayer));
|
||||
}
|
||||
|
||||
impl_benchmark_test_suite!(Pallet, crate::mock::new_test_ext(), crate::mock::TestRuntime)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user