Skip to content

Commit

Permalink
Use 400 slots-per-epoch in EAH tests (solana-labs#28801)
Browse files Browse the repository at this point in the history
  • Loading branch information
brooksprumo authored and gnapoli23 committed Dec 16, 2022
1 parent efd1e4c commit 02eab3c
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 39 deletions.
14 changes: 7 additions & 7 deletions core/tests/epoch_accounts_hash.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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 {
Expand Down Expand Up @@ -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();

Expand Down Expand Up @@ -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);
Expand Down Expand Up @@ -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);
Expand Down
63 changes: 31 additions & 32 deletions runtime/src/accounts_background_service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down Expand Up @@ -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(),
Expand All @@ -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)
Expand All @@ -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());
}
}

0 comments on commit 02eab3c

Please sign in to comment.