From 80462c6e2f7b3e821fc18de67946a05c1d26cce4 Mon Sep 17 00:00:00 2001 From: Brooks Prumo Date: Thu, 5 May 2022 16:03:08 -0500 Subject: [PATCH] Update local-cluster tests to work with higher minimum stake delegation --- local-cluster/src/local_cluster.rs | 6 +- local-cluster/tests/common.rs | 4 + local-cluster/tests/local_cluster.rs | 133 ++++++++++++-------- local-cluster/tests/local_cluster_flakey.rs | 14 ++- local-cluster/tests/local_cluster_slow_1.rs | 29 +++-- local-cluster/tests/local_cluster_slow_2.rs | 16 +-- 6 files changed, 118 insertions(+), 84 deletions(-) diff --git a/local-cluster/src/local_cluster.rs b/local-cluster/src/local_cluster.rs index 696755d5fbfedf..625b467c532a90 100644 --- a/local-cluster/src/local_cluster.rs +++ b/local-cluster/src/local_cluster.rs @@ -221,7 +221,7 @@ impl LocalCluster { create_stake_config_account( 1, &stake_config::Config { - warmup_cooldown_rate: 1_000_000_000.0f64, + warmup_cooldown_rate: std::f64::MAX, slash_penalty: std::u8::MAX, }, ), @@ -568,8 +568,8 @@ impl LocalCluster { let vote_account_pubkey = vote_account.pubkey(); let node_pubkey = from_account.pubkey(); info!( - "setup_vote_and_stake_accounts: {}, {}", - node_pubkey, vote_account_pubkey + "setup_vote_and_stake_accounts: {}, {}, amount: {}", + node_pubkey, vote_account_pubkey, amount, ); let stake_account_keypair = Keypair::new(); let stake_account_pubkey = stake_account_keypair.pubkey(); diff --git a/local-cluster/tests/common.rs b/local-cluster/tests/common.rs index e74165d5f82183..b243def93cff9c 100644 --- a/local-cluster/tests/common.rs +++ b/local-cluster/tests/common.rs @@ -26,6 +26,7 @@ use { account::AccountSharedData, clock::{self, Slot, DEFAULT_MS_PER_SLOT, DEFAULT_TICKS_PER_SLOT}, hash::Hash, + native_token::LAMPORTS_PER_SOL, pubkey::Pubkey, signature::{Keypair, Signer}, }, @@ -47,6 +48,9 @@ use { pub const RUST_LOG_FILTER: &str = "error,solana_core::replay_stage=warn,solana_local_cluster=info,local_cluster=info"; +pub const DEFAULT_CLUSTER_LAMPORTS: u64 = 10_000_000 * LAMPORTS_PER_SOL; +pub const DEFAULT_NODE_STAKE: u64 = 10 * LAMPORTS_PER_SOL; + pub fn last_vote_in_tower(tower_path: &Path, node_pubkey: &Pubkey) -> Option<(Slot, Hash)> { restore_tower(tower_path, node_pubkey).map(|tower| tower.last_voted_slot_hash().unwrap()) } diff --git a/local-cluster/tests/local_cluster.rs b/local-cluster/tests/local_cluster.rs index 815ba6e67ec97f..838d2539730e92 100644 --- a/local-cluster/tests/local_cluster.rs +++ b/local-cluster/tests/local_cluster.rs @@ -70,8 +70,12 @@ mod common; fn test_local_cluster_start_and_exit() { solana_logger::setup(); let num_nodes = 1; - let cluster = - LocalCluster::new_with_equal_stakes(num_nodes, 100, 3, SocketAddrSpace::Unspecified); + let cluster = LocalCluster::new_with_equal_stakes( + num_nodes, + DEFAULT_CLUSTER_LAMPORTS, + DEFAULT_NODE_STAKE, + SocketAddrSpace::Unspecified, + ); assert_eq!(cluster.validators.len(), num_nodes); } @@ -84,8 +88,8 @@ fn test_local_cluster_start_and_exit_with_config() { &ValidatorConfig::default_for_test(), NUM_NODES, ), - node_stakes: vec![3; NUM_NODES], - cluster_lamports: 100, + node_stakes: vec![DEFAULT_NODE_STAKE; NUM_NODES], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, ticks_per_slot: 8, slots_per_epoch: MINIMUM_SLOTS_PER_EPOCH as u64, stakers_slot_offset: MINIMUM_SLOTS_PER_EPOCH as u64, @@ -101,8 +105,12 @@ fn test_spend_and_verify_all_nodes_1() { solana_logger::setup_with_default(RUST_LOG_FILTER); error!("test_spend_and_verify_all_nodes_1"); let num_nodes = 1; - let local = - LocalCluster::new_with_equal_stakes(num_nodes, 10_000, 100, SocketAddrSpace::Unspecified); + let local = LocalCluster::new_with_equal_stakes( + num_nodes, + DEFAULT_CLUSTER_LAMPORTS, + DEFAULT_NODE_STAKE, + SocketAddrSpace::Unspecified, + ); cluster_tests::spend_and_verify_all_nodes( &local.entry_point_info, &local.funding_keypair, @@ -118,8 +126,12 @@ fn test_spend_and_verify_all_nodes_2() { solana_logger::setup_with_default(RUST_LOG_FILTER); error!("test_spend_and_verify_all_nodes_2"); let num_nodes = 2; - let local = - LocalCluster::new_with_equal_stakes(num_nodes, 10_000, 100, SocketAddrSpace::Unspecified); + let local = LocalCluster::new_with_equal_stakes( + num_nodes, + DEFAULT_CLUSTER_LAMPORTS, + DEFAULT_NODE_STAKE, + SocketAddrSpace::Unspecified, + ); cluster_tests::spend_and_verify_all_nodes( &local.entry_point_info, &local.funding_keypair, @@ -135,8 +147,12 @@ fn test_spend_and_verify_all_nodes_3() { solana_logger::setup_with_default(RUST_LOG_FILTER); error!("test_spend_and_verify_all_nodes_3"); let num_nodes = 3; - let local = - LocalCluster::new_with_equal_stakes(num_nodes, 10_000, 100, SocketAddrSpace::Unspecified); + let local = LocalCluster::new_with_equal_stakes( + num_nodes, + DEFAULT_CLUSTER_LAMPORTS, + DEFAULT_NODE_STAKE, + SocketAddrSpace::Unspecified, + ); cluster_tests::spend_and_verify_all_nodes( &local.entry_point_info, &local.funding_keypair, @@ -151,8 +167,12 @@ fn test_spend_and_verify_all_nodes_3() { fn test_local_cluster_signature_subscribe() { solana_logger::setup_with_default(RUST_LOG_FILTER); let num_nodes = 2; - let cluster = - LocalCluster::new_with_equal_stakes(num_nodes, 10_000, 100, SocketAddrSpace::Unspecified); + let cluster = LocalCluster::new_with_equal_stakes( + num_nodes, + DEFAULT_CLUSTER_LAMPORTS, + DEFAULT_NODE_STAKE, + SocketAddrSpace::Unspecified, + ); let nodes = cluster.get_node_pubkeys(); // Get non leader @@ -228,8 +248,12 @@ fn test_spend_and_verify_all_nodes_env_num_nodes() { .expect("please set environment variable NUM_NODES") .parse() .expect("could not parse NUM_NODES as a number"); - let local = - LocalCluster::new_with_equal_stakes(num_nodes, 10_000, 100, SocketAddrSpace::Unspecified); + let local = LocalCluster::new_with_equal_stakes( + num_nodes, + DEFAULT_CLUSTER_LAMPORTS, + DEFAULT_NODE_STAKE, + SocketAddrSpace::Unspecified, + ); cluster_tests::spend_and_verify_all_nodes( &local.entry_point_info, &local.funding_keypair, @@ -251,8 +275,8 @@ fn test_two_unbalanced_stakes() { let mut cluster = LocalCluster::new( &mut ClusterConfig { - node_stakes: vec![999_990, 3], - cluster_lamports: 1_000_000, + node_stakes: vec![DEFAULT_NODE_STAKE * 100, DEFAULT_NODE_STAKE], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + DEFAULT_NODE_STAKE * 100, validator_configs: make_identical_validator_configs(&validator_config, 2), ticks_per_slot: num_ticks_per_slot, slots_per_epoch: num_slots_per_epoch, @@ -278,11 +302,12 @@ fn test_two_unbalanced_stakes() { #[test] #[serial] fn test_forwarding() { + solana_logger::setup_with_default(RUST_LOG_FILTER); // Set up a cluster where one node is never the leader, so all txs sent to this node // will be have to be forwarded in order to be confirmed let mut config = ClusterConfig { - node_stakes: vec![999_990, 3], - cluster_lamports: 2_000_000, + node_stakes: vec![DEFAULT_NODE_STAKE * 100, DEFAULT_NODE_STAKE], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + DEFAULT_NODE_STAKE * 100, validator_configs: make_identical_validator_configs( &ValidatorConfig::default_for_test(), 2, @@ -320,8 +345,8 @@ fn test_restart_node() { let validator_config = ValidatorConfig::default_for_test(); let mut cluster = LocalCluster::new( &mut ClusterConfig { - node_stakes: vec![100; 1], - cluster_lamports: 100, + node_stakes: vec![DEFAULT_NODE_STAKE], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, validator_configs: vec![safe_clone_config(&validator_config)], ticks_per_slot, slots_per_epoch, @@ -359,8 +384,8 @@ fn test_mainnet_beta_cluster_type() { let mut config = ClusterConfig { cluster_type: ClusterType::MainnetBeta, - node_stakes: vec![100; 1], - cluster_lamports: 1_000, + node_stakes: vec![DEFAULT_NODE_STAKE], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, validator_configs: make_identical_validator_configs( &ValidatorConfig::default_for_test(), 1, @@ -429,10 +454,10 @@ fn test_snapshot_download() { let validator_snapshot_test_config = setup_snapshot_validator_config(snapshot_interval_slots, num_account_paths); - let stake = 10_000; + let stake = DEFAULT_NODE_STAKE; let mut config = ClusterConfig { node_stakes: vec![stake], - cluster_lamports: 1_000_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, validator_configs: make_identical_validator_configs( &leader_snapshot_test_config.validator_config, 1, @@ -511,10 +536,10 @@ fn test_incremental_snapshot_download() { num_account_paths, ); - let stake = 10_000; + let stake = DEFAULT_NODE_STAKE; let mut config = ClusterConfig { node_stakes: vec![stake], - cluster_lamports: 1_000_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, validator_configs: make_identical_validator_configs( &leader_snapshot_test_config.validator_config, 1, @@ -665,10 +690,10 @@ fn test_incremental_snapshot_download_with_crossing_full_snapshot_interval_at_st accounts_hash_interval, num_account_paths, ); - let stake = 10_000; + let stake = DEFAULT_NODE_STAKE; let mut config = ClusterConfig { node_stakes: vec![stake], - cluster_lamports: 1_000_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, validator_configs: make_identical_validator_configs( &leader_snapshot_test_config.validator_config, 1, @@ -1082,8 +1107,8 @@ fn test_snapshot_restart_tower() { setup_snapshot_validator_config(snapshot_interval_slots, num_account_paths); let mut config = ClusterConfig { - node_stakes: vec![10000, 10], - cluster_lamports: 100_000, + node_stakes: vec![DEFAULT_NODE_STAKE * 100, DEFAULT_NODE_STAKE], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + DEFAULT_NODE_STAKE * 100, validator_configs: vec![ safe_clone_config(&leader_snapshot_test_config.validator_config), safe_clone_config(&validator_snapshot_test_config.validator_config), @@ -1161,8 +1186,8 @@ fn test_snapshots_blockstore_floor() { .snapshot_archives_dir; let mut config = ClusterConfig { - node_stakes: vec![10000], - cluster_lamports: 100_000, + node_stakes: vec![DEFAULT_NODE_STAKE], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, validator_configs: make_identical_validator_configs( &leader_snapshot_test_config.validator_config, 1, @@ -1197,8 +1222,6 @@ fn test_snapshots_blockstore_floor() { let slot_floor = archive_info.slot(); // Start up a new node from a snapshot - let validator_stake = 5; - let cluster_nodes = discover_cluster( &cluster.entry_point_info.gossip, 1, @@ -1213,7 +1236,7 @@ fn test_snapshots_blockstore_floor() { cluster.add_validator( &validator_snapshot_test_config.validator_config, - validator_stake, + DEFAULT_NODE_STAKE, Arc::new(Keypair::new()), None, SocketAddrSpace::Unspecified, @@ -1273,8 +1296,8 @@ fn test_snapshots_restart_validity() { ); let mut config = ClusterConfig { - node_stakes: vec![10000], - cluster_lamports: 100_000, + node_stakes: vec![DEFAULT_NODE_STAKE], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, validator_configs: make_identical_validator_configs( &snapshot_test_config.validator_config, 1, @@ -1372,8 +1395,8 @@ fn test_wait_for_max_stake() { solana_logger::setup_with_default(RUST_LOG_FILTER); let validator_config = ValidatorConfig::default_for_test(); let mut config = ClusterConfig { - cluster_lamports: 10_000, - node_stakes: vec![100; 4], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, + node_stakes: vec![DEFAULT_NODE_STAKE; 4], validator_configs: make_identical_validator_configs(&validator_config, 4), ..ClusterConfig::default() }; @@ -1396,8 +1419,8 @@ fn test_no_voting() { ..ValidatorConfig::default_for_test() }; let mut config = ClusterConfig { - cluster_lamports: 10_000, - node_stakes: vec![100], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, + node_stakes: vec![DEFAULT_NODE_STAKE], validator_configs: vec![validator_config], ..ClusterConfig::default() }; @@ -1433,7 +1456,7 @@ fn test_optimistic_confirmation_violation_detection() { solana_logger::setup_with_default(RUST_LOG_FILTER); // First set up the cluster with 2 nodes let slots_per_epoch = 2048; - let node_stakes = vec![51, 50]; + let node_stakes = vec![51 * DEFAULT_NODE_STAKE, 50 * DEFAULT_NODE_STAKE]; let validator_keys: Vec<_> = vec![ "4qhhXNTbKD1a5vxDDLZcHKj7ELNeiivtUBxn3wUK1F5VRsQVP89VUhfXqSfgiFB14GfuBgtrQ96n9NvWQADVkcCg", "3kHBzVwie5vTEaY6nFCPeFT8qDpoXzn7dCEioGRNBTnUDpvwnG85w8Wq63gVWpVTP8k2a8cgcWRjSXyUkEygpXWS", @@ -1443,7 +1466,7 @@ fn test_optimistic_confirmation_violation_detection() { .take(node_stakes.len()) .collect(); let mut config = ClusterConfig { - cluster_lamports: 100_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + node_stakes.iter().sum::(), node_stakes: node_stakes.clone(), validator_configs: make_identical_validator_configs( &ValidatorConfig::default_for_test(), @@ -1572,8 +1595,8 @@ fn test_validator_saves_tower() { let validator_identity_keypair = Arc::new(Keypair::new()); let validator_id = validator_identity_keypair.pubkey(); let mut config = ClusterConfig { - cluster_lamports: 10_000, - node_stakes: vec![100], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, + node_stakes: vec![DEFAULT_NODE_STAKE], validator_configs: vec![validator_config], validator_keys: Some(vec![(validator_identity_keypair.clone(), true)]), ..ClusterConfig::default() @@ -1712,8 +1735,8 @@ fn do_test_future_tower(cluster_mode: ClusterMode) { // First set up the cluster with 4 nodes let slots_per_epoch = 2048; let node_stakes = match cluster_mode { - ClusterMode::MasterOnly => vec![100], - ClusterMode::MasterSlave => vec![100, 1], + ClusterMode::MasterOnly => vec![DEFAULT_NODE_STAKE], + ClusterMode::MasterSlave => vec![DEFAULT_NODE_STAKE * 100, DEFAULT_NODE_STAKE], }; let validator_keys = vec![ @@ -1734,7 +1757,7 @@ fn do_test_future_tower(cluster_mode: ClusterMode) { }; let mut config = ClusterConfig { - cluster_lamports: 100_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + DEFAULT_NODE_STAKE * 100, node_stakes: node_stakes.clone(), validator_configs: make_identical_validator_configs( &ValidatorConfig::default_for_test(), @@ -1826,7 +1849,7 @@ fn test_hard_fork_invalidates_tower() { // First set up the cluster with 2 nodes let slots_per_epoch = 2048; - let node_stakes = vec![60, 40]; + let node_stakes = vec![60 * DEFAULT_NODE_STAKE, 40 * DEFAULT_NODE_STAKE]; let validator_keys = vec![ "28bN3xyvrP4E8LwEgtLjhnkb7cY4amQb6DrYAbAYjgRV4GAGgkVM2K7wnxnAS7WDneuavza7x21MiafLu1HkwQt4", @@ -1845,7 +1868,7 @@ fn test_hard_fork_invalidates_tower() { let validator_b_pubkey = validators[1]; let mut config = ClusterConfig { - cluster_lamports: 100_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + node_stakes.iter().sum::(), node_stakes: node_stakes.clone(), validator_configs: make_identical_validator_configs( &ValidatorConfig::default_for_test(), @@ -1971,7 +1994,7 @@ fn test_restart_tower_rollback() { // First set up the cluster with 2 nodes let slots_per_epoch = 2048; - let node_stakes = vec![10000, 1]; + let node_stakes = vec![DEFAULT_NODE_STAKE * 100, DEFAULT_NODE_STAKE]; let validator_strings = vec![ "28bN3xyvrP4E8LwEgtLjhnkb7cY4amQb6DrYAbAYjgRV4GAGgkVM2K7wnxnAS7WDneuavza7x21MiafLu1HkwQt4", @@ -1987,7 +2010,7 @@ fn test_restart_tower_rollback() { let b_pubkey = validator_keys[1].0.pubkey(); let mut config = ClusterConfig { - cluster_lamports: 100_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + DEFAULT_NODE_STAKE * 100, node_stakes: node_stakes.clone(), validator_configs: make_identical_validator_configs( &ValidatorConfig::default_for_test(), @@ -2122,7 +2145,7 @@ fn run_test_load_program_accounts_partition(scan_commitment: CommitmentConfig) { #[test] #[serial] fn test_votes_land_in_fork_during_long_partition() { - let total_stake = 100; + let total_stake = 3 * DEFAULT_NODE_STAKE; // Make `lighter_stake` insufficient for switching threshold let lighter_stake = (SWITCH_FORK_THRESHOLD as f64 * total_stake as f64) as u64; let heavier_stake = lighter_stake + 1; @@ -2335,7 +2358,7 @@ fn run_test_load_program_accounts(scan_commitment: CommitmentConfig) { solana_logger::setup_with_default(RUST_LOG_FILTER); // First set up the cluster with 2 nodes let slots_per_epoch = 2048; - let node_stakes = vec![51, 50]; + let node_stakes = vec![51 * DEFAULT_NODE_STAKE, 50 * DEFAULT_NODE_STAKE]; let validator_keys: Vec<_> = vec![ "4qhhXNTbKD1a5vxDDLZcHKj7ELNeiivtUBxn3wUK1F5VRsQVP89VUhfXqSfgiFB14GfuBgtrQ96n9NvWQADVkcCg", "3kHBzVwie5vTEaY6nFCPeFT8qDpoXzn7dCEioGRNBTnUDpvwnG85w8Wq63gVWpVTP8k2a8cgcWRjSXyUkEygpXWS", @@ -2360,7 +2383,7 @@ fn run_test_load_program_accounts(scan_commitment: CommitmentConfig) { ); let mut config = ClusterConfig { - cluster_lamports: 100_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + node_stakes.iter().sum::(), node_stakes: node_stakes.clone(), validator_configs: make_identical_validator_configs( &ValidatorConfig::default_for_test(), diff --git a/local-cluster/tests/local_cluster_flakey.rs b/local-cluster/tests/local_cluster_flakey.rs index 646b69ba41fe6b..6dc530dcb9065f 100644 --- a/local-cluster/tests/local_cluster_flakey.rs +++ b/local-cluster/tests/local_cluster_flakey.rs @@ -2,10 +2,7 @@ //! because these tests are run separately from the rest of local cluster tests. #![allow(clippy::integer_arithmetic)] use { - common::{ - copy_blocks, create_custom_leader_schedule, last_vote_in_tower, open_blockstore, - purge_slots, remove_tower, wait_for_last_vote_in_tower_to_land_in_ledger, RUST_LOG_FILTER, - }, + common::*, log::*, serial_test::serial, solana_core::validator::ValidatorConfig, @@ -86,7 +83,12 @@ fn do_test_optimistic_confirmation_violation_with_or_without_tower(with_tower: b // First set up the cluster with 4 nodes let slots_per_epoch = 2048; - let node_stakes = vec![31, 36, 33, 0]; + let node_stakes = vec![ + 31 * DEFAULT_NODE_STAKE, + 36 * DEFAULT_NODE_STAKE, + 33 * DEFAULT_NODE_STAKE, + 0, + ]; let base_slot: Slot = 26; // S2 let next_slot_on_a: Slot = 27; // S3 @@ -151,7 +153,7 @@ fn do_test_optimistic_confirmation_violation_with_or_without_tower(with_tower: b validator_configs[2].voting_disabled = true; let mut config = ClusterConfig { - cluster_lamports: 100_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + node_stakes.iter().sum::(), node_stakes, validator_configs, validator_keys: Some(validator_keys), diff --git a/local-cluster/tests/local_cluster_slow_1.rs b/local-cluster/tests/local_cluster_slow_1.rs index 745d1710054ba9..095e87aeebaf94 100644 --- a/local-cluster/tests/local_cluster_slow_1.rs +++ b/local-cluster/tests/local_cluster_slow_1.rs @@ -76,7 +76,7 @@ mod common; fn test_fork_choice_refresh_old_votes() { solana_logger::setup_with_default(RUST_LOG_FILTER); let max_switch_threshold_failure_pct = 1.0 - 2.0 * SWITCH_FORK_THRESHOLD; - let total_stake = 100; + let total_stake = 100 * DEFAULT_NODE_STAKE; let max_failures_stake = (max_switch_threshold_failure_pct * total_stake as f64) as u64; // 1% less than the failure stake, where the 2% is allocated to a validator that @@ -89,7 +89,7 @@ fn test_fork_choice_refresh_old_votes() { // Heavier fork still doesn't have enough stake to switch. Both branches need // the vote to land from the validator with `alive_stake_3` to allow the other // fork to switch. - let alive_stake_3 = 2; + let alive_stake_3 = 2 * DEFAULT_NODE_STAKE; assert!(alive_stake_1 < alive_stake_2); assert!(alive_stake_1 + alive_stake_3 > alive_stake_2); @@ -271,7 +271,12 @@ fn test_kill_heaviest_partition() { // eventually choose the major partition // 4) Check for recovery let num_slots_per_validator = 8; - let partitions: [usize; 4] = [11, 10, 10, 10]; + let partitions: [usize; 4] = [ + 11 * DEFAULT_NODE_STAKE as usize, + 10 * DEFAULT_NODE_STAKE as usize, + 10 * DEFAULT_NODE_STAKE as usize, + 10 * DEFAULT_NODE_STAKE as usize, + ]; let (leader_schedule, validator_keys) = create_custom_leader_schedule_with_random_keys(&[ num_slots_per_validator * (partitions.len() - 1), num_slots_per_validator, @@ -302,7 +307,7 @@ fn test_kill_heaviest_partition() { #[serial] fn test_kill_partition_switch_threshold_no_progress() { let max_switch_threshold_failure_pct = 1.0 - 2.0 * SWITCH_FORK_THRESHOLD; - let total_stake = 10_000; + let total_stake = 10_000 * DEFAULT_NODE_STAKE; let max_failures_stake = (max_switch_threshold_failure_pct * total_stake as f64) as u64; let failures_stake = max_failures_stake; @@ -336,7 +341,7 @@ fn test_kill_partition_switch_threshold_no_progress() { #[serial] fn test_kill_partition_switch_threshold_progress() { let max_switch_threshold_failure_pct = 1.0 - 2.0 * SWITCH_FORK_THRESHOLD; - let total_stake = 10_000; + let total_stake = 10_000 * DEFAULT_NODE_STAKE; // Kill `< max_failures_stake` of the validators let max_failures_stake = (max_switch_threshold_failure_pct * total_stake as f64) as u64; @@ -401,13 +406,13 @@ fn test_duplicate_shreds_broadcast_leader() { // Critical that bad_leader_stake + good_node_stake < DUPLICATE_THRESHOLD and that // bad_leader_stake + good_node_stake + our_node_stake > DUPLICATE_THRESHOLD so that // our vote is the determining factor - let bad_leader_stake = 10000000000; + let bad_leader_stake = 10_000_000 * DEFAULT_NODE_STAKE; // Ensure that the good_node_stake is always on the critical path, and the partition node // should never be on the critical path. This way, none of the bad shreds sent to the partition // node corrupt the good node. - let good_node_stake = 500000; - let our_node_stake = 10000000000; - let partition_node_stake = 1; + let good_node_stake = 500 * DEFAULT_NODE_STAKE; + let our_node_stake = 10_000_000 * DEFAULT_NODE_STAKE; + let partition_node_stake = DEFAULT_NODE_STAKE; let node_stakes = vec![ bad_leader_stake, @@ -584,7 +589,7 @@ fn test_duplicate_shreds_broadcast_leader() { #[serial] fn test_switch_threshold_uses_gossip_votes() { solana_logger::setup_with_default(RUST_LOG_FILTER); - let total_stake = 100; + let total_stake = 100 * DEFAULT_NODE_STAKE; // Minimum stake needed to generate a switching proof let minimum_switch_stake = (SWITCH_FORK_THRESHOLD as f64 * total_stake as f64) as u64; @@ -819,8 +824,8 @@ fn test_switch_threshold_uses_gossip_votes() { #[serial] fn test_listener_startup() { let mut config = ClusterConfig { - node_stakes: vec![100; 1], - cluster_lamports: 1_000, + node_stakes: vec![DEFAULT_NODE_STAKE], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, num_listeners: 3, validator_configs: make_identical_validator_configs( &ValidatorConfig::default_for_test(), diff --git a/local-cluster/tests/local_cluster_slow_2.rs b/local-cluster/tests/local_cluster_slow_2.rs index 4affc73ef298f5..c778f9917cb8eb 100644 --- a/local-cluster/tests/local_cluster_slow_2.rs +++ b/local-cluster/tests/local_cluster_slow_2.rs @@ -78,10 +78,10 @@ fn test_consistency_halt() { .validator_config .accounts_hash_fault_injection_slots = 40; - let validator_stake = 10_000; + let validator_stake = DEFAULT_NODE_STAKE; let mut config = ClusterConfig { node_stakes: vec![validator_stake], - cluster_lamports: 100_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, validator_configs: vec![leader_snapshot_test_config.validator_config], ..ClusterConfig::default() }; @@ -176,8 +176,8 @@ fn test_leader_failure_4() { let num_nodes = 4; let validator_config = ValidatorConfig::default_for_test(); let mut config = ClusterConfig { - cluster_lamports: 10_000, - node_stakes: vec![100; 4], + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, + node_stakes: vec![DEFAULT_NODE_STAKE; 4], validator_configs: make_identical_validator_configs(&validator_config, num_nodes), ..ClusterConfig::default() }; @@ -209,9 +209,9 @@ fn test_ledger_cleanup_service() { ..ValidatorConfig::default_for_test() }; let mut config = ClusterConfig { - cluster_lamports: 10_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS, poh_config: PohConfig::new_sleep(Duration::from_millis(50)), - node_stakes: vec![100; num_nodes], + node_stakes: vec![DEFAULT_NODE_STAKE; num_nodes], validator_configs: make_identical_validator_configs(&validator_config, num_nodes), ..ClusterConfig::default() }; @@ -270,7 +270,7 @@ fn test_slot_hash_expiry() { solana_sdk::slot_hashes::set_entries_for_tests_only(64); let slots_per_epoch = 2048; - let node_stakes = vec![60, 40]; + let node_stakes = vec![60 * DEFAULT_NODE_STAKE, 40 * DEFAULT_NODE_STAKE]; let validator_keys = vec![ "28bN3xyvrP4E8LwEgtLjhnkb7cY4amQb6DrYAbAYjgRV4GAGgkVM2K7wnxnAS7WDneuavza7x21MiafLu1HkwQt4", "2saHBBoTkLMmttmPQP8KfBkcCw45S5cwtV3wTdGCscRC8uxdgvHxpHiWXKx4LvJjNJtnNcbSv5NdheokFFqnNDt8", @@ -298,7 +298,7 @@ fn test_slot_hash_expiry() { validator_configs[1].voting_disabled = true; let mut config = ClusterConfig { - cluster_lamports: 100_000, + cluster_lamports: DEFAULT_CLUSTER_LAMPORTS + node_stakes.iter().sum::(), node_stakes, validator_configs, validator_keys: Some(validator_keys),