diff --git a/accounts-db/src/accounts_db.rs b/accounts-db/src/accounts_db.rs index e87b31af11f12b..f29341e3c17760 100644 --- a/accounts-db/src/accounts_db.rs +++ b/accounts-db/src/accounts_db.rs @@ -66,7 +66,9 @@ use { cache_hash_data::{CacheHashData, DeletionPolicy as CacheHashDeletionPolicy}, contains::Contains, epoch_accounts_hash::EpochAccountsHashManager, - partitioned_rewards::{PartitionedEpochRewardsConfig, TestPartitionedEpochRewards}, + partitioned_rewards::{ + PartitionedEpochRewardsConfig, DEFAULT_PARTITIONED_EPOCH_REWARDS_CONFIG, + }, read_only_accounts_cache::ReadOnlyAccountsCache, sorted_storages::SortedStorages, storable_accounts::{StorableAccounts, StorableAccountsBySlot}, @@ -506,7 +508,7 @@ pub const ACCOUNTS_DB_CONFIG_FOR_TESTING: AccountsDbConfig = AccountsDbConfig { skip_initial_hash_calc: false, exhaustively_verify_refcounts: false, create_ancient_storage: CreateAncientStorage::Pack, - test_partitioned_epoch_rewards: TestPartitionedEpochRewards::CompareResults, + partitioned_epoch_rewards_config: DEFAULT_PARTITIONED_EPOCH_REWARDS_CONFIG, test_skip_rewrites_but_include_in_bank_hash: false, storage_access: StorageAccess::Mmap, scan_filter_for_shrinking: ScanFilter::OnlyAbnormalWithVerify, @@ -532,7 +534,7 @@ pub const ACCOUNTS_DB_CONFIG_FOR_BENCHMARKS: AccountsDbConfig = AccountsDbConfig skip_initial_hash_calc: false, exhaustively_verify_refcounts: false, create_ancient_storage: CreateAncientStorage::Pack, - test_partitioned_epoch_rewards: TestPartitionedEpochRewards::None, + partitioned_epoch_rewards_config: DEFAULT_PARTITIONED_EPOCH_REWARDS_CONFIG, test_skip_rewrites_but_include_in_bank_hash: false, storage_access: StorageAccess::Mmap, scan_filter_for_shrinking: ScanFilter::OnlyAbnormalWithVerify, @@ -661,7 +663,7 @@ pub struct AccountsDbConfig { pub exhaustively_verify_refcounts: bool, /// how to create ancient storages pub create_ancient_storage: CreateAncientStorage, - pub test_partitioned_epoch_rewards: TestPartitionedEpochRewards, + pub partitioned_epoch_rewards_config: PartitionedEpochRewardsConfig, pub storage_access: StorageAccess, pub scan_filter_for_shrinking: ScanFilter, pub enable_experimental_accumulator_hash: bool, @@ -1969,10 +1971,6 @@ impl AccountsDb { accounts_hash_cache_path }); - let test_partitioned_epoch_rewards = accounts_db_config.test_partitioned_epoch_rewards; - let partitioned_epoch_rewards_config: PartitionedEpochRewardsConfig = - PartitionedEpochRewardsConfig::new(test_partitioned_epoch_rewards); - let read_cache_size = accounts_db_config.read_cache_limit_bytes.unwrap_or(( Self::DEFAULT_MAX_READ_ONLY_CACHE_DATA_SIZE_LO, Self::DEFAULT_MAX_READ_ONLY_CACHE_DATA_SIZE_HI, @@ -2035,7 +2033,7 @@ impl AccountsDb { Self::READ_ONLY_CACHE_MS_TO_SKIP_LRU_UPDATE, ), write_cache_limit_bytes: accounts_db_config.write_cache_limit_bytes, - partitioned_epoch_rewards_config, + partitioned_epoch_rewards_config: accounts_db_config.partitioned_epoch_rewards_config, exhaustively_verify_refcounts: accounts_db_config.exhaustively_verify_refcounts, test_skip_rewrites_but_include_in_bank_hash: accounts_db_config .test_skip_rewrites_but_include_in_bank_hash, diff --git a/accounts-db/src/partitioned_rewards.rs b/accounts-db/src/partitioned_rewards.rs index 4ced408c6495e9..85758a4df84f0f 100644 --- a/accounts-db/src/partitioned_rewards.rs +++ b/accounts-db/src/partitioned_rewards.rs @@ -1,98 +1,39 @@ //! Code related to partitioned rewards distribution -#[derive(Debug)] +/// # stake accounts to store in one block during partitioned reward interval +/// Target to store 64 rewards per entry/tick in a block. A block has a minimum of 64 +/// entries/tick. This gives 4096 total rewards to store in one block. +/// This constant affects consensus. +const MAX_PARTITIONED_REWARDS_PER_BLOCK: u64 = 4096; + +#[derive(Debug, Clone, Copy)] /// Configuration options for partitioned epoch rewards. -/// This struct allows various forms of testing, especially prior to feature activation. pub struct PartitionedEpochRewardsConfig { /// number of stake accounts to store in one block during partitioned reward interval /// normally, this is a number tuned for reasonable performance, such as 4096 accounts/block - /// if force_one_slot_partitioned_rewards, this will usually be u64::MAX so that all stake accounts are written in the first block pub stake_account_stores_per_block: u64, - /// if true, end of epoch bank rewards will force using partitioned rewards distribution. - /// see `set_test_enable_partitioned_rewards` - pub test_enable_partitioned_rewards: bool, - /// if true, end of epoch non-partitioned bank rewards will test the partitioned rewards distribution vote and stake accounts - /// This has a significant performance impact on the first slot in each new epoch. - pub test_compare_partitioned_epoch_rewards: bool, } +/// Convenient constant for default partitioned epoch rewards configuration +/// used for benchmarks and tests. +pub const DEFAULT_PARTITIONED_EPOCH_REWARDS_CONFIG: PartitionedEpochRewardsConfig = + PartitionedEpochRewardsConfig { + stake_account_stores_per_block: MAX_PARTITIONED_REWARDS_PER_BLOCK, + }; + impl Default for PartitionedEpochRewardsConfig { fn default() -> Self { Self { - // # stake accounts to store in one block during partitioned reward interval - // Target to store 64 rewards per entry/tick in a block. A block has a minimum of 64 - // entries/tick. This gives 4096 total rewards to store in one block. - // This constant affects consensus. - stake_account_stores_per_block: 4096, - test_enable_partitioned_rewards: false, - test_compare_partitioned_epoch_rewards: false, + stake_account_stores_per_block: MAX_PARTITIONED_REWARDS_PER_BLOCK, } } } -#[derive(Debug, Default, Clone, Copy)] -pub enum TestPartitionedEpochRewards { - #[default] - None, - CompareResults, - ForcePartitionedEpochRewardsInOneBlock, - PartitionedEpochRewardsConfigRewardBlocks { - stake_account_stores_per_block: u64, - }, -} - impl PartitionedEpochRewardsConfig { - pub fn new(test: TestPartitionedEpochRewards) -> Self { - match test { - TestPartitionedEpochRewards::None => Self::default(), - TestPartitionedEpochRewards::CompareResults => { - Self::set_test_compare_partitioned_epoch_rewards() - } - TestPartitionedEpochRewards::ForcePartitionedEpochRewardsInOneBlock => { - Self::set_test_enable_partitioned_rewards() - } - TestPartitionedEpochRewards::PartitionedEpochRewardsConfigRewardBlocks { - stake_account_stores_per_block, - } => { - Self::set_test_enable_partitioned_rewards_with_custom_number_of_stake_accounts_per_block( - stake_account_stores_per_block - ) - } - } - } - - /// All rewards will be distributed in the first block in the epoch, matching - /// consensus for the non-partitioned rewards, but running all the partitioned rewards - /// code. - fn set_test_enable_partitioned_rewards() -> Self { - Self { - stake_account_stores_per_block: u64::MAX, - test_enable_partitioned_rewards: true, - // irrelevant if we are not running old code path - test_compare_partitioned_epoch_rewards: false, - } - } - - /// All rewards will be distributed in the first block in the epoch as normal. - /// Then, the partitioned rewards code will calculate expected results and compare to - /// the old code path's results. - fn set_test_compare_partitioned_epoch_rewards() -> Self { - Self { - test_compare_partitioned_epoch_rewards: true, - ..PartitionedEpochRewardsConfig::default() - } - } - - /// A method that configures how many reward reward calculation blocks and how many stake - /// accounts to store per reward block. - fn set_test_enable_partitioned_rewards_with_custom_number_of_stake_accounts_per_block( - stake_account_stores_per_block: u64, - ) -> Self { + /// Only for tests and benchmarks + pub fn new_for_test(stake_account_stores_per_block: u64) -> Self { Self { stake_account_stores_per_block, - test_enable_partitioned_rewards: true, - // irrelevant if we are not running old code path - test_compare_partitioned_epoch_rewards: false, } } } diff --git a/ledger-tool/src/args.rs b/ledger-tool/src/args.rs index bc80abcfa7b113..1d0505968d822d 100644 --- a/ledger-tool/src/args.rs +++ b/ledger-tool/src/args.rs @@ -5,7 +5,6 @@ use { accounts_db::{AccountsDb, AccountsDbConfig, CreateAncientStorage}, accounts_file::StorageAccess, accounts_index::{AccountsIndexConfig, IndexLimitMb, ScanFilter}, - partitioned_rewards::TestPartitionedEpochRewards, utils::create_and_canonicalize_directories, }, solana_clap_utils::{ @@ -301,15 +300,6 @@ pub fn get_accounts_db_config( ..AccountsIndexConfig::default() }; - let test_partitioned_epoch_rewards = - if arg_matches.is_present("partitioned_epoch_rewards_compare_calculation") { - TestPartitionedEpochRewards::CompareResults - } else if arg_matches.is_present("partitioned_epoch_rewards_force_enable_single_slot") { - TestPartitionedEpochRewards::ForcePartitionedEpochRewardsInOneBlock - } else { - TestPartitionedEpochRewards::None - }; - let accounts_hash_cache_path = arg_matches .value_of("accounts_hash_cache_path") .map(Into::into) @@ -388,7 +378,6 @@ pub fn get_accounts_db_config( .ok(), exhaustively_verify_refcounts: arg_matches.is_present("accounts_db_verify_refcounts"), skip_initial_hash_calc: arg_matches.is_present("accounts_db_skip_initial_hash_calculation"), - test_partitioned_epoch_rewards, test_skip_rewrites_but_include_in_bank_hash: arg_matches .is_present("accounts_db_test_skip_rewrites"), create_ancient_storage, diff --git a/ledger-tool/src/main.rs b/ledger-tool/src/main.rs index 4580c0b7731abe..8e0cdc5a019895 100644 --- a/ledger-tool/src/main.rs +++ b/ledger-tool/src/main.rs @@ -1136,29 +1136,6 @@ fn main() { tasks and assert.", ), ) - .arg( - Arg::with_name("partitioned_epoch_rewards_compare_calculation") - .long("partitioned-epoch-rewards-compare-calculation") - .takes_value(false) - .help( - "Do normal epoch rewards distribution, but also calculate rewards \ - using the partitioned rewards code path and compare the resulting \ - vote and stake accounts", - ) - .hidden(hidden_unless_forced()), - ) - .arg( - Arg::with_name("partitioned_epoch_rewards_force_enable_single_slot") - .long("partitioned-epoch-rewards-force-enable-single-slot") - .takes_value(false) - .help( - "Force the partitioned rewards distribution, but distribute all \ - rewards in the first slot in the epoch. This should match consensus \ - with the normal rewards distribution.", - ) - .conflicts_with("partitioned_epoch_rewards_compare_calculation") - .hidden(hidden_unless_forced()), - ) .arg( Arg::with_name("print_accounts_stats") .long("print-accounts-stats") diff --git a/runtime/src/bank.rs b/runtime/src/bank.rs index 7ff38ba1c2b2f3..fdc805fad20839 100644 --- a/runtime/src/bank.rs +++ b/runtime/src/bank.rs @@ -2673,21 +2673,6 @@ impl Bank { metrics, ); - // this checking of an unactivated feature can be enabled in tests or with a validator by passing `--partitioned-epoch-rewards-compare-calculation` - if self - .partitioned_epoch_rewards_config() - .test_compare_partitioned_epoch_rewards - { - // immutable `&self` to avoid side effects - (self as &Bank).compare_with_partitioned_rewards( - &stake_rewards, - &vote_account_rewards, - rewarded_epoch, - thread_pool, - null_tracer(), - ); - } - self.store_stake_accounts(thread_pool, &stake_rewards, metrics); let vote_rewards = self.store_vote_accounts(vote_account_rewards, metrics); self.update_reward_history(stake_rewards, vote_rewards); @@ -5658,16 +5643,13 @@ impl Bank { let measure_total = Measure::start(""); let slot = self.slot(); - let ignore = (!self.is_partitioned_rewards_feature_enabled() - && self.force_partition_rewards_in_first_block_of_epoch()) - .then_some(sysvar::epoch_rewards::id()); let (accounts_delta_hash, accounts_delta_hash_us) = measure_us!({ self.rc .accounts .accounts_db .calculate_accounts_delta_hash_internal( slot, - ignore, + None, self.skipped_rewrites.lock().unwrap().clone(), ) }); diff --git a/runtime/src/bank/partitioned_epoch_rewards/calculation.rs b/runtime/src/bank/partitioned_epoch_rewards/calculation.rs index 4d179c753991ab..aef86acba2347e 100644 --- a/runtime/src/bank/partitioned_epoch_rewards/calculation.rs +++ b/runtime/src/bank/partitioned_epoch_rewards/calculation.rs @@ -61,12 +61,7 @@ impl Bank { let slot = self.slot(); let distribution_starting_block_height = - // For live-cluster testing pre-activation - if self.force_partition_rewards_in_first_block_of_epoch() { - self.block_height() - } else { - self.block_height() + REWARD_CALCULATION_NUM_BLOCKS - }; + self.block_height() + REWARD_CALCULATION_NUM_BLOCKS; let num_partitions = stake_rewards_by_partition.len() as u64; diff --git a/runtime/src/bank/partitioned_epoch_rewards/compare.rs b/runtime/src/bank/partitioned_epoch_rewards/compare.rs deleted file mode 100644 index de52cfd6de7090..00000000000000 --- a/runtime/src/bank/partitioned_epoch_rewards/compare.rs +++ /dev/null @@ -1,114 +0,0 @@ -use { - super::{Bank, PartitionedRewardsCalculation, PartitionedStakeReward}, - crate::bank::{RewardCalcTracer, RewardsMetrics, VoteReward}, - dashmap::DashMap, - log::info, - rayon::ThreadPool, - solana_accounts_db::stake_rewards::StakeReward, - solana_sdk::{ - account::{AccountSharedData, WritableAccount}, - clock::Epoch, - pubkey::Pubkey, - reward_info::RewardInfo, - }, - std::collections::HashMap, -}; - -impl Bank { - /// compare the vote and stake accounts between the normal rewards calculation code - /// and the partitioned rewards calculation code - /// `stake_rewards_expected` and `vote_rewards_expected` are the results of the normal rewards calculation code - /// This fn should have NO side effects. - pub(in crate::bank) fn compare_with_partitioned_rewards( - &self, - stake_rewards_expected: &[StakeReward], - vote_rewards_expected: &DashMap, - rewarded_epoch: Epoch, - thread_pool: &ThreadPool, - reward_calc_tracer: Option, - ) { - let partitioned_rewards = self.calculate_rewards_for_partitioning( - rewarded_epoch, - reward_calc_tracer, - thread_pool, - &mut RewardsMetrics::default(), - ); - Self::compare_with_partitioned_rewards_results( - stake_rewards_expected, - vote_rewards_expected, - partitioned_rewards, - ); - } - - /// compare the vote and stake accounts between the normal rewards calculation code - /// and the partitioned rewards calculation code - /// `stake_rewards_expected` and `vote_rewards_expected` are the results of the normal rewards calculation code - /// This fn should have NO side effects. - /// This fn is only called in tests or with a debug cli arg prior to partitioned rewards feature activation. - fn compare_with_partitioned_rewards_results( - stake_rewards_expected: &[StakeReward], - vote_rewards_expected: &DashMap, - partitioned_rewards: PartitionedRewardsCalculation, - ) { - // put partitioned stake rewards in a hashmap - let mut stake_rewards: HashMap = HashMap::default(); - partitioned_rewards - .stake_rewards_by_partition - .stake_rewards_by_partition - .iter() - .flatten() - .for_each(|stake_reward| { - stake_rewards.insert(stake_reward.stake_pubkey, stake_reward); - }); - - // verify stake rewards match expected - stake_rewards_expected.iter().for_each(|stake_reward| { - let partitioned = stake_rewards.remove(&stake_reward.stake_pubkey).unwrap(); - let converted = PartitionedStakeReward::maybe_from(stake_reward).expect( - "StakeRewards should only be deserializable accounts with state \ - StakeStateV2::Stake", - ); - assert_eq!(partitioned, &converted); - }); - assert!(stake_rewards.is_empty(), "{stake_rewards:?}"); - - let mut vote_rewards: HashMap = HashMap::default(); - partitioned_rewards - .vote_account_rewards - .accounts_to_store - .iter() - .enumerate() - .for_each(|(i, account)| { - if let Some(account) = account { - let reward = &partitioned_rewards.vote_account_rewards.rewards[i]; - vote_rewards.insert(reward.0, (reward.1, account.clone())); - } - }); - - // verify vote rewards match expected - vote_rewards_expected.iter().for_each(|entry| { - if entry.value().vote_needs_store { - let partitioned = vote_rewards.remove(entry.key()).unwrap(); - let mut to_store_partitioned = partitioned.1.clone(); - to_store_partitioned.set_lamports(partitioned.0.post_balance); - let mut to_store_normal = entry.value().vote_account.clone(); - _ = to_store_normal.checked_add_lamports(entry.value().vote_rewards); - assert_eq!(to_store_partitioned, to_store_normal, "{:?}", entry.key()); - } - }); - assert!(vote_rewards.is_empty(), "{vote_rewards:?}"); - info!( - "verified partitioned rewards calculation matching: {}, {}", - partitioned_rewards - .stake_rewards_by_partition - .stake_rewards_by_partition - .iter() - .map(|rewards| rewards.len()) - .sum::(), - partitioned_rewards - .vote_account_rewards - .accounts_to_store - .len() - ); - } -} diff --git a/runtime/src/bank/partitioned_epoch_rewards/mod.rs b/runtime/src/bank/partitioned_epoch_rewards/mod.rs index 7b6ad888e4f8e5..0916bc3cca1bff 100644 --- a/runtime/src/bank/partitioned_epoch_rewards/mod.rs +++ b/runtime/src/bank/partitioned_epoch_rewards/mod.rs @@ -1,5 +1,4 @@ mod calculation; -mod compare; mod distribution; mod epoch_rewards_hasher; mod sysvar; @@ -13,10 +12,9 @@ use { solana_feature_set as feature_set, solana_sdk::{ account::AccountSharedData, - account_utils::StateMut, pubkey::Pubkey, reward_info::RewardInfo, - stake::state::{Delegation, Stake, StakeStateV2}, + stake::state::{Delegation, Stake}, }, solana_stake_program::points::PointValue, solana_vote::vote_account::VoteAccounts, @@ -39,20 +37,6 @@ pub(crate) struct PartitionedStakeReward { pub stake_reward_info: RewardInfo, } -impl PartitionedStakeReward { - fn maybe_from(stake_reward: &StakeReward) -> Option { - if let Ok(StakeStateV2::Stake(_meta, stake, _flags)) = stake_reward.stake_account.state() { - Some(Self { - stake_pubkey: stake_reward.stake_pubkey, - stake, - stake_reward_info: stake_reward.stake_reward_info, - }) - } else { - None - } - } -} - type PartitionedStakeRewards = Vec; #[derive(Debug, Clone, PartialEq, Serialize, Deserialize)] @@ -252,21 +236,12 @@ impl Bank { /// This means the feature is activated or certain testing situations. pub(super) fn is_partitioned_rewards_code_enabled(&self) -> bool { self.is_partitioned_rewards_feature_enabled() - || self - .partitioned_epoch_rewards_config() - .test_enable_partitioned_rewards } /// For testing only pub fn force_reward_interval_end_for_tests(&mut self) { self.epoch_reward_status = EpochRewardStatus::Inactive; } - - pub(super) fn force_partition_rewards_in_first_block_of_epoch(&self) -> bool { - self.partitioned_epoch_rewards_config() - .test_enable_partitioned_rewards - && self.partitioned_rewards_stake_account_stores_per_block() == u64::MAX - } } #[cfg(test)] @@ -281,18 +256,16 @@ mod tests { runtime_config::RuntimeConfig, }, assert_matches::assert_matches, - solana_accounts_db::{ - accounts_db::{AccountsDbConfig, ACCOUNTS_DB_CONFIG_FOR_TESTING}, - partitioned_rewards::TestPartitionedEpochRewards, - }, + solana_accounts_db::accounts_db::{AccountsDbConfig, ACCOUNTS_DB_CONFIG_FOR_TESTING}, solana_sdk::{ account::Account, + account_utils::StateMut, epoch_schedule::EpochSchedule, native_token::LAMPORTS_PER_SOL, reward_type::RewardType, signature::Signer, signer::keypair::Keypair, - stake::instruction::StakeError, + stake::{instruction::StakeError, state::StakeStateV2}, system_transaction, transaction::Transaction, vote::state::{VoteStateVersions, MAX_LOCKOUT_HISTORY}, @@ -307,6 +280,20 @@ mod tests { pub fn new_random() -> Self { Self::maybe_from(&StakeReward::new_random()).unwrap() } + + fn maybe_from(stake_reward: &StakeReward) -> Option { + if let Ok(StakeStateV2::Stake(_meta, stake, _flags)) = + stake_reward.stake_account.state() + { + Some(Self { + stake_pubkey: stake_reward.stake_pubkey, + stake, + stake_reward_info: stake_reward.stake_reward_info, + }) + } else { + None + } + } } pub fn convert_rewards( @@ -384,10 +371,8 @@ mod tests { genesis_config.epoch_schedule = EpochSchedule::new(SLOTS_PER_EPOCH); let mut accounts_db_config: AccountsDbConfig = ACCOUNTS_DB_CONFIG_FOR_TESTING.clone(); - accounts_db_config.test_partitioned_epoch_rewards = - TestPartitionedEpochRewards::PartitionedEpochRewardsConfigRewardBlocks { - stake_account_stores_per_block, - }; + accounts_db_config.partitioned_epoch_rewards_config = + PartitionedEpochRewardsConfig::new_for_test(stake_account_stores_per_block); let bank = Bank::new_with_paths( &genesis_config, @@ -491,10 +476,8 @@ mod tests { // Config stake reward distribution to be 10 per block let mut accounts_db_config: AccountsDbConfig = ACCOUNTS_DB_CONFIG_FOR_TESTING.clone(); - accounts_db_config.test_partitioned_epoch_rewards = - TestPartitionedEpochRewards::PartitionedEpochRewardsConfigRewardBlocks { - stake_account_stores_per_block: 10, - }; + accounts_db_config.partitioned_epoch_rewards_config = + PartitionedEpochRewardsConfig::new_for_test(10); let bank = Bank::new_with_paths( &genesis_config, diff --git a/validator/src/cli.rs b/validator/src/cli.rs index 19a2b7f77e7b0a..af9ac6abc1f906 100644 --- a/validator/src/cli.rs +++ b/validator/src/cli.rs @@ -1445,29 +1445,6 @@ pub fn app<'a>(version: &'a str, default_args: &'a DefaultArgs) -> App<'a, 'a> { .takes_value(true) .help("Number of bins to divide the accounts index into"), ) - .arg( - Arg::with_name("partitioned_epoch_rewards_compare_calculation") - .long("partitioned-epoch-rewards-compare-calculation") - .takes_value(false) - .help( - "Do normal epoch rewards distribution, but also calculate rewards using the \ - partitioned rewards code path and compare the resulting vote and stake \ - accounts", - ) - .hidden(hidden_unless_forced()), - ) - .arg( - Arg::with_name("partitioned_epoch_rewards_force_enable_single_slot") - .long("partitioned-epoch-rewards-force-enable-single-slot") - .takes_value(false) - .help( - "Force the partitioned rewards distribution, but distribute all rewards in \ - the first slot in the epoch. This should match consensus with the normal \ - rewards distribution.", - ) - .conflicts_with("partitioned_epoch_rewards_compare_calculation") - .hidden(hidden_unless_forced()), - ) .arg( Arg::with_name("accounts_index_path") .long("accounts-index-path") diff --git a/validator/src/main.rs b/validator/src/main.rs index bee65e487ba92a..3bbcbdb8380fa1 100644 --- a/validator/src/main.rs +++ b/validator/src/main.rs @@ -23,7 +23,6 @@ use { AccountIndex, AccountSecondaryIndexes, AccountSecondaryIndexesIncludeExclude, AccountsIndexConfig, IndexLimitMb, ScanFilter, }, - partitioned_rewards::TestPartitionedEpochRewards, utils::{create_all_accounts_run_and_snapshot_dirs, create_and_canonicalize_directories}, }, solana_clap_utils::input_parsers::{keypair_of, keypairs_of, pubkey_of, value_of, values_of}, @@ -1224,15 +1223,6 @@ pub fn main() { accounts_index_config.bins = Some(bins); } - let test_partitioned_epoch_rewards = - if matches.is_present("partitioned_epoch_rewards_compare_calculation") { - TestPartitionedEpochRewards::CompareResults - } else if matches.is_present("partitioned_epoch_rewards_force_enable_single_slot") { - TestPartitionedEpochRewards::ForcePartitionedEpochRewardsInOneBlock - } else { - TestPartitionedEpochRewards::None - }; - accounts_index_config.index_limit_mb = if matches.is_present("disable_accounts_disk_index") { IndexLimitMb::InMemOnly } else { @@ -1357,7 +1347,6 @@ pub fn main() { .ok(), exhaustively_verify_refcounts: matches.is_present("accounts_db_verify_refcounts"), create_ancient_storage, - test_partitioned_epoch_rewards, test_skip_rewrites_but_include_in_bank_hash: matches .is_present("accounts_db_test_skip_rewrites"), storage_access,