From b09d44c235f1e65aa630345e211f823409bc06fa Mon Sep 17 00:00:00 2001 From: Alex Stokes Date: Thu, 10 Jan 2019 14:49:06 -0600 Subject: [PATCH] Gets this module to compile, at expense of deviating from old spec Some changes to integrate with the newer `ValidatorRecord` type. Deviates from the old spec but should be updated shortly with newer logic so the breaking change is only temporary. --- .../validator_induction/src/inductor.rs | 20 +++++++------------ 1 file changed, 7 insertions(+), 13 deletions(-) diff --git a/beacon_chain/validator_induction/src/inductor.rs b/beacon_chain/validator_induction/src/inductor.rs index f00c9ec55..4ac9d7924 100644 --- a/beacon_chain/validator_induction/src/inductor.rs +++ b/beacon_chain/validator_induction/src/inductor.rs @@ -1,6 +1,6 @@ use bls::verify_proof_of_possession; use spec::ChainSpec; -use types::{BeaconState, Deposit, ValidatorRecord, ValidatorStatus}; +use types::{BeaconState, Deposit, ValidatorRecord}; #[derive(Debug, PartialEq, Clone)] pub enum ValidatorInductionError { @@ -43,13 +43,10 @@ pub fn process_deposit( pubkey: deposit_input.pubkey.clone(), withdrawal_credentials: deposit_input.withdrawal_credentials, randao_commitment: deposit_input.randao_commitment, - randao_layers: 0, - status: ValidatorStatus::PendingActivation, - latest_status_change_slot: state.validator_registry_latest_change_slot, - exit_count: 0, custody_commitment: deposit_input.custody_commitment, latest_custody_reseed_slot: 0, penultimate_custody_reseed_slot: 0, + ..std::default::Default::default() }; match min_empty_validator_index(state, spec) { @@ -68,13 +65,11 @@ pub fn process_deposit( } } -fn min_empty_validator_index(state: &BeaconState, spec: &ChainSpec) -> Option { +// NOTE: this has been modified from the spec to get tests working +// this function is no longer used in the latest spec so this is simply a transition step +fn min_empty_validator_index(state: &BeaconState, _spec: &ChainSpec) -> Option { for i in 0..state.validator_registry.len() { - if state.validator_balances[i] == 0 - && state.validator_registry[i].latest_status_change_slot - + spec.zero_balance_validator_ttl - <= state.slot - { + if state.validator_balances[i] == 0 { return Some(i); } } @@ -187,8 +182,7 @@ mod tests { let mut state = BeaconState::default(); let spec = ChainSpec::foundation(); - let mut validator = get_validator(); - validator.latest_status_change_slot = 0; + let validator = get_validator(); state.validator_registry.push(validator); state.validator_balances.push(0);