* 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>
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
#![feature(test)]
 | 
						|
 | 
						|
extern crate test;
 | 
						|
 | 
						|
use rand::{thread_rng, Rng};
 | 
						|
use solana_runtime::{accounts_db::AccountInfo, accounts_index::AccountsIndex};
 | 
						|
use solana_sdk::pubkey::Pubkey;
 | 
						|
use test::Bencher;
 | 
						|
 | 
						|
#[bench]
 | 
						|
fn bench_accounts_index(bencher: &mut Bencher) {
 | 
						|
    const NUM_PUBKEYS: usize = 10_000;
 | 
						|
    let pubkeys: Vec<_> = (0..NUM_PUBKEYS).map(|_| Pubkey::new_rand()).collect();
 | 
						|
 | 
						|
    const NUM_FORKS: u64 = 16;
 | 
						|
 | 
						|
    let mut reclaims = vec![];
 | 
						|
    let mut index = AccountsIndex::<AccountInfo>::default();
 | 
						|
    for f in 0..NUM_FORKS {
 | 
						|
        for pubkey in pubkeys.iter().take(NUM_PUBKEYS) {
 | 
						|
            index.insert(f, pubkey, AccountInfo::default(), &mut reclaims);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    let mut fork = NUM_FORKS;
 | 
						|
    let mut root = 0;
 | 
						|
    bencher.iter(|| {
 | 
						|
        for _p in 0..NUM_PUBKEYS {
 | 
						|
            let pubkey = thread_rng().gen_range(0, NUM_PUBKEYS);
 | 
						|
            index.insert(
 | 
						|
                fork,
 | 
						|
                &pubkeys[pubkey],
 | 
						|
                AccountInfo::default(),
 | 
						|
                &mut reclaims,
 | 
						|
            );
 | 
						|
            reclaims.clear();
 | 
						|
        }
 | 
						|
        index.add_root(root);
 | 
						|
        root += 1;
 | 
						|
        fork += 1;
 | 
						|
    });
 | 
						|
}
 |