From 02eab3c185dbe683ec0a5b0a7d83f4a398263154 Mon Sep 17 00:00:00 2001 From: Brooks Prumo Date: Mon, 14 Nov 2022 16:49:20 -0600 Subject: [PATCH] Use 400 slots-per-epoch in EAH tests (#28801) --- core/tests/epoch_accounts_hash.rs | 14 ++--- runtime/src/accounts_background_service.rs | 63 +++++++++++----------- 2 files changed, 38 insertions(+), 39 deletions(-) diff --git a/core/tests/epoch_accounts_hash.rs b/core/tests/epoch_accounts_hash.rs index be934f710e1508..3c1545399ddb5e 100755 --- a/core/tests/epoch_accounts_hash.rs +++ b/core/tests/epoch_accounts_hash.rs @@ -63,10 +63,10 @@ struct TestEnvironment { impl TestEnvironment { /// A small, round number to make the tests run quickly, and easy to debug - const SLOTS_PER_EPOCH: u64 = 100; + const SLOTS_PER_EPOCH: u64 = 400; /// A small, round number to ensure accounts packages are sent to the background services - const ACCOUNTS_HASH_INTERVAL: u64 = 10; + const ACCOUNTS_HASH_INTERVAL: u64 = 40; #[must_use] fn new() -> TestEnvironment { @@ -252,7 +252,7 @@ impl Drop for BackgroundServices { /// Ensure that EAHs are requested, calculated, and awaited correctly. /// Test both with and without snapshots to make sure they don't interfere with EAH. #[test_case(TestEnvironment::new() ; "without snapshots")] -#[test_case(TestEnvironment::new_with_snapshots(20, 10) ; "with snapshots")] +#[test_case(TestEnvironment::new_with_snapshots(80, 40) ; "with snapshots")] fn test_epoch_accounts_hash_basic(test_environment: TestEnvironment) { solana_logger::setup(); @@ -366,10 +366,10 @@ fn test_snapshots_have_expected_epoch_accounts_hash() { const NUM_EPOCHS_TO_TEST: u64 = 2; - // Since slots-per-epoch is 100, EAH start will be slots 25 and 125, and EAH stop will be slots - // 75 and 175. Pick a full snapshot interval that triggers in the three scenarios outlined in + // Since slots-per-epoch is 400, EAH start will be slots 100 and 500, and EAH stop will be slots + // 300 and 700. Pick a full snapshot interval that triggers in the three scenarios outlined in // the test's description. - const FULL_SNAPSHOT_INTERVAL: Slot = 20; + const FULL_SNAPSHOT_INTERVAL: Slot = 80; let test_environment = TestEnvironment::new_with_snapshots(FULL_SNAPSHOT_INTERVAL, FULL_SNAPSHOT_INTERVAL); @@ -484,7 +484,7 @@ fn test_background_services_request_handling() { solana_logger::setup(); const NUM_EPOCHS_TO_TEST: u64 = 2; - const FULL_SNAPSHOT_INTERVAL: Slot = 20; + const FULL_SNAPSHOT_INTERVAL: Slot = 80; let test_environment = TestEnvironment::new_with_snapshots(FULL_SNAPSHOT_INTERVAL, FULL_SNAPSHOT_INTERVAL); diff --git a/runtime/src/accounts_background_service.rs b/runtime/src/accounts_background_service.rs index 128865dd4611a6..6a17a427934c88 100644 --- a/runtime/src/accounts_background_service.rs +++ b/runtime/src/accounts_background_service.rs @@ -822,12 +822,12 @@ mod test { #[test] fn test_get_next_snapshot_request() { // These constants were picked to ensure the desired snapshot requests were sent to the - // channel. With 100 slots per Epoch, the EAH start will be at slot 25. Ensure there are + // channel. With 400 slots per Epoch, the EAH start will be at slot 100. Ensure there are // other requests before this slot, and then 2+ requests of each type afterwards (to // further test the prioritization logic). - const SLOTS_PER_EPOCH: Slot = 100; - const FULL_SNAPSHOT_INTERVAL: Slot = 20; - const INCREMENTAL_SNAPSHOT_INTERVAL: Slot = 6; + const SLOTS_PER_EPOCH: Slot = 400; + const FULL_SNAPSHOT_INTERVAL: Slot = 80; + const INCREMENTAL_SNAPSHOT_INTERVAL: Slot = 30; let snapshot_config = SnapshotConfig { full_snapshot_archive_interval_slots: FULL_SNAPSHOT_INTERVAL, @@ -863,28 +863,27 @@ mod test { // Create new banks and send snapshot requests so that the following requests will be in // the channel before handling the requests: // - // fss 20 - // iss 24 - // eah 25 <-- handled 1st - // iss 30 - // iss 36 - // fss 40 - // iss 42 - // iss 48 - // iss 54 - // fss 60 <-- handled 2nd - // iss 66 - // iss 72 <-- handled 3rd - // ahv 73 - // ahv 74 - // ahv 75 <-- handled 4th + // fss 80 + // iss 90 + // eah 100 <-- handled 1st + // iss 120 + // iss 150 + // fss 160 + // iss 180 + // iss 210 + // fss 240 <-- handled 2nd + // iss 270 + // iss 300 <-- handled 3rd + // ahv 301 + // ahv 302 + // ahv 303 <-- handled 4th // // (slots not called out will all be AHV) - // Also, incremental snapshots before slot 60 (the first full snapshot handled), will + // Also, incremental snapshots before slot 240 (the first full snapshot handled), will // actually be AHV since the last full snapshot slot will be `None`. This is expected and // fine; but maybe unexpected for a reader/debugger without this additional context. let mut parent = Arc::clone(&bank); - for _ in 0..75 { + for _ in 0..303 { let bank = Arc::new(Bank::new_from_parent( &parent, &Pubkey::new_unique(), @@ -908,9 +907,9 @@ mod test { accounts_package_type, AccountsPackageType::EpochAccountsHash ); - assert_eq!(snapshot_request.snapshot_root_bank.slot(), 25); + assert_eq!(snapshot_request.snapshot_root_bank.slot(), 100); - // Ensure the full snapshot from slot 60 is handled 2nd + // Ensure the full snapshot from slot 240 is handled 2nd // (the older full snapshots are skipped and dropped) let (snapshot_request, accounts_package_type, ..) = snapshot_request_handler .get_next_snapshot_request(None) @@ -919,33 +918,33 @@ mod test { accounts_package_type, AccountsPackageType::Snapshot(SnapshotType::FullSnapshot) ); - assert_eq!(snapshot_request.snapshot_root_bank.slot(), 60); + assert_eq!(snapshot_request.snapshot_root_bank.slot(), 240); - // Ensure the incremental snapshot from slot 72 is handled 3rd + // Ensure the incremental snapshot from slot 300 is handled 3rd // (the older incremental snapshots are skipped and dropped) let (snapshot_request, accounts_package_type, ..) = snapshot_request_handler - .get_next_snapshot_request(Some(60)) + .get_next_snapshot_request(Some(240)) .unwrap(); assert_eq!( accounts_package_type, - AccountsPackageType::Snapshot(SnapshotType::IncrementalSnapshot(60)) + AccountsPackageType::Snapshot(SnapshotType::IncrementalSnapshot(240)) ); - assert_eq!(snapshot_request.snapshot_root_bank.slot(), 72); + assert_eq!(snapshot_request.snapshot_root_bank.slot(), 300); - // Ensure the accounts hash verifier from slot 75 is handled 4th + // Ensure the accounts hash verifier from slot 303 is handled 4th // (the older accounts hash verifiers are skipped and dropped) let (snapshot_request, accounts_package_type, ..) = snapshot_request_handler - .get_next_snapshot_request(Some(60)) + .get_next_snapshot_request(Some(240)) .unwrap(); assert_eq!( accounts_package_type, AccountsPackageType::AccountsHashVerifier ); - assert_eq!(snapshot_request.snapshot_root_bank.slot(), 75); + assert_eq!(snapshot_request.snapshot_root_bank.slot(), 303); // And now ensure the snapshot request channel is empty! assert!(snapshot_request_handler - .get_next_snapshot_request(Some(60)) + .get_next_snapshot_request(Some(240)) .is_none()); } }