* address warnings from 'rustup run beta cargo clippy --workspace' minor refactoring in: - cli/src/cli.rs - cli/src/offline/blockhash_query.rs - logger/src/lib.rs - runtime/src/accounts_db.rs expect some performance improvement AccountsDB::clean_accounts() * address warnings from 'rustup run beta cargo clippy --workspace --tests' * address warnings from 'rustup run nightly cargo clippy --workspace --all-targets' * rustfmt * fix warning stragglers * properly fix clippy warnings test_vote_subscribe() replace ref-to-arc with ref parameters where arc not cloned * Remove lock around JsonRpcRequestProcessor (#10417) automerge * make ancestors parameter optional to avoid forcing construction of empty hash maps Co-authored-by: Greg Fitzgerald <greg@solana.com>
36 lines
983 B
Rust
36 lines
983 B
Rust
#![feature(test)]
|
|
|
|
extern crate test;
|
|
|
|
use bincode::serialize;
|
|
use solana_runtime::status_cache::*;
|
|
use solana_sdk::{
|
|
hash::{hash, Hash},
|
|
signature::Signature,
|
|
};
|
|
use test::Bencher;
|
|
|
|
type BankStatusCache = StatusCache<()>;
|
|
|
|
#[bench]
|
|
fn test_statuscache_serialize(bencher: &mut Bencher) {
|
|
let mut status_cache = BankStatusCache::default();
|
|
status_cache.add_root(0);
|
|
status_cache.clear_signatures();
|
|
for hash_index in 0..100 {
|
|
let blockhash = Hash::new(&vec![hash_index; std::mem::size_of::<Hash>()]);
|
|
let mut id = blockhash;
|
|
for _ in 0..100 {
|
|
id = hash(id.as_ref());
|
|
let mut sigbytes = Vec::from(id.as_ref());
|
|
id = hash(id.as_ref());
|
|
sigbytes.extend(id.as_ref());
|
|
let sig = Signature::new(&sigbytes);
|
|
status_cache.insert(&blockhash, &sig, 0, ());
|
|
}
|
|
}
|
|
bencher.iter(|| {
|
|
let _ = serialize(&status_cache.slot_deltas(&[0])).unwrap();
|
|
});
|
|
}
|