mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-19 03:01:02 +00:00
Handle the AllowMultiAssetPools=false case in benchmarks (#14590)
* Handle the AllowMultiAssetPools=false case in benchmarks * ".git/.scripts/commands/bench/bench.sh" pallet dev pallet_asset_conversion --------- Co-authored-by: command-bot <>
This commit is contained in:
@@ -28,6 +28,7 @@ use frame_support::{
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
use frame_system::RawOrigin as SystemOrigin;
|
use frame_system::RawOrigin as SystemOrigin;
|
||||||
|
use sp_core::Get;
|
||||||
use sp_runtime::traits::{Bounded, StaticLookup};
|
use sp_runtime::traits::{Bounded, StaticLookup};
|
||||||
use sp_std::{ops::Div, prelude::*};
|
use sp_std::{ops::Div, prelude::*};
|
||||||
|
|
||||||
@@ -168,117 +169,160 @@ benchmarks! {
|
|||||||
}
|
}
|
||||||
|
|
||||||
swap_exact_tokens_for_tokens {
|
swap_exact_tokens_for_tokens {
|
||||||
let asset1 = T::MultiAssetIdConverter::get_native();
|
let native = T::MultiAssetIdConverter::get_native();
|
||||||
let asset2 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(0));
|
let asset1 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(1));
|
||||||
let asset3 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(1));
|
let asset2 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(2));
|
||||||
let asset4 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(2));
|
let (_, caller, _) = create_asset_and_pool::<T>(&native, &asset1);
|
||||||
|
let (_, _) = create_asset::<T>(&asset2);
|
||||||
let (_, caller, _) = create_asset_and_pool::<T>(&asset1, &asset2);
|
|
||||||
let (_, _) = create_asset::<T>(&asset3);
|
|
||||||
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset2.clone(), asset3.clone())?;
|
|
||||||
let (_, _) = create_asset::<T>(&asset4);
|
|
||||||
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset3.clone(), asset4.clone())?;
|
|
||||||
|
|
||||||
let path: BoundedVec<_, T::MaxSwapPathLength> =
|
|
||||||
BoundedVec::try_from(vec![asset1.clone(), asset2.clone(), asset3.clone(), asset4.clone()]).unwrap();
|
|
||||||
let ed: u128 = T::Currency::minimum_balance().into();
|
let ed: u128 = T::Currency::minimum_balance().into();
|
||||||
let add_amount1 = 100 * ed;
|
|
||||||
|
|
||||||
AssetConversion::<T>::add_liquidity(
|
AssetConversion::<T>::add_liquidity(
|
||||||
SystemOrigin::Signed(caller.clone()).into(),
|
SystemOrigin::Signed(caller.clone()).into(),
|
||||||
|
native.clone(),
|
||||||
asset1.clone(),
|
asset1.clone(),
|
||||||
asset2.clone(),
|
(100 * ed).into(),
|
||||||
add_amount1.into(),
|
|
||||||
200.into(),
|
200.into(),
|
||||||
0.into(),
|
0.into(),
|
||||||
0.into(),
|
0.into(),
|
||||||
caller.clone(),
|
caller.clone(),
|
||||||
)?;
|
)?;
|
||||||
AssetConversion::<T>::add_liquidity(
|
|
||||||
SystemOrigin::Signed(caller.clone()).into(),
|
let path;
|
||||||
asset2.clone(),
|
// if we only allow the native-asset pools, then the worst case scenario would be to swap
|
||||||
asset3.clone(),
|
// asset1-native-asset2
|
||||||
200.into(),
|
if !T::AllowMultiAssetPools::get() {
|
||||||
2000.into(),
|
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), native.clone(), asset2.clone())?;
|
||||||
0.into(),
|
AssetConversion::<T>::add_liquidity(
|
||||||
0.into(),
|
SystemOrigin::Signed(caller.clone()).into(),
|
||||||
caller.clone(),
|
native.clone(),
|
||||||
)?;
|
asset2.clone(),
|
||||||
AssetConversion::<T>::add_liquidity(
|
(500 * ed).into(),
|
||||||
SystemOrigin::Signed(caller.clone()).into(),
|
1000.into(),
|
||||||
asset3.clone(),
|
0.into(),
|
||||||
asset4.clone(),
|
0.into(),
|
||||||
2000.into(),
|
caller.clone(),
|
||||||
2000.into(),
|
)?;
|
||||||
0.into(),
|
path = vec![asset1.clone(), native.clone(), asset2.clone()];
|
||||||
0.into(),
|
} else {
|
||||||
caller.clone(),
|
let asset3 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(3));
|
||||||
)?;
|
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset1.clone(), asset2.clone())?;
|
||||||
let asset1_balance = T::Currency::balance(&caller);
|
let (_, _) = create_asset::<T>(&asset3);
|
||||||
}: _(SystemOrigin::Signed(caller.clone()), path.clone(), ed.into(), 1.into(), caller.clone(), false)
|
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset2.clone(), asset3.clone())?;
|
||||||
|
|
||||||
|
AssetConversion::<T>::add_liquidity(
|
||||||
|
SystemOrigin::Signed(caller.clone()).into(),
|
||||||
|
asset1.clone(),
|
||||||
|
asset2.clone(),
|
||||||
|
200.into(),
|
||||||
|
2000.into(),
|
||||||
|
0.into(),
|
||||||
|
0.into(),
|
||||||
|
caller.clone(),
|
||||||
|
)?;
|
||||||
|
AssetConversion::<T>::add_liquidity(
|
||||||
|
SystemOrigin::Signed(caller.clone()).into(),
|
||||||
|
asset2.clone(),
|
||||||
|
asset3.clone(),
|
||||||
|
2000.into(),
|
||||||
|
2000.into(),
|
||||||
|
0.into(),
|
||||||
|
0.into(),
|
||||||
|
caller.clone(),
|
||||||
|
)?;
|
||||||
|
path = vec![native.clone(), asset1.clone(), asset2.clone(), asset3.clone()];
|
||||||
|
}
|
||||||
|
|
||||||
|
let path: BoundedVec<_, T::MaxSwapPathLength> = BoundedVec::try_from(path).unwrap();
|
||||||
|
let native_balance = T::Currency::balance(&caller);
|
||||||
|
let asset1_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(1), &caller);
|
||||||
|
}: _(SystemOrigin::Signed(caller.clone()), path, ed.into(), 1.into(), caller.clone(), false)
|
||||||
verify {
|
verify {
|
||||||
let new_asset1_balance = T::Currency::balance(&caller);
|
if !T::AllowMultiAssetPools::get() {
|
||||||
assert_eq!(
|
let new_asset1_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(1), &caller);
|
||||||
new_asset1_balance,
|
assert_eq!(new_asset1_balance, asset1_balance - 100.into());
|
||||||
asset1_balance - ed.into()
|
} else {
|
||||||
);
|
let new_native_balance = T::Currency::balance(&caller);
|
||||||
|
assert_eq!(new_native_balance, native_balance - ed.into());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
swap_tokens_for_exact_tokens {
|
swap_tokens_for_exact_tokens {
|
||||||
let asset1 = T::MultiAssetIdConverter::get_native();
|
let native = T::MultiAssetIdConverter::get_native();
|
||||||
let asset2 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(0));
|
let asset1 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(1));
|
||||||
let asset3 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(1));
|
let asset2 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(2));
|
||||||
let asset4 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(2));
|
let (_, caller, _) = create_asset_and_pool::<T>(&native, &asset1);
|
||||||
|
let (_, _) = create_asset::<T>(&asset2);
|
||||||
let (_, caller, _) = create_asset_and_pool::<T>(&asset1, &asset2);
|
|
||||||
let (_, _) = create_asset::<T>(&asset3);
|
|
||||||
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset2.clone(), asset3.clone())?;
|
|
||||||
let (_, _) = create_asset::<T>(&asset4);
|
|
||||||
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset3.clone(), asset4.clone())?;
|
|
||||||
|
|
||||||
let path: BoundedVec<_, T::MaxSwapPathLength> =
|
|
||||||
BoundedVec::try_from(vec![asset1.clone(), asset2.clone(), asset3.clone(), asset4.clone()]).unwrap();
|
|
||||||
let ed: u128 = T::Currency::minimum_balance().into();
|
let ed: u128 = T::Currency::minimum_balance().into();
|
||||||
let add_amount1 = 1000 + ed;
|
let add_native = 1000 + ed;
|
||||||
|
|
||||||
AssetConversion::<T>::add_liquidity(
|
AssetConversion::<T>::add_liquidity(
|
||||||
SystemOrigin::Signed(caller.clone()).into(),
|
SystemOrigin::Signed(caller.clone()).into(),
|
||||||
|
native.clone(),
|
||||||
asset1.clone(),
|
asset1.clone(),
|
||||||
asset2.clone(),
|
add_native.into(),
|
||||||
add_amount1.into(),
|
|
||||||
200.into(),
|
200.into(),
|
||||||
0.into(),
|
0.into(),
|
||||||
0.into(),
|
0.into(),
|
||||||
caller.clone(),
|
caller.clone(),
|
||||||
)?;
|
)?;
|
||||||
AssetConversion::<T>::add_liquidity(
|
|
||||||
SystemOrigin::Signed(caller.clone()).into(),
|
let path;
|
||||||
asset2.clone(),
|
// if we only allow the native-asset pools, then the worst case scenario would be to swap
|
||||||
asset3.clone(),
|
// asset1-native-asset2
|
||||||
200.into(),
|
if !T::AllowMultiAssetPools::get() {
|
||||||
2000.into(),
|
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), native.clone(), asset2.clone())?;
|
||||||
0.into(),
|
AssetConversion::<T>::add_liquidity(
|
||||||
0.into(),
|
SystemOrigin::Signed(caller.clone()).into(),
|
||||||
caller.clone(),
|
native.clone(),
|
||||||
)?;
|
asset2.clone(),
|
||||||
AssetConversion::<T>::add_liquidity(
|
(500 + ed).into(),
|
||||||
SystemOrigin::Signed(caller.clone()).into(),
|
1000.into(),
|
||||||
asset3.clone(),
|
0.into(),
|
||||||
asset4.clone(),
|
0.into(),
|
||||||
2000.into(),
|
caller.clone(),
|
||||||
2000.into(),
|
)?;
|
||||||
0.into(),
|
path = vec![asset1.clone(), native.clone(), asset2.clone()];
|
||||||
0.into(),
|
} else {
|
||||||
caller.clone(),
|
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset1.clone(), asset2.clone())?;
|
||||||
)?;
|
let asset3 = T::MultiAssetIdConverter::into_multiasset_id(&T::BenchmarkHelper::asset_id(3));
|
||||||
let asset4_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(2), &caller);
|
let (_, _) = create_asset::<T>(&asset3);
|
||||||
}: _(SystemOrigin::Signed(caller.clone()), path.clone(), 100.into(), add_amount1.into(), caller.clone(), false)
|
AssetConversion::<T>::create_pool(SystemOrigin::Signed(caller.clone()).into(), asset2.clone(), asset3.clone())?;
|
||||||
|
|
||||||
|
AssetConversion::<T>::add_liquidity(
|
||||||
|
SystemOrigin::Signed(caller.clone()).into(),
|
||||||
|
asset1.clone(),
|
||||||
|
asset2.clone(),
|
||||||
|
200.into(),
|
||||||
|
2000.into(),
|
||||||
|
0.into(),
|
||||||
|
0.into(),
|
||||||
|
caller.clone(),
|
||||||
|
)?;
|
||||||
|
AssetConversion::<T>::add_liquidity(
|
||||||
|
SystemOrigin::Signed(caller.clone()).into(),
|
||||||
|
asset2.clone(),
|
||||||
|
asset3.clone(),
|
||||||
|
2000.into(),
|
||||||
|
2000.into(),
|
||||||
|
0.into(),
|
||||||
|
0.into(),
|
||||||
|
caller.clone(),
|
||||||
|
)?;
|
||||||
|
path = vec![native.clone(), asset1.clone(), asset2.clone(), asset3.clone()];
|
||||||
|
}
|
||||||
|
|
||||||
|
let path: BoundedVec<_, T::MaxSwapPathLength> = BoundedVec::try_from(path).unwrap();
|
||||||
|
let asset2_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(2), &caller);
|
||||||
|
let asset3_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(3), &caller);
|
||||||
|
}: _(SystemOrigin::Signed(caller.clone()), path.clone(), 100.into(), add_native.into(), caller.clone(), false)
|
||||||
verify {
|
verify {
|
||||||
let new_asset4_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(2), &caller);
|
if !T::AllowMultiAssetPools::get() {
|
||||||
assert_eq!(
|
let new_asset2_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(2), &caller);
|
||||||
new_asset4_balance,
|
assert_eq!(new_asset2_balance, asset2_balance + 100.into());
|
||||||
asset4_balance + 100.into()
|
} else {
|
||||||
);
|
let new_asset3_balance = T::Assets::balance(T::BenchmarkHelper::asset_id(3), &caller);
|
||||||
|
assert_eq!(new_asset3_balance, asset3_balance + 100.into());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl_benchmark_test_suite!(AssetConversion, crate::mock::new_test_ext(), crate::mock::Test);
|
impl_benchmark_test_suite!(AssetConversion, crate::mock::new_test_ext(), crate::mock::Test);
|
||||||
|
|||||||
+133
-136
@@ -18,28 +18,25 @@
|
|||||||
//! Autogenerated weights for pallet_asset_conversion
|
//! Autogenerated weights for pallet_asset_conversion
|
||||||
//!
|
//!
|
||||||
//! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 4.0.0-dev
|
//! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 4.0.0-dev
|
||||||
//! DATE: 2023-06-16, STEPS: `50`, REPEAT: `20`, LOW RANGE: `[]`, HIGH RANGE: `[]`
|
//! DATE: 2023-07-17, STEPS: `50`, REPEAT: `20`, LOW RANGE: `[]`, HIGH RANGE: `[]`
|
||||||
//! WORST CASE MAP SIZE: `1000000`
|
//! WORST CASE MAP SIZE: `1000000`
|
||||||
//! HOSTNAME: `runner-e8ezs4ez-project-145-concurrent-0`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
|
//! HOSTNAME: `runner-gghbxkbs-project-145-concurrent-0`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
|
||||||
//! EXECUTION: Some(Wasm), WASM-EXECUTION: Compiled, CHAIN: Some("dev"), DB CACHE: 1024
|
//! EXECUTION: ``, WASM-EXECUTION: `Compiled`, CHAIN: `Some("dev")`, DB CACHE: `1024`
|
||||||
|
|
||||||
// Executed Command:
|
// Executed Command:
|
||||||
// ./target/production/substrate
|
// target/production/substrate
|
||||||
// benchmark
|
// benchmark
|
||||||
// pallet
|
// pallet
|
||||||
// --chain=dev
|
|
||||||
// --steps=50
|
// --steps=50
|
||||||
// --repeat=20
|
// --repeat=20
|
||||||
// --pallet=pallet_asset_conversion
|
|
||||||
// --no-storage-info
|
|
||||||
// --no-median-slopes
|
|
||||||
// --no-min-squares
|
|
||||||
// --extrinsic=*
|
// --extrinsic=*
|
||||||
// --execution=wasm
|
|
||||||
// --wasm-execution=compiled
|
// --wasm-execution=compiled
|
||||||
// --heap-pages=4096
|
// --heap-pages=4096
|
||||||
// --output=./frame/asset-conversion/src/weights.rs
|
// --json-file=/builds/parity/mirrors/substrate/.git/.artifacts/bench.json
|
||||||
|
// --pallet=pallet_asset_conversion
|
||||||
|
// --chain=dev
|
||||||
// --header=./HEADER-APACHE2
|
// --header=./HEADER-APACHE2
|
||||||
|
// --output=./frame/asset-conversion/src/weights.rs
|
||||||
// --template=./.maintain/frame-weight-template.hbs
|
// --template=./.maintain/frame-weight-template.hbs
|
||||||
|
|
||||||
#![cfg_attr(rustfmt, rustfmt_skip)]
|
#![cfg_attr(rustfmt, rustfmt_skip)]
|
||||||
@@ -62,197 +59,197 @@ pub trait WeightInfo {
|
|||||||
/// Weights for pallet_asset_conversion using the Substrate node and recommended hardware.
|
/// Weights for pallet_asset_conversion using the Substrate node and recommended hardware.
|
||||||
pub struct SubstrateWeight<T>(PhantomData<T>);
|
pub struct SubstrateWeight<T>(PhantomData<T>);
|
||||||
impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
|
impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
|
||||||
/// Storage: AssetConversion Pools (r:1 w:1)
|
/// Storage: `AssetConversion::Pools` (r:1 w:1)
|
||||||
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen)
|
/// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
|
||||||
/// Storage: System Account (r:2 w:2)
|
/// Storage: `System::Account` (r:2 w:2)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:1 w:1)
|
/// Storage: `Assets::Account` (r:1 w:1)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Asset (r:1 w:1)
|
/// Storage: `Assets::Asset` (r:1 w:1)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: AssetConversion NextPoolAssetId (r:1 w:1)
|
/// Storage: `AssetConversion::NextPoolAssetId` (r:1 w:1)
|
||||||
/// Proof: AssetConversion NextPoolAssetId (max_values: Some(1), max_size: Some(4), added: 499, mode: MaxEncodedLen)
|
/// Proof: `AssetConversion::NextPoolAssetId` (`max_values`: Some(1), `max_size`: Some(4), added: 499, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Asset (r:1 w:1)
|
/// Storage: `PoolAssets::Asset` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Account (r:1 w:1)
|
/// Storage: `PoolAssets::Account` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
fn create_pool() -> Weight {
|
fn create_pool() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `729`
|
// Measured: `729`
|
||||||
// Estimated: `6196`
|
// Estimated: `6196`
|
||||||
// Minimum execution time: 129_741_000 picoseconds.
|
// Minimum execution time: 131_549_000 picoseconds.
|
||||||
Weight::from_parts(132_516_000, 6196)
|
Weight::from_parts(134_287_000, 6196)
|
||||||
.saturating_add(T::DbWeight::get().reads(8_u64))
|
.saturating_add(T::DbWeight::get().reads(8_u64))
|
||||||
.saturating_add(T::DbWeight::get().writes(8_u64))
|
.saturating_add(T::DbWeight::get().writes(8_u64))
|
||||||
}
|
}
|
||||||
/// Storage: AssetConversion Pools (r:1 w:0)
|
/// Storage: `AssetConversion::Pools` (r:1 w:0)
|
||||||
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen)
|
/// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
|
||||||
/// Storage: System Account (r:1 w:1)
|
/// Storage: `System::Account` (r:1 w:1)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Asset (r:1 w:1)
|
/// Storage: `Assets::Asset` (r:1 w:1)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:2 w:2)
|
/// Storage: `Assets::Account` (r:2 w:2)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Asset (r:1 w:1)
|
/// Storage: `PoolAssets::Asset` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Account (r:2 w:2)
|
/// Storage: `PoolAssets::Account` (r:2 w:2)
|
||||||
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
fn add_liquidity() -> Weight {
|
fn add_liquidity() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `1382`
|
// Measured: `1382`
|
||||||
// Estimated: `6208`
|
// Estimated: `6208`
|
||||||
// Minimum execution time: 154_821_000 picoseconds.
|
// Minimum execution time: 156_395_000 picoseconds.
|
||||||
Weight::from_parts(157_855_000, 6208)
|
Weight::from_parts(157_952_000, 6208)
|
||||||
.saturating_add(T::DbWeight::get().reads(8_u64))
|
.saturating_add(T::DbWeight::get().reads(8_u64))
|
||||||
.saturating_add(T::DbWeight::get().writes(7_u64))
|
.saturating_add(T::DbWeight::get().writes(7_u64))
|
||||||
}
|
}
|
||||||
/// Storage: AssetConversion Pools (r:1 w:0)
|
/// Storage: `AssetConversion::Pools` (r:1 w:0)
|
||||||
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen)
|
/// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
|
||||||
/// Storage: System Account (r:1 w:1)
|
/// Storage: `System::Account` (r:1 w:1)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Asset (r:1 w:1)
|
/// Storage: `Assets::Asset` (r:1 w:1)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:2 w:2)
|
/// Storage: `Assets::Account` (r:2 w:2)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Asset (r:1 w:1)
|
/// Storage: `PoolAssets::Asset` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Account (r:1 w:1)
|
/// Storage: `PoolAssets::Account` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
fn remove_liquidity() -> Weight {
|
fn remove_liquidity() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `1371`
|
// Measured: `1371`
|
||||||
// Estimated: `6208`
|
// Estimated: `6208`
|
||||||
// Minimum execution time: 139_490_000 picoseconds.
|
// Minimum execution time: 140_295_000 picoseconds.
|
||||||
Weight::from_parts(143_626_000, 6208)
|
Weight::from_parts(143_452_000, 6208)
|
||||||
.saturating_add(T::DbWeight::get().reads(7_u64))
|
.saturating_add(T::DbWeight::get().reads(7_u64))
|
||||||
.saturating_add(T::DbWeight::get().writes(6_u64))
|
.saturating_add(T::DbWeight::get().writes(6_u64))
|
||||||
}
|
}
|
||||||
/// Storage: System Account (r:1 w:1)
|
/// Storage: `System::Account` (r:1 w:1)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Asset (r:3 w:3)
|
/// Storage: `Assets::Asset` (r:3 w:3)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:6 w:6)
|
/// Storage: `Assets::Account` (r:6 w:6)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
fn swap_exact_tokens_for_tokens() -> Weight {
|
fn swap_exact_tokens_for_tokens() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `1732`
|
// Measured: `1738`
|
||||||
// Estimated: `16644`
|
// Estimated: `16644`
|
||||||
// Minimum execution time: 212_868_000 picoseconds.
|
// Minimum execution time: 214_657_000 picoseconds.
|
||||||
Weight::from_parts(221_638_000, 16644)
|
Weight::from_parts(217_657_000, 16644)
|
||||||
.saturating_add(T::DbWeight::get().reads(10_u64))
|
.saturating_add(T::DbWeight::get().reads(10_u64))
|
||||||
.saturating_add(T::DbWeight::get().writes(10_u64))
|
.saturating_add(T::DbWeight::get().writes(10_u64))
|
||||||
}
|
}
|
||||||
/// Storage: Assets Asset (r:3 w:3)
|
/// Storage: `Assets::Asset` (r:3 w:3)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:6 w:6)
|
/// Storage: `Assets::Account` (r:6 w:6)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
/// Storage: System Account (r:1 w:1)
|
/// Storage: `System::Account` (r:1 w:1)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
fn swap_tokens_for_exact_tokens() -> Weight {
|
fn swap_tokens_for_exact_tokens() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `1732`
|
// Measured: `1738`
|
||||||
// Estimated: `16644`
|
// Estimated: `16644`
|
||||||
// Minimum execution time: 211_746_000 picoseconds.
|
// Minimum execution time: 215_319_000 picoseconds.
|
||||||
Weight::from_parts(217_322_000, 16644)
|
Weight::from_parts(218_299_000, 16644)
|
||||||
.saturating_add(T::DbWeight::get().reads(10_u64))
|
.saturating_add(T::DbWeight::get().reads(10_u64))
|
||||||
.saturating_add(T::DbWeight::get().writes(10_u64))
|
.saturating_add(T::DbWeight::get().writes(10_u64))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// For backwards compatibility and tests
|
// For backwards compatibility and tests.
|
||||||
impl WeightInfo for () {
|
impl WeightInfo for () {
|
||||||
/// Storage: AssetConversion Pools (r:1 w:1)
|
/// Storage: `AssetConversion::Pools` (r:1 w:1)
|
||||||
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen)
|
/// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
|
||||||
/// Storage: System Account (r:2 w:2)
|
/// Storage: `System::Account` (r:2 w:2)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:1 w:1)
|
/// Storage: `Assets::Account` (r:1 w:1)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Asset (r:1 w:1)
|
/// Storage: `Assets::Asset` (r:1 w:1)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: AssetConversion NextPoolAssetId (r:1 w:1)
|
/// Storage: `AssetConversion::NextPoolAssetId` (r:1 w:1)
|
||||||
/// Proof: AssetConversion NextPoolAssetId (max_values: Some(1), max_size: Some(4), added: 499, mode: MaxEncodedLen)
|
/// Proof: `AssetConversion::NextPoolAssetId` (`max_values`: Some(1), `max_size`: Some(4), added: 499, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Asset (r:1 w:1)
|
/// Storage: `PoolAssets::Asset` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Account (r:1 w:1)
|
/// Storage: `PoolAssets::Account` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
fn create_pool() -> Weight {
|
fn create_pool() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `729`
|
// Measured: `729`
|
||||||
// Estimated: `6196`
|
// Estimated: `6196`
|
||||||
// Minimum execution time: 129_741_000 picoseconds.
|
// Minimum execution time: 131_549_000 picoseconds.
|
||||||
Weight::from_parts(132_516_000, 6196)
|
Weight::from_parts(134_287_000, 6196)
|
||||||
.saturating_add(RocksDbWeight::get().reads(8_u64))
|
.saturating_add(RocksDbWeight::get().reads(8_u64))
|
||||||
.saturating_add(RocksDbWeight::get().writes(8_u64))
|
.saturating_add(RocksDbWeight::get().writes(8_u64))
|
||||||
}
|
}
|
||||||
/// Storage: AssetConversion Pools (r:1 w:0)
|
/// Storage: `AssetConversion::Pools` (r:1 w:0)
|
||||||
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen)
|
/// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
|
||||||
/// Storage: System Account (r:1 w:1)
|
/// Storage: `System::Account` (r:1 w:1)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Asset (r:1 w:1)
|
/// Storage: `Assets::Asset` (r:1 w:1)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:2 w:2)
|
/// Storage: `Assets::Account` (r:2 w:2)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Asset (r:1 w:1)
|
/// Storage: `PoolAssets::Asset` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Account (r:2 w:2)
|
/// Storage: `PoolAssets::Account` (r:2 w:2)
|
||||||
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
fn add_liquidity() -> Weight {
|
fn add_liquidity() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `1382`
|
// Measured: `1382`
|
||||||
// Estimated: `6208`
|
// Estimated: `6208`
|
||||||
// Minimum execution time: 154_821_000 picoseconds.
|
// Minimum execution time: 156_395_000 picoseconds.
|
||||||
Weight::from_parts(157_855_000, 6208)
|
Weight::from_parts(157_952_000, 6208)
|
||||||
.saturating_add(RocksDbWeight::get().reads(8_u64))
|
.saturating_add(RocksDbWeight::get().reads(8_u64))
|
||||||
.saturating_add(RocksDbWeight::get().writes(7_u64))
|
.saturating_add(RocksDbWeight::get().writes(7_u64))
|
||||||
}
|
}
|
||||||
/// Storage: AssetConversion Pools (r:1 w:0)
|
/// Storage: `AssetConversion::Pools` (r:1 w:0)
|
||||||
/// Proof: AssetConversion Pools (max_values: None, max_size: Some(30), added: 2505, mode: MaxEncodedLen)
|
/// Proof: `AssetConversion::Pools` (`max_values`: None, `max_size`: Some(30), added: 2505, mode: `MaxEncodedLen`)
|
||||||
/// Storage: System Account (r:1 w:1)
|
/// Storage: `System::Account` (r:1 w:1)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Asset (r:1 w:1)
|
/// Storage: `Assets::Asset` (r:1 w:1)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:2 w:2)
|
/// Storage: `Assets::Account` (r:2 w:2)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Asset (r:1 w:1)
|
/// Storage: `PoolAssets::Asset` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: PoolAssets Account (r:1 w:1)
|
/// Storage: `PoolAssets::Account` (r:1 w:1)
|
||||||
/// Proof: PoolAssets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `PoolAssets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
fn remove_liquidity() -> Weight {
|
fn remove_liquidity() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `1371`
|
// Measured: `1371`
|
||||||
// Estimated: `6208`
|
// Estimated: `6208`
|
||||||
// Minimum execution time: 139_490_000 picoseconds.
|
// Minimum execution time: 140_295_000 picoseconds.
|
||||||
Weight::from_parts(143_626_000, 6208)
|
Weight::from_parts(143_452_000, 6208)
|
||||||
.saturating_add(RocksDbWeight::get().reads(7_u64))
|
.saturating_add(RocksDbWeight::get().reads(7_u64))
|
||||||
.saturating_add(RocksDbWeight::get().writes(6_u64))
|
.saturating_add(RocksDbWeight::get().writes(6_u64))
|
||||||
}
|
}
|
||||||
/// Storage: System Account (r:1 w:1)
|
/// Storage: `System::Account` (r:1 w:1)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Asset (r:3 w:3)
|
/// Storage: `Assets::Asset` (r:3 w:3)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:6 w:6)
|
/// Storage: `Assets::Account` (r:6 w:6)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
fn swap_exact_tokens_for_tokens() -> Weight {
|
fn swap_exact_tokens_for_tokens() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `1732`
|
// Measured: `1738`
|
||||||
// Estimated: `16644`
|
// Estimated: `16644`
|
||||||
// Minimum execution time: 212_868_000 picoseconds.
|
// Minimum execution time: 214_657_000 picoseconds.
|
||||||
Weight::from_parts(221_638_000, 16644)
|
Weight::from_parts(217_657_000, 16644)
|
||||||
.saturating_add(RocksDbWeight::get().reads(10_u64))
|
.saturating_add(RocksDbWeight::get().reads(10_u64))
|
||||||
.saturating_add(RocksDbWeight::get().writes(10_u64))
|
.saturating_add(RocksDbWeight::get().writes(10_u64))
|
||||||
}
|
}
|
||||||
/// Storage: Assets Asset (r:3 w:3)
|
/// Storage: `Assets::Asset` (r:3 w:3)
|
||||||
/// Proof: Assets Asset (max_values: None, max_size: Some(210), added: 2685, mode: MaxEncodedLen)
|
/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(210), added: 2685, mode: `MaxEncodedLen`)
|
||||||
/// Storage: Assets Account (r:6 w:6)
|
/// Storage: `Assets::Account` (r:6 w:6)
|
||||||
/// Proof: Assets Account (max_values: None, max_size: Some(134), added: 2609, mode: MaxEncodedLen)
|
/// Proof: `Assets::Account` (`max_values`: None, `max_size`: Some(134), added: 2609, mode: `MaxEncodedLen`)
|
||||||
/// Storage: System Account (r:1 w:1)
|
/// Storage: `System::Account` (r:1 w:1)
|
||||||
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode: MaxEncodedLen)
|
/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `MaxEncodedLen`)
|
||||||
fn swap_tokens_for_exact_tokens() -> Weight {
|
fn swap_tokens_for_exact_tokens() -> Weight {
|
||||||
// Proof Size summary in bytes:
|
// Proof Size summary in bytes:
|
||||||
// Measured: `1732`
|
// Measured: `1738`
|
||||||
// Estimated: `16644`
|
// Estimated: `16644`
|
||||||
// Minimum execution time: 211_746_000 picoseconds.
|
// Minimum execution time: 215_319_000 picoseconds.
|
||||||
Weight::from_parts(217_322_000, 16644)
|
Weight::from_parts(218_299_000, 16644)
|
||||||
.saturating_add(RocksDbWeight::get().reads(10_u64))
|
.saturating_add(RocksDbWeight::get().reads(10_u64))
|
||||||
.saturating_add(RocksDbWeight::get().writes(10_u64))
|
.saturating_add(RocksDbWeight::get().writes(10_u64))
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user