From 8c98c5b165046de38af12ca23b088727feb6965b Mon Sep 17 00:00:00 2001 From: "Jeff Washington (jwash)" Date: Wed, 4 Jan 2023 12:15:56 -0600 Subject: [PATCH] get_storages_for_slot uses get_slot_storage_entry (#29498) --- runtime/src/account_storage.rs | 9 --------- runtime/src/accounts_db.rs | 33 ++++++++++----------------------- 2 files changed, 10 insertions(+), 32 deletions(-) diff --git a/runtime/src/account_storage.rs b/runtime/src/account_storage.rs index aa7ca5795d392b..1452c2a8b5e2e0 100644 --- a/runtime/src/account_storage.rs +++ b/runtime/src/account_storage.rs @@ -1,7 +1,5 @@ //! Manage the map of slot -> append vecs -#[cfg(test)] -use crate::accounts_db::SnapshotStorage; use { crate::accounts_db::{AccountStorageEntry, AppendVecId, SlotStores}, dashmap::DashMap, @@ -44,13 +42,6 @@ impl AccountStorage { }) } - /// return all append vecs for 'slot' if any exist - #[cfg(test)] - pub(crate) fn get_slot_storage_entries(&self, slot: Slot) -> Option { - self.get_slot_stores(slot) - .map(|res| res.read().unwrap().values().cloned().collect()) - } - pub(crate) fn all_slots(&self) -> Vec { self.map.iter().map(|iter_item| *iter_item.key()).collect() } diff --git a/runtime/src/accounts_db.rs b/runtime/src/accounts_db.rs index 5c453216c051f8..28d8006dd84e9b 100644 --- a/runtime/src/accounts_db.rs +++ b/runtime/src/accounts_db.rs @@ -4266,7 +4266,9 @@ impl AccountsDb { #[cfg(test)] fn get_storages_for_slot(&self, slot: Slot) -> Option { - self.storage.get_slot_storage_entries(slot) + self.storage + .get_slot_storage_entry(slot) + .map(|storage| vec![storage]) } /// 'accounts' that exist in the current slot we are combining into a different ancient slot @@ -14216,9 +14218,7 @@ pub mod tests { } fn slot_stores(db: &AccountsDb, slot: Slot) -> SnapshotStorage { - db.storage - .get_slot_storage_entries(slot) - .unwrap_or_default() + db.get_storages_for_slot(slot).unwrap_or_default() } #[test] @@ -14573,10 +14573,8 @@ pub mod tests { impl AccountsDb { fn get_and_assert_single_storage(&self, slot: Slot) -> Arc { - let mut storage_maps: SnapshotStorage = self - .storage - .get_slot_storage_entries(slot) - .unwrap_or_default(); + let mut storage_maps: SnapshotStorage = + self.get_storages_for_slot(slot).unwrap_or_default(); assert_eq!(storage_maps.len(), 1); storage_maps.pop().unwrap() @@ -15856,10 +15854,7 @@ pub mod tests { accounts.store_for_tests(slot0, &[(&shared_key, &account)]); accounts.add_root_and_flush_write_cache(slot0); - let storage_maps = accounts - .storage - .get_slot_storage_entries(slot0) - .unwrap_or_default(); + let storage_maps = accounts.get_storages_for_slot(slot0).unwrap_or_default(); let storage_info = StorageSizeAndCountMap::default(); let accounts_map = accounts.process_storage_slot(&storage_maps[..]); AccountsDb::update_storage_info(&storage_info, &accounts_map, &Mutex::default()); @@ -15908,10 +15903,7 @@ pub mod tests { accounts.store_for_tests(slot0, &[(&keys[1], &account_big)]); accounts.add_root_and_flush_write_cache(slot0); - let storage_maps = accounts - .storage - .get_slot_storage_entries(slot0) - .unwrap_or_default(); + let storage_maps = accounts.get_storages_for_slot(slot0).unwrap_or_default(); let storage_info = StorageSizeAndCountMap::default(); let accounts_map = accounts.process_storage_slot(&storage_maps[..]); AccountsDb::update_storage_info(&storage_info, &accounts_map, &Mutex::default()); @@ -16013,7 +16005,7 @@ pub mod tests { /// asserts that not only are there 0 append vecs, but there is not even an entry in the storage map for 'slot' fn assert_no_storages_at_slot(db: &AccountsDb, slot: Slot) { - assert!(db.storage.get_slot_storage_entries(slot).is_none()); + assert!(db.get_storages_for_slot(slot).is_none()); } /// Test to make sure `clean_accounts()` works properly with the `last_full_snapshot_slot` @@ -17401,12 +17393,7 @@ pub mod tests { let max_slot_inclusive = ancient_slot + (num_normal_slots as Slot); let initial_accounts = get_all_accounts(&db, ancient_slot..(max_slot_inclusive + 1)); - let ancient = db - .get_storages_for_slot(ancient_slot) - .unwrap() - .first() - .unwrap() - .clone(); + let ancient = db.storage.get_slot_storage_entry(ancient_slot).unwrap(); let initial_len = ancient.alive_bytes(); // set size of ancient to be 'full' adjust_append_vec_len_for_tests(&ancient, ancient.accounts.capacity() as usize);