1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
use crate::{AccountId, AssetId, Balance, Duster, DustingReward, NativeAssetId, Runtime, Tokens};
use super::*;
use frame_benchmarking::account;
use frame_benchmarking::BenchmarkError;
use frame_support::assert_ok;
use frame_system::RawOrigin;
use orml_benchmarking::runtime_benchmarks;
use sp_runtime::traits::SaturatedConversion;
use orml_traits::{GetByKey, MultiCurrency, MultiCurrencyExtended};
const SEED: u32 = 1;
pub fn update_balance(currency_id: AssetId, who: &AccountId, balance: Balance) {
assert_ok!(<Tokens as MultiCurrencyExtended<_>>::update_balance(
currency_id,
who,
balance.saturated_into()
));
}
runtime_benchmarks! {
{ Runtime, pallet_duster }
dust_account{
let caller: AccountId = account("caller", 0, SEED);
let to_dust_account: AccountId = account("dust", 0, SEED);
let dust_dest_account: AccountId = account("dest", 1, SEED);
pallet_duster::DustAccount::<Runtime>::put(dust_dest_account);
let asset_id = register_asset(b"TST".to_vec(), 100u128).map_err(|_| BenchmarkError::Stop("Failed to register asset"))?;
let reward = DustingReward::get();
let dest_account = Duster::dust_dest_account();
let min_deposit = AssetRegistry::get(&asset_id);
update_balance(asset_id, &dest_account.clone().unwrap(), min_deposit);
let dust_amount = min_deposit;
update_balance(asset_id, &to_dust_account, min_deposit);
update_asset(asset_id, b"TST".to_vec(), 110u128).map_err(|_| BenchmarkError::Stop("Failed to update asset"))?;
assert_eq!(Tokens::free_balance(asset_id, &to_dust_account), dust_amount);
let current_balance = Tokens::free_balance(asset_id, &dest_account.clone().unwrap());
}: { pallet_duster::Pallet::<Runtime>::dust_account(RawOrigin::Signed(caller.clone()).into(), to_dust_account.clone(),asset_id)? }
verify {
assert_eq!(Tokens::free_balance(asset_id, &to_dust_account), 0u128);
assert_eq!(Tokens::free_balance(NativeAssetId::get(), &caller), reward);
assert_eq!(Tokens::free_balance(asset_id, &dest_account.unwrap()), current_balance + dust_amount);
}
add_nondustable_account{
let caller: AccountId = account("caller", 0, SEED);
let nondustable_account: AccountId = account("dust", 0, SEED);
}: { pallet_duster::Pallet::<Runtime>::add_nondustable_account(RawOrigin::Root.into(), nondustable_account.clone())? }
verify {
assert!(pallet_duster::Pallet::<Runtime>::blacklisted(&nondustable_account).is_some());
}
remove_nondustable_account{
let caller: AccountId = account("caller", 0, SEED);
let nondustable_account: AccountId = account("dust", 0, SEED);
pallet_duster::Pallet::<Runtime>::add_nondustable_account(RawOrigin::Root.into(), nondustable_account.clone())?;
}: { pallet_duster::Pallet::<Runtime>::remove_nondustable_account(RawOrigin::Root.into(), nondustable_account.clone())? }
verify {
assert!(pallet_duster::Pallet::<Runtime>::blacklisted(&nondustable_account).is_none());
}
}
#[cfg(test)]
mod tests {
use super::*;
use orml_benchmarking::impl_benchmark_test_suite;
fn new_test_ext() -> sp_io::TestExternalities {
frame_system::GenesisConfig::default()
.build_storage::<crate::Runtime>()
.unwrap()
.into()
}
impl_benchmark_test_suite!(new_test_ext(),);
}