mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-08 22:58:00 +00:00
bda8641892
* Draft of new sessions * Reintroduce tuple impls * Move staking module to new session API * More work on staking and grandpa. * Use iterator to avoid cloning and tuple macro * Make runtime build again * Polish the OpaqueKeys devex * Move consensus logic into system & aura. * Fix up system module * Get build mostly going. Stuck at service.rs * Building again * Update srml/staking/src/lib.rs Co-Authored-By: DemiMarie-parity <48690212+DemiMarie-parity@users.noreply.github.com> * Refactoring out Consensus module, AuthorityIdOf, &c. * Refactored out DigestItem::AuthoritiesChanged. Building. * Remove tentative code * Remove invalid comment * Make Seal opaque and introduce nice methods for handling opaque items. * Start to use proper digest for Aura authorities tracking. * Fix up grandpa, remove system::Raw/Log * Refactor Grandpa to use new logging infrastructure. Also make authorityid/sessionkey static. Switch over to storing authorities in a straight Vec. * Building again * Tidy up some AuthorityIds * Expunge most of the rest of the AuthorityKey confusion. Also, de-generify Babe and re-generify Aura. * Remove cruft * Untangle last of the `AuthorityId`s. * Sort out finality_tracker * Refactor median getting * Apply suggestions from code review Co-Authored-By: Robert Habermeier <rphmeier@gmail.com> * Session tests works * Update core/sr-primitives/src/generic/digest.rs Co-Authored-By: DemiMarie-parity <48690212+DemiMarie-parity@users.noreply.github.com> * Session tests works * Fix for staking from @dvc94ch * log an error * fix test runtime build * Some test fixes * Staking mock update to new session api. * Fix build. * Move OpaqueKeys to primitives. * Use on_initialize instead of check_rotate_session. * Update tests to new staking api. * fixup mock * Fix bond_extra_and_withdraw_unbonded_works. * Fix bond_with_little_staked_value_bounded_by_slot_stake. * Fix bond_with_no_staked_value. * Fix change_controller_works. * Fix less_than_needed_candidates_works. * Fix multi_era_reward_should_work. * Fix nominating_and_rewards_should_work. * Fix nominators_also_get_slashed. * Fix phragmen_large_scale_test. * Fix phragmen_poc_works. * Fix phragmen_score_should_be_accurate_on_large_stakes. * Fix phragmen_should_not_overflow. * Fix reward_destination_works. * Fix rewards_should_work. * Fix sessions_and_eras_should_work. * Fix slot_stake_is_least_staked_validator. * Fix too_many_unbond_calls_should_not_work. * Fix wrong_vote_is_null. * Fix runtime. * Fix wasm runtime build. * Update Cargo.lock * Fix warnings. * Fix grandpa tests. * Fix test-runtime build. * Fix template node build. * Fix stuff. * Update Cargo.lock to fix CI * Re-add missing AuRa logs Runtimes are required to know about every digest they receive ― they panic otherwise. This re-adds support for AuRa pre-runtime digests. * Update core/consensus/babe/src/digest.rs Co-Authored-By: DemiMarie-parity <48690212+DemiMarie-parity@users.noreply.github.com> * Kill log trait and all that jazz. * Refactor staking tests. * Fix ci runtime wasm check. * Line length 120. * Make tests build again * Remove trailing commas in function declarations The `extern_functions!` macro doesn’t like them, perhaps due to a bug in rustc. * Fix type error * Fix compilation errors * Fix a test * Another couple of fixes * Fix another test * More test fixes * Another test fix * Bump runtime. * Wrap long line * Fix build, remove redundant code. * Issue to track TODO * Leave the benchmark code alone. * Fix missing `std::time::{Instant, Duration}` * Indentation * Aura ConsensusLog as enum
95 lines
2.9 KiB
Rust
95 lines
2.9 KiB
Rust
// Copyright 2019 Parity Technologies
|
|
//
|
|
// 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.
|
|
|
|
|
|
#[macro_use]
|
|
extern crate criterion;
|
|
|
|
use criterion::{Criterion, black_box, Bencher, Fun};
|
|
use std::time::Duration;
|
|
use substrate_primitives::crypto::Pair as _;
|
|
use substrate_primitives::hashing::{twox_128, blake2_128};
|
|
|
|
const MAX_KEY_SIZE: u32 = 32;
|
|
|
|
fn get_key(key_size: u32) -> Vec<u8> {
|
|
use rand::SeedableRng;
|
|
use rand::Rng;
|
|
|
|
let rnd: [u8; 32] = rand::rngs::StdRng::seed_from_u64(12).gen();
|
|
let mut rnd = rnd.iter().cycle();
|
|
|
|
(0..key_size)
|
|
.map(|_| rnd.next().unwrap().clone())
|
|
.collect()
|
|
}
|
|
|
|
fn bench_blake2_128(b: &mut Bencher, key: &Vec<u8>) {
|
|
b.iter(|| {
|
|
let _a = blake2_128(black_box(key));
|
|
});
|
|
}
|
|
|
|
fn bench_twox_128(b: &mut Bencher, key: &Vec<u8>) {
|
|
b.iter(|| {
|
|
let _a = twox_128(black_box(key));
|
|
});
|
|
}
|
|
|
|
fn bench_hash_128_fix_size(c: &mut Criterion) {
|
|
let key = get_key(MAX_KEY_SIZE);
|
|
let blake_fn = Fun::new("blake2_128", bench_blake2_128);
|
|
let twox_fn = Fun::new("twox_128", bench_twox_128);
|
|
let fns = vec![blake_fn, twox_fn];
|
|
|
|
c.bench_functions("fixed size hashing", fns, key);
|
|
}
|
|
|
|
fn bench_hash_128_dyn_size(c: &mut Criterion) {
|
|
let mut keys = Vec::new();
|
|
for i in (2..MAX_KEY_SIZE).step_by(4) {
|
|
keys.push(get_key(i).clone())
|
|
}
|
|
|
|
c.bench_function_over_inputs("dyn size hashing - blake2", |b, key| bench_blake2_128(b, &key), keys.clone());
|
|
c.bench_function_over_inputs("dyn size hashing - twox", |b, key| bench_twox_128(b, &key), keys);
|
|
}
|
|
|
|
fn bench_ed25519(c: &mut Criterion) {
|
|
c.bench_function_over_inputs("signing - ed25519", |b, &msg_size| {
|
|
let msg = (0..msg_size)
|
|
.map(|_| rand::random::<u8>())
|
|
.collect::<Vec<_>>();
|
|
let key = substrate_primitives::ed25519::Pair::generate().0;
|
|
b.iter(|| key.sign(&msg))
|
|
}, vec![32, 1024, 1024 * 1024]);
|
|
|
|
c.bench_function_over_inputs("verifying - ed25519", |b, &msg_size| {
|
|
let msg = (0..msg_size)
|
|
.map(|_| rand::random::<u8>())
|
|
.collect::<Vec<_>>();
|
|
let key = substrate_primitives::ed25519::Pair::generate().0;
|
|
let sig = key.sign(&msg);
|
|
let public = key.public();
|
|
b.iter(|| substrate_primitives::ed25519::Pair::verify(&sig, &msg, &public))
|
|
}, vec![32, 1024, 1024 * 1024]);
|
|
}
|
|
|
|
criterion_group!{
|
|
name = benches;
|
|
config = Criterion::default().warm_up_time(Duration::from_millis(500)).without_plots();
|
|
targets = bench_hash_128_fix_size, bench_hash_128_dyn_size, bench_ed25519
|
|
}
|
|
criterion_main!(benches);
|