1
// Copyright 2024 Moonbeam foundation
2
// This file is part of Moonbeam.
3

            
4
// Moonbeam is free software: you can redistribute it and/or modify
5
// it under the terms of the GNU General Public License as published by
6
// the Free Software Foundation, either version 3 of the License, or
7
// (at your option) any later version.
8

            
9
// Moonbeam is distributed in the hope that it will be useful,
10
// but WITHOUT ANY WARRANTY; without even the implied warranty of
11
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
// GNU General Public License for more details.
13

            
14
// You should have received a copy of the GNU General Public License
15
// along with Moonbeam.  If not, see <http://www.gnu.org/licenses/>.
16

            
17
//! Autogenerated weights for `pallet_asset_manager`
18
//!
19
//! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 42.0.0
20
//! DATE: 2024-10-10, STEPS: `50`, REPEAT: `20`, LOW RANGE: `[]`, HIGH RANGE: `[]`
21
//! WORST CASE MAP SIZE: `1000000`
22
//! HOSTNAME: `ip-10-0-0-176`, CPU: `Intel(R) Xeon(R) Platinum 8375C CPU @ 2.90GHz`
23
//! WASM-EXECUTION: Compiled, CHAIN: Some("moonbase-dev"), DB CACHE: 1024
24

            
25
// Executed Command:
26
// ./target/production/moonbeam
27
// benchmark
28
// pallet
29
// --chain=moonbase-dev
30
// --steps=50
31
// --repeat=20
32
// --pallet=pallet_asset_manager
33
// --extrinsic=*
34
// --wasm-execution=compiled
35
// --header=./file_header.txt
36
// --template=./benchmarking/frame-weight-template.hbs
37
// --output=./runtime/common/src/weights/
38

            
39
#![cfg_attr(rustfmt, rustfmt_skip)]
40
#![allow(unused_parens)]
41
#![allow(unused_imports)]
42

            
43
use frame_support::{traits::Get, weights::{Weight, constants::RocksDbWeight}};
44
use sp_std::marker::PhantomData;
45

            
46
/// Weights for `pallet_asset_manager`.
47
pub struct WeightInfo<T>(PhantomData<T>);
48
impl<T: frame_system::Config> pallet_asset_manager::WeightInfo for WeightInfo<T> {
49
	/// Storage: `AssetManager::AssetIdType` (r:1 w:1)
50
	/// Proof: `AssetManager::AssetIdType` (`max_values`: None, `max_size`: None, mode: `Measured`)
51
	/// Storage: `Assets::Asset` (r:1 w:1)
52
	/// Proof: `Assets::Asset` (`max_values`: None, `max_size`: Some(174), added: 2649, mode: `MaxEncodedLen`)
53
	/// Storage: `Assets::NextAssetId` (r:1 w:0)
54
	/// Proof: `Assets::NextAssetId` (`max_values`: Some(1), `max_size`: Some(16), added: 511, mode: `MaxEncodedLen`)
55
	/// Storage: `Assets::Metadata` (r:1 w:1)
56
	/// Proof: `Assets::Metadata` (`max_values`: None, `max_size`: Some(152), added: 2627, mode: `MaxEncodedLen`)
57
	/// Storage: `AssetManager::AssetTypeId` (r:0 w:1)
58
	/// Proof: `AssetManager::AssetTypeId` (`max_values`: None, `max_size`: None, mode: `Measured`)
59
	fn register_foreign_asset() -> Weight {
60
		// Proof Size summary in bytes:
61
		//  Measured:  `82`
62
		//  Estimated: `3639`
63
		// Minimum execution time: 29_430_000 picoseconds.
64
		Weight::from_parts(30_152_000, 3639)
65
			.saturating_add(T::DbWeight::get().reads(4_u64))
66
			.saturating_add(T::DbWeight::get().writes(4_u64))
67
	}
68
	/// Storage: `AssetManager::AssetIdType` (r:1 w:1)
69
	/// Proof: `AssetManager::AssetIdType` (`max_values`: None, `max_size`: None, mode: `Measured`)
70
	/// Storage: `AssetManager::AssetTypeId` (r:0 w:2)
71
	/// Proof: `AssetManager::AssetTypeId` (`max_values`: None, `max_size`: None, mode: `Measured`)
72
	/// The range of component `x` is `[5, 100]`.
73
	fn change_existing_asset_type() -> Weight {
74
		// Proof Size summary in bytes:
75
		//  Measured:  `447 + x * (4 ±0)`
76
		//  Estimated: `3909 + x * (5 ±0)`
77
		// Minimum execution time: 16_773_000 picoseconds.
78
		Weight::from_parts(18_536_714, 3909)
79
			// Standard Error: 1_512
80
			.saturating_add(Weight::from_parts(79_685, 0))
81
			.saturating_add(T::DbWeight::get().reads(1_u64))
82
			.saturating_add(T::DbWeight::get().writes(3_u64))
83
			.saturating_add(Weight::from_parts(0, 5))
84
	}
85
	/// Storage: `AssetManager::AssetIdType` (r:1 w:1)
86
	/// Proof: `AssetManager::AssetIdType` (`max_values`: None, `max_size`: None, mode: `Measured`)
87
	/// Storage: `AssetManager::AssetTypeId` (r:0 w:1)
88
	/// Proof: `AssetManager::AssetTypeId` (`max_values`: None, `max_size`: None, mode: `Measured`)
89
	/// The range of component `x` is `[5, 100]`.
90
	fn remove_existing_asset_type() -> Weight {
91
		// Proof Size summary in bytes:
92
		//  Measured:  `447 + x * (4 ±0)`
93
		//  Estimated: `3909 + x * (5 ±0)`
94
		// Minimum execution time: 14_226_000 picoseconds.
95
		Weight::from_parts(15_816_525, 3909)
96
			// Standard Error: 1_445
97
			.saturating_add(Weight::from_parts(78_038, 0))
98
			.saturating_add(T::DbWeight::get().reads(1_u64))
99
			.saturating_add(T::DbWeight::get().writes(2_u64))
100
			.saturating_add(Weight::from_parts(0, 5))
101
	}
102
}