Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: electra fork transition spec tests #6769

Merged
merged 3 commits into from
May 14, 2024

Conversation

twoeths
Copy link
Contributor

@twoeths twoeths commented May 14, 2024

Motivation

Fix electra fork transition spec tests

Description

Follow https://github.com/ethereum/consensus-specs/blob/dev/specs/electra/fork.md

· deneb/fork/fork/pyspec_tests/deneb_fork_random_2
     ✓ deneb/fork/fork/pyspec_tests/deneb_fork_random_2
 ✓ test/spec/presets/fork.test.ts (72) 1554ms
   ✓ altair/fork/fork/pyspec_tests (16) 475ms
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_0
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_1
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_2
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_3
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_duplicate_attestations
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_large_validator_set
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_low_balances
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_misc_balances
     ✓ altair/fork/fork/pyspec_tests/altair_fork_random_mismatched_attestations
     ✓ altair/fork/fork/pyspec_tests/fork_base_state
     ✓ altair/fork/fork/pyspec_tests/fork_many_next_epoch
     ✓ altair/fork/fork/pyspec_tests/fork_next_epoch
     ✓ altair/fork/fork/pyspec_tests/fork_next_epoch_with_block
     ✓ altair/fork/fork/pyspec_tests/fork_random_large_validator_set
     ✓ altair/fork/fork/pyspec_tests/fork_random_low_balances
     ✓ altair/fork/fork/pyspec_tests/fork_random_misc_balances
   ✓ bellatrix/fork/fork/pyspec_tests (14)
     ✓ bellatrix/fork/fork/pyspec_tests/bellatrix_fork_random_0
     ✓ bellatrix/fork/fork/pyspec_tests/bellatrix_fork_random_1
     ✓ bellatrix/fork/fork/pyspec_tests/bellatrix_fork_random_2
     ✓ bellatrix/fork/fork/pyspec_tests/bellatrix_fork_random_3
     ✓ bellatrix/fork/fork/pyspec_tests/bellatrix_fork_random_large_validator_set
     ✓ bellatrix/fork/fork/pyspec_tests/bellatrix_fork_random_low_balances
     ✓ bellatrix/fork/fork/pyspec_tests/bellatrix_fork_random_misc_balances
     ✓ bellatrix/fork/fork/pyspec_tests/fork_base_state
     ✓ bellatrix/fork/fork/pyspec_tests/fork_many_next_epoch
     ✓ bellatrix/fork/fork/pyspec_tests/fork_next_epoch
     ✓ bellatrix/fork/fork/pyspec_tests/fork_next_epoch_with_block
     ✓ bellatrix/fork/fork/pyspec_tests/fork_random_large_validator_set
     ✓ bellatrix/fork/fork/pyspec_tests/fork_random_low_balances
     ✓ bellatrix/fork/fork/pyspec_tests/fork_random_misc_balances
   ✓ capella/fork/fork/pyspec_tests (14)
     ✓ capella/fork/fork/pyspec_tests/capella_fork_random_0
     ✓ capella/fork/fork/pyspec_tests/capella_fork_random_1
     ✓ capella/fork/fork/pyspec_tests/capella_fork_random_2
     ✓ capella/fork/fork/pyspec_tests/capella_fork_random_3
     ✓ capella/fork/fork/pyspec_tests/capella_fork_random_large_validator_set
     ✓ capella/fork/fork/pyspec_tests/capella_fork_random_low_balances
     ✓ capella/fork/fork/pyspec_tests/capella_fork_random_misc_balances
     ✓ capella/fork/fork/pyspec_tests/fork_base_state
     ✓ capella/fork/fork/pyspec_tests/fork_many_next_epoch
     ✓ capella/fork/fork/pyspec_tests/fork_next_epoch
     ✓ capella/fork/fork/pyspec_tests/fork_next_epoch_with_block
     ✓ capella/fork/fork/pyspec_tests/fork_random_large_validator_set
     ✓ capella/fork/fork/pyspec_tests/fork_random_low_balances
     ✓ capella/fork/fork/pyspec_tests/fork_random_misc_balances
   ✓ deneb/fork/fork/pyspec_tests (14) 381ms
     ✓ deneb/fork/fork/pyspec_tests/deneb_fork_random_0
     ✓ deneb/fork/fork/pyspec_tests/deneb_fork_random_1
     ✓ deneb/fork/fork/pyspec_tests/deneb_fork_random_2
     ✓ deneb/fork/fork/pyspec_tests/deneb_fork_random_3
     ✓ deneb/fork/fork/pyspec_tests/deneb_fork_random_large_validator_set
     ✓ deneb/fork/fork/pyspec_tests/deneb_fork_random_low_balances
     ✓ deneb/fork/fork/pyspec_tests/deneb_fork_random_misc_balances
     ✓ deneb/fork/fork/pyspec_tests/fork_base_state
     ✓ deneb/fork/fork/pyspec_tests/fork_many_next_epoch
     ✓ deneb/fork/fork/pyspec_tests/fork_next_epoch
     ✓ deneb/fork/fork/pyspec_tests/fork_next_epoch_with_block
     ✓ deneb/fork/fork/pyspec_tests/fork_random_large_validator_set
     ✓ deneb/fork/fork/pyspec_tests/fork_random_low_balances
     ✓ deneb/fork/fork/pyspec_tests/fork_random_misc_balances
   ✓ electra/fork/fork/pyspec_tests (14)
     ✓ electra/fork/fork/pyspec_tests/electra_fork_random_0
     ✓ electra/fork/fork/pyspec_tests/electra_fork_random_1
     ✓ electra/fork/fork/pyspec_tests/electra_fork_random_2
     ✓ electra/fork/fork/pyspec_tests/electra_fork_random_3
     ✓ electra/fork/fork/pyspec_tests/electra_fork_random_large_validator_set
     ✓ electra/fork/fork/pyspec_tests/electra_fork_random_low_balances
     ✓ electra/fork/fork/pyspec_tests/electra_fork_random_misc_balances
     ✓ electra/fork/fork/pyspec_tests/fork_base_state
     ✓ electra/fork/fork/pyspec_tests/fork_many_next_epoch
     ✓ electra/fork/fork/pyspec_tests/fork_next_epoch
     ✓ electra/fork/fork/pyspec_tests/fork_next_epoch_with_block
     ✓ electra/fork/fork/pyspec_tests/fork_random_large_validator_set
     ✓ electra/fork/fork/pyspec_tests/fork_random_low_balances
     ✓ electra/fork/fork/pyspec_tests/fork_random_misc_balances

 Test Files  1 passed (1)
      Tests  72 passed (72)

@twoeths twoeths requested a review from a team as a code owner May 14, 2024 09:21
@twoeths twoeths force-pushed the tuyen/fix_fork_spec_tests branch from 4e650ae to 31978f4 Compare May 14, 2024 09:26
exitEpochs.push(currentEpochPre);
}
stateElectraView.earliestExitEpoch = Math.max(...exitEpochs) + 1;
stateElectraView.consolidationBalanceToConsume = BigInt(0);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is this line needed if its set in L95?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is this line needed if its set in L95?

Current implementation of upgradeStateToElectra() is just a hacky function solely for devnet 0 and related spec tests.

Eventually we will need to replace upgradeStateToElectra() with upgradeStateToElectraOriginal(). I think we can clean up and fix small details at that time

@ensi321 ensi321 merged commit de9ed21 into electra-fork May 14, 2024
12 of 17 checks passed
@ensi321 ensi321 deleted the tuyen/fix_fork_spec_tests branch May 14, 2024 09:56
g11tech pushed a commit that referenced this pull request May 24, 2024
* fix: electra fork transition

* fix: merge issue

* chore: remove unwanted change
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

3 participants