mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-24 20:41:14 +00:00
bc2b3d9d28
* make reexports private * make reexports private 2 * make reexports private for runtime-benchmarking * make reexports private for try-runtime * fix for try-runtime * make reexports private for tests * fmt * make reexports private for tests * make reexports private for experimental * fix beefy * fix ui test * fix ui test * fix benches * ".git/.scripts/commands/fmt/fmt.sh" * fix contracts use * wip * wip * do not reexport sp_api::metadata_ir * fix CI checks * fix support tests * ".git/.scripts/commands/fmt/fmt.sh" * Update frame/support/src/lib.rs Co-authored-by: Bastian Köcher <git@kchr.de> * import codec directly * fmt * wip * wip * remove benchmarking private exports * fix zepter warning * fix imports * partially fix node-cli tests * fix node-cli tests * fix node-cli build * fix zepter warning * fix test * fix ui test * fix ci * remove unnecessary imports * add import back * add import back --------- Co-authored-by: command-bot <> Co-authored-by: Bastian Köcher <git@kchr.de>
165 lines
4.0 KiB
Rust
165 lines
4.0 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
//! A set of benchmarks which can establish a global baseline for all other
|
|
//! benchmarking. These benchmarks do not require a pallet to be deployed.
|
|
|
|
#![cfg(feature = "runtime-benchmarks")]
|
|
|
|
use crate::benchmarks;
|
|
use frame_system::Pallet as System;
|
|
use sp_runtime::{
|
|
traits::{AppVerify, Hash},
|
|
RuntimeAppPublic,
|
|
};
|
|
use sp_std::{vec, vec::Vec};
|
|
|
|
mod crypto {
|
|
use sp_application_crypto::{app_crypto, sr25519, KeyTypeId};
|
|
|
|
pub const TEST_KEY_TYPE_ID: KeyTypeId = KeyTypeId(*b"test");
|
|
app_crypto!(sr25519, TEST_KEY_TYPE_ID);
|
|
}
|
|
pub type SignerId = crypto::Public;
|
|
|
|
pub struct Pallet<T: Config>(System<T>);
|
|
pub trait Config: frame_system::Config {}
|
|
|
|
benchmarks! {
|
|
addition {
|
|
let i in 0 .. 1_000_000;
|
|
let mut start = 0;
|
|
}: {
|
|
(0..i).for_each(|_| start += 1);
|
|
} verify {
|
|
assert_eq!(start, i);
|
|
}
|
|
|
|
subtraction {
|
|
let i in 0 .. 1_000_000;
|
|
let mut start = u32::MAX;
|
|
}: {
|
|
(0..i).for_each(|_| start -= 1);
|
|
} verify {
|
|
assert_eq!(start, u32::MAX - i);
|
|
}
|
|
|
|
multiplication {
|
|
let i in 0 .. 1_000_000;
|
|
let mut out = 0;
|
|
}: {
|
|
(1..=i).for_each(|j| out = 2 * j);
|
|
} verify {
|
|
assert_eq!(out, 2 * i);
|
|
}
|
|
|
|
division {
|
|
let i in 0 .. 1_000_000;
|
|
let mut out = 0;
|
|
}: {
|
|
(0..=i).for_each(|j| out = j / 2);
|
|
} verify {
|
|
assert_eq!(out, i / 2);
|
|
}
|
|
|
|
hashing {
|
|
let mut hash = T::Hash::default();
|
|
}: {
|
|
(0..=100_000u32).for_each(|j| hash = T::Hashing::hash(&j.to_be_bytes()));
|
|
} verify {
|
|
assert!(hash != T::Hash::default());
|
|
}
|
|
|
|
sr25519_verification {
|
|
let i in 0 .. 100;
|
|
|
|
let public = SignerId::generate_pair(None);
|
|
|
|
let sigs_count: u8 = i.try_into().unwrap();
|
|
let msg_and_sigs: Vec<_> = (0..sigs_count).map(|j| {
|
|
let msg = vec![j, j];
|
|
(msg.clone(), public.sign(&msg).unwrap())
|
|
})
|
|
.collect();
|
|
}: {
|
|
msg_and_sigs.iter().for_each(|(msg, sig)| {
|
|
assert!(sig.verify(&msg[..], &public));
|
|
});
|
|
}
|
|
|
|
impl_benchmark_test_suite!(
|
|
Pallet,
|
|
mock::new_test_ext(),
|
|
mock::Test,
|
|
);
|
|
}
|
|
|
|
#[cfg(test)]
|
|
pub mod mock {
|
|
use sp_runtime::{testing::H256, BuildStorage};
|
|
|
|
type AccountId = u64;
|
|
type Nonce = u32;
|
|
|
|
type Block = frame_system::mocking::MockBlock<Test>;
|
|
|
|
frame_support::construct_runtime!(
|
|
pub enum Test
|
|
{
|
|
System: frame_system::{Pallet, Call, Config<T>, Storage, Event<T>},
|
|
}
|
|
);
|
|
|
|
impl frame_system::Config for Test {
|
|
type BaseCallFilter = frame_support::traits::Everything;
|
|
type BlockWeights = ();
|
|
type BlockLength = ();
|
|
type DbWeight = ();
|
|
type RuntimeOrigin = RuntimeOrigin;
|
|
type Nonce = Nonce;
|
|
type RuntimeCall = RuntimeCall;
|
|
type Hash = H256;
|
|
type Hashing = ::sp_runtime::traits::BlakeTwo256;
|
|
type AccountId = AccountId;
|
|
type Lookup = sp_runtime::traits::IdentityLookup<Self::AccountId>;
|
|
type Block = Block;
|
|
type RuntimeEvent = RuntimeEvent;
|
|
type BlockHashCount = ();
|
|
type Version = ();
|
|
type PalletInfo = PalletInfo;
|
|
type AccountData = ();
|
|
type OnNewAccount = ();
|
|
type OnKilledAccount = ();
|
|
type SystemWeightInfo = ();
|
|
type SS58Prefix = ();
|
|
type OnSetCode = ();
|
|
type MaxConsumers = frame_support::traits::ConstU32<16>;
|
|
}
|
|
|
|
impl super::Config for Test {}
|
|
|
|
pub fn new_test_ext() -> sp_io::TestExternalities {
|
|
use sp_keystore::{testing::MemoryKeystore, KeystoreExt};
|
|
|
|
let t = frame_system::GenesisConfig::<Test>::default().build_storage().unwrap();
|
|
let mut ext = sp_io::TestExternalities::new(t);
|
|
ext.register_extension(KeystoreExt::new(MemoryKeystore::new()));
|
|
|
|
ext
|
|
}
|
|
}
|