merge_parents() => squash() (#2943)

This commit is contained in:
Rob Walker 2019-02-25 20:34:05 -08:00 committed by GitHub
parent 897279eddb
commit 25690ff078
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 24 additions and 26 deletions

View File

@ -257,7 +257,7 @@ impl AccountsDB {
}
/// become the root accountsDB
fn merge_parents<U>(&mut self, parents: &[U])
fn squash<U>(&mut self, parents: &[U])
where
U: Deref<Target = Self>,
{
@ -407,8 +407,8 @@ impl Accounts {
}
/// accounts starts with an empty data structure for every child/fork
/// this merges all the parents/checkpoints
pub fn merge_parents<U>(&self, parents: &[U])
/// this function squashes all the parents into this instance
pub fn squash<U>(&self, parents: &[U])
where
U: Deref<Target = Self>,
{
@ -419,7 +419,7 @@ impl Accounts {
.map(|obj| obj.accounts_db.read().unwrap())
.collect();
self.accounts_db.write().unwrap().merge_parents(&dbs);
self.accounts_db.write().unwrap().squash(&dbs);
}
}
@ -832,7 +832,7 @@ mod tests {
}
#[test]
fn test_accounts_merge_parents() {
fn test_accounts_squash() {
let mut db0 = AccountsDB::default();
let key = Pubkey::default();
let account = Account::new(1, 0, key);
@ -844,8 +844,8 @@ mod tests {
let mut db1 = AccountsDB::default();
db1.store(false, &key, &Account::new(0, 0, key));
// merge, which should whack key's account
db1.merge_parents(&[&db0]);
// squash, which should whack key's account
db1.squash(&[&db0]);
assert_eq!(AccountsDB::load(&[&db1], &key), None);
}

View File

@ -163,25 +163,22 @@ impl Bank {
}
}
/// merge (i.e. pull) the parent's state up into this Bank,
/// squash the parent's state up into this Bank,
/// this Bank becomes a root
pub fn merge_parents(&self) {
pub fn squash(&self) {
self.freeze();
let parents = self.parents();
*self.parent.write().unwrap() = None;
let parent_accounts: Vec<_> = parents.iter().map(|b| &b.accounts).collect();
self.accounts.merge_parents(&parent_accounts);
self.accounts.squash(&parent_accounts);
let parent_caches: Vec<_> = parents
.iter()
.map(|b| b.status_cache.read().unwrap())
.collect();
self.status_cache
.write()
.unwrap()
.merge_parents(&parent_caches);
self.status_cache.write().unwrap().squash(&parent_caches);
}
/// Return the more recent checkpoint of this bank instance.
@ -1472,7 +1469,7 @@ mod tests {
}
#[test]
fn test_bank_hash_internal_state_merge_parents() {
fn test_bank_hash_internal_state_squash() {
let bank0 = Arc::new(Bank::new(&GenesisBlock::new(10).0));
let bank1 = Bank::new_from_parent_and_id(&bank0, 1);
@ -1480,7 +1477,7 @@ mod tests {
assert_eq!(bank0.hash_internal_state(), bank1.hash_internal_state());
// remove parent
bank1.merge_parents();
bank1.squash();
assert!(bank1.parents().is_empty());
// hash should still match
@ -1489,7 +1486,7 @@ mod tests {
/// Verifies that last ids and accounts are correctly referenced from parent
#[test]
fn test_bank_merge_parents() {
fn test_bank_squash() {
let (genesis_block, mint_keypair) = GenesisBlock::new(2);
let key1 = Keypair::new();
let key2 = Keypair::new();
@ -1526,7 +1523,7 @@ mod tests {
);
// works iteration 0, no-ops on iteration 1 and 2
bank.merge_parents();
bank.squash();
}
}

View File

@ -84,8 +84,9 @@ impl<T: Clone> StatusCache<T> {
self.get_signature_status_merged(sig)
}
fn merge_parent_is_full(&mut self, parent: &Self) -> bool {
// flatten the parent and their merges into self.merges, limit
fn squash_parent_is_full(&mut self, parent: &Self) -> bool {
// flatten and squash the parent and its merges into self.merges,
// returns true if self is full
self.merges.push_back(StatusCache {
signatures: parent.signatures.clone(),
@ -106,12 +107,12 @@ impl<T: Clone> StatusCache<T> {
/// copy the parents and parents' merges up to this instance, up to
/// MAX_CACHE_ENTRIES deep
pub fn merge_parents<U>(&mut self, parents: &[U])
pub fn squash<U>(&mut self, parents: &[U])
where
U: Deref<Target = Self>,
{
for parent in parents {
if self.merge_parent_is_full(parent) {
if self.squash_parent_is_full(parent) {
break;
}
}
@ -233,7 +234,7 @@ mod tests {
}
#[test]
fn test_status_cache_merge_parents_has_signature() {
fn test_status_cache_squash_has_signature() {
let sig = Signature::default();
let last_id = hash(Hash::default().as_ref());
let mut first = BankStatusCache::new(&last_id);
@ -247,7 +248,7 @@ mod tests {
let last_id = hash(last_id.as_ref());
let mut second = BankStatusCache::new(&last_id);
second.merge_parents(&[&first]);
second.squash(&[&first]);
assert_eq!(second.get_signature_status(&sig), Some(Ok(())));
assert!(second.has_signature(&sig));
@ -255,7 +256,7 @@ mod tests {
#[test]
#[ignore] // takes a lot of time or RAM or both..
fn test_status_cache_merge_parents_overflow() {
fn test_status_cache_squash_overflow() {
let mut last_id = hash(Hash::default().as_ref());
let mut cache = BankStatusCache::new(&last_id);
@ -281,7 +282,7 @@ mod tests {
assert!(root.has_signature(&sig));
// will overflow
cache.merge_parents(&parents_refs);
cache.squash(&parents_refs);
assert_eq!(cache.get_signature_status(&sig), None);
assert!(!cache.has_signature(&sig));