Skip to content

Commit

Permalink
Prevent repeated accounts in genesis to avoid breaking account hashing
Browse files Browse the repository at this point in the history
  • Loading branch information
mvines committed Oct 6, 2019
1 parent 4870a2c commit c34cc49
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 9 deletions.
7 changes: 6 additions & 1 deletion local_cluster/src/local_cluster.rs
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,12 @@ impl LocalCluster {
storage_contract::create_validator_storage_account(leader_pubkey, 1),
));

// override staking config
// Replace staking config
genesis_block.accounts = genesis_block
.accounts
.into_iter()
.filter(|(pubkey, _)| *pubkey != stake_config::id())
.collect();
genesis_block.accounts.push((
stake_config::id(),
stake_config::create_account(
Expand Down
27 changes: 19 additions & 8 deletions runtime/src/bank.rs
Original file line number Diff line number Diff line change
Expand Up @@ -611,11 +611,17 @@ impl Bank {
self.update_fees();

for (pubkey, account) in genesis_block.accounts.iter() {
if self.get_account(&pubkey).is_some() {
panic!("{} repeated in genesis block", pubkey);
}
self.store_account(pubkey, account);
self.capitalization
.fetch_add(account.lamports, Ordering::Relaxed);
}
for (pubkey, account) in genesis_block.rewards_pools.iter() {
if self.get_account(&pubkey).is_some() {
panic!("{} repeated in genesis block", pubkey);
}
self.store_account(pubkey, account);
}

Expand Down Expand Up @@ -1637,7 +1643,10 @@ mod tests {
#[test]
fn test_bank_capitalization() {
let bank = Arc::new(Bank::new(&GenesisBlock {
accounts: vec![(Pubkey::default(), Account::new(42, 0, &Pubkey::default()),); 42],
accounts: (0..42)
.into_iter()
.map(|_| (Pubkey::new_rand(), Account::new(42, 0, &Pubkey::default())))
.collect(),
..GenesisBlock::default()
}));
assert_eq!(bank.capitalization(), 42 * 42);
Expand All @@ -1649,13 +1658,15 @@ mod tests {
fn test_bank_update_rewards() {
// create a bank that ticks really slowly...
let bank = Arc::new(Bank::new(&GenesisBlock {
accounts: vec![
(
Pubkey::default(),
Account::new(1_000_000_000, 0, &Pubkey::default()),
);
42
],
accounts: (0..42)
.into_iter()
.map(|_| {
(
Pubkey::new_rand(),
Account::new(1_000_000_000, 0, &Pubkey::default()),
)
})
.collect(),
// set it up so the first epoch is a full year long
poh_config: PohConfig {
target_tick_duration: Duration::from_secs(
Expand Down

0 comments on commit c34cc49

Please sign in to comment.