Fix rng of tests

This commit is contained in:
Hsiao-Wei Wang 2024-04-27 14:49:40 +08:00
parent 3c96d41f4c
commit c70bcba878
No known key found for this signature in database
GPG Key ID: AE3D6B174F971DE4
4 changed files with 47 additions and 33 deletions

View File

@ -324,7 +324,7 @@ def test_zero_length_transaction_regular_payload(spec, state):
yield from run_zero_length_transaction_test(spec, state) yield from run_zero_length_transaction_test(spec, state)
def run_randomized_non_validated_execution_fields_test(spec, state, execution_valid=True, rng=Random(5555)): def run_randomized_non_validated_execution_fields_test(spec, state, rng, execution_valid=True):
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_randomized_execution_payload(spec, state, rng) execution_payload = build_randomized_execution_payload(spec, state, rng)
@ -340,7 +340,7 @@ def run_randomized_non_validated_execution_fields_test(spec, state, execution_va
def test_randomized_non_validated_execution_fields_first_payload__execution_valid(spec, state): def test_randomized_non_validated_execution_fields_first_payload__execution_valid(spec, state):
rng = Random(1111) rng = Random(1111)
state = build_state_with_incomplete_transition(spec, state) state = build_state_with_incomplete_transition(spec, state)
yield from run_randomized_non_validated_execution_fields_test(spec, state, rng=rng) yield from run_randomized_non_validated_execution_fields_test(spec, state, rng)
@with_bellatrix_and_later @with_bellatrix_and_later
@ -348,7 +348,7 @@ def test_randomized_non_validated_execution_fields_first_payload__execution_vali
def test_randomized_non_validated_execution_fields_regular_payload__execution_valid(spec, state): def test_randomized_non_validated_execution_fields_regular_payload__execution_valid(spec, state):
rng = Random(2222) rng = Random(2222)
state = build_state_with_complete_transition(spec, state) state = build_state_with_complete_transition(spec, state)
yield from run_randomized_non_validated_execution_fields_test(spec, state, rng=rng) yield from run_randomized_non_validated_execution_fields_test(spec, state, rng)
@with_bellatrix_and_later @with_bellatrix_and_later
@ -356,7 +356,7 @@ def test_randomized_non_validated_execution_fields_regular_payload__execution_va
def test_invalid_randomized_non_validated_execution_fields_first_payload__execution_invalid(spec, state): def test_invalid_randomized_non_validated_execution_fields_first_payload__execution_invalid(spec, state):
rng = Random(3333) rng = Random(3333)
state = build_state_with_incomplete_transition(spec, state) state = build_state_with_incomplete_transition(spec, state)
yield from run_randomized_non_validated_execution_fields_test(spec, state, execution_valid=False, rng=rng) yield from run_randomized_non_validated_execution_fields_test(spec, state, rng, execution_valid=False)
@with_bellatrix_and_later @with_bellatrix_and_later
@ -364,4 +364,4 @@ def test_invalid_randomized_non_validated_execution_fields_first_payload__execut
def test_invalid_randomized_non_validated_execution_fields_regular_payload__execution_invalid(spec, state): def test_invalid_randomized_non_validated_execution_fields_regular_payload__execution_invalid(spec, state):
rng = Random(4444) rng = Random(4444)
state = build_state_with_complete_transition(spec, state) state = build_state_with_complete_transition(spec, state)
yield from run_randomized_non_validated_execution_fields_test(spec, state, execution_valid=False, rng=rng) yield from run_randomized_non_validated_execution_fields_test(spec, state, rng, execution_valid=False)

View File

@ -113,7 +113,7 @@ def test_success_zero_expected_withdrawals(spec, state):
@spec_state_test @spec_state_test
def test_success_one_full_withdrawal(spec, state): def test_success_one_full_withdrawal(spec, state):
fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals( fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals(
spec, state, num_full_withdrawals=1) spec, state, rng=random.Random(42), num_full_withdrawals=1)
assert len(fully_withdrawable_indices) == 1 assert len(fully_withdrawable_indices) == 1
assert len(partial_withdrawals_indices) == 0 assert len(partial_withdrawals_indices) == 0
@ -130,7 +130,7 @@ def test_success_one_full_withdrawal(spec, state):
@spec_state_test @spec_state_test
def test_success_one_partial_withdrawal(spec, state): def test_success_one_partial_withdrawal(spec, state):
fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals( fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals(
spec, state, num_partial_withdrawals=1) spec, state, rng=random.Random(42), num_partial_withdrawals=1)
assert len(fully_withdrawable_indices) == 0 assert len(fully_withdrawable_indices) == 0
assert len(partial_withdrawals_indices) == 1 assert len(partial_withdrawals_indices) == 1
for index in partial_withdrawals_indices: for index in partial_withdrawals_indices:
@ -153,6 +153,7 @@ def test_success_mixed_fully_and_partial_withdrawable(spec, state):
num_partial_withdrawals = spec.MAX_WITHDRAWALS_PER_PAYLOAD - num_full_withdrawals num_partial_withdrawals = spec.MAX_WITHDRAWALS_PER_PAYLOAD - num_full_withdrawals
fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals( fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals(
spec, state, spec, state,
rng=random.Random(42),
num_full_withdrawals=num_full_withdrawals, num_full_withdrawals=num_full_withdrawals,
num_partial_withdrawals=num_partial_withdrawals, num_partial_withdrawals=num_partial_withdrawals,
) )
@ -174,7 +175,7 @@ def test_success_all_fully_withdrawable_in_one_sweep(spec, state):
withdrawal_count = len(state.validators) withdrawal_count = len(state.validators)
fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals( fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals(
spec, state, num_full_withdrawals=withdrawal_count) spec, state, rng=random.Random(42), num_full_withdrawals=withdrawal_count)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -193,7 +194,7 @@ def test_success_all_fully_withdrawable(spec, state):
withdrawal_count = spec.MAX_VALIDATORS_PER_WITHDRAWALS_SWEEP withdrawal_count = spec.MAX_VALIDATORS_PER_WITHDRAWALS_SWEEP
fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals( fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals(
spec, state, num_full_withdrawals=withdrawal_count) spec, state, rng=random.Random(42), num_full_withdrawals=withdrawal_count)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -212,7 +213,7 @@ def test_success_all_partially_withdrawable_in_one_sweep(spec, state):
withdrawal_count = len(state.validators) withdrawal_count = len(state.validators)
fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals( fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals(
spec, state, num_partial_withdrawals=withdrawal_count) spec, state, rng=random.Random(42), num_partial_withdrawals=withdrawal_count)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -231,7 +232,7 @@ def test_success_all_partially_withdrawable(spec, state):
withdrawal_count = spec.MAX_VALIDATORS_PER_WITHDRAWALS_SWEEP withdrawal_count = spec.MAX_VALIDATORS_PER_WITHDRAWALS_SWEEP
fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals( fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals(
spec, state, num_partial_withdrawals=withdrawal_count) spec, state, rng=random.Random(42), num_partial_withdrawals=withdrawal_count)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -266,7 +267,7 @@ def test_invalid_non_withdrawable_non_empty_withdrawals(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_one_expected_full_withdrawal_and_none_in_withdrawals(spec, state): def test_invalid_one_expected_full_withdrawal_and_none_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=1) prepare_expected_withdrawals(spec, state, rng=random.Random(42), num_full_withdrawals=1)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -279,7 +280,7 @@ def test_invalid_one_expected_full_withdrawal_and_none_in_withdrawals(spec, stat
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_one_expected_partial_withdrawal_and_none_in_withdrawals(spec, state): def test_invalid_one_expected_partial_withdrawal_and_none_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_partial_withdrawals=1) prepare_expected_withdrawals(spec, state, rng=random.Random(42), num_partial_withdrawals=1)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -292,7 +293,7 @@ def test_invalid_one_expected_partial_withdrawal_and_none_in_withdrawals(spec, s
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_one_expected_full_withdrawal_and_duplicate_in_withdrawals(spec, state): def test_invalid_one_expected_full_withdrawal_and_duplicate_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=2) prepare_expected_withdrawals(spec, state, rng=random.Random(42), num_full_withdrawals=2)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -305,7 +306,7 @@ def test_invalid_one_expected_full_withdrawal_and_duplicate_in_withdrawals(spec,
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_two_expected_partial_withdrawal_and_duplicate_in_withdrawals(spec, state): def test_invalid_two_expected_partial_withdrawal_and_duplicate_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_partial_withdrawals=2) prepare_expected_withdrawals(spec, state, rng=random.Random(42), num_partial_withdrawals=2)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -318,7 +319,8 @@ def test_invalid_two_expected_partial_withdrawal_and_duplicate_in_withdrawals(sp
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_max_per_slot_full_withdrawals_and_one_less_in_withdrawals(spec, state): def test_invalid_max_per_slot_full_withdrawals_and_one_less_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -331,7 +333,8 @@ def test_invalid_max_per_slot_full_withdrawals_and_one_less_in_withdrawals(spec,
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_max_per_slot_partial_withdrawals_and_one_less_in_withdrawals(spec, state): def test_invalid_max_per_slot_partial_withdrawals_and_one_less_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -344,7 +347,8 @@ def test_invalid_max_per_slot_partial_withdrawals_and_one_less_in_withdrawals(sp
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_a_lot_fully_withdrawable_too_few_in_withdrawals(spec, state): def test_invalid_a_lot_fully_withdrawable_too_few_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -357,7 +361,8 @@ def test_invalid_a_lot_fully_withdrawable_too_few_in_withdrawals(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_a_lot_partially_withdrawable_too_few_in_withdrawals(spec, state): def test_invalid_a_lot_partially_withdrawable_too_few_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -370,7 +375,8 @@ def test_invalid_a_lot_partially_withdrawable_too_few_in_withdrawals(spec, state
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_a_lot_mixed_withdrawable_in_queue_too_few_in_withdrawals(spec, state): def test_invalid_a_lot_mixed_withdrawable_in_queue_too_few_in_withdrawals(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD, prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD,
num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD) num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD)
next_slot(spec, state) next_slot(spec, state)
@ -388,7 +394,8 @@ def test_invalid_a_lot_mixed_withdrawable_in_queue_too_few_in_withdrawals(spec,
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_incorrect_withdrawal_index(spec, state): def test_invalid_incorrect_withdrawal_index(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=1) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_full_withdrawals=1)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -401,7 +408,8 @@ def test_invalid_incorrect_withdrawal_index(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_incorrect_address_full(spec, state): def test_invalid_incorrect_address_full(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=1) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_full_withdrawals=1)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -414,7 +422,8 @@ def test_invalid_incorrect_address_full(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_incorrect_address_partial(spec, state): def test_invalid_incorrect_address_partial(spec, state):
prepare_expected_withdrawals(spec, state, num_partial_withdrawals=1) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_partial_withdrawals=1)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -427,7 +436,7 @@ def test_invalid_incorrect_address_partial(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_incorrect_amount_full(spec, state): def test_invalid_incorrect_amount_full(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=1) prepare_expected_withdrawals(spec, state, rng=random.Random(42), num_full_withdrawals=1)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -440,7 +449,7 @@ def test_invalid_incorrect_amount_full(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_incorrect_amount_partial(spec, state): def test_invalid_incorrect_amount_partial(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=1) prepare_expected_withdrawals(spec, state, rng=random.Random(42), num_full_withdrawals=1)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -453,7 +462,8 @@ def test_invalid_incorrect_amount_partial(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_one_of_many_incorrectly_full(spec, state): def test_invalid_one_of_many_incorrectly_full(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -472,7 +482,8 @@ def test_invalid_one_of_many_incorrectly_full(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_one_of_many_incorrectly_partial(spec, state): def test_invalid_one_of_many_incorrectly_partial(spec, state):
prepare_expected_withdrawals(spec, state, num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -491,7 +502,8 @@ def test_invalid_one_of_many_incorrectly_partial(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_many_incorrectly_full(spec, state): def test_invalid_many_incorrectly_full(spec, state):
prepare_expected_withdrawals(spec, state, num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)
@ -510,7 +522,8 @@ def test_invalid_many_incorrectly_full(spec, state):
@with_capella_and_later @with_capella_and_later
@spec_state_test @spec_state_test
def test_invalid_many_incorrectly_partial(spec, state): def test_invalid_many_incorrectly_partial(spec, state):
prepare_expected_withdrawals(spec, state, num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4) prepare_expected_withdrawals(spec, state, rng=random.Random(42),
num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 4)
next_slot(spec, state) next_slot(spec, state)
execution_payload = build_empty_execution_payload(spec, state) execution_payload = build_empty_execution_payload(spec, state)

View File

@ -1,3 +1,4 @@
import random
from eth2spec.test.helpers.constants import MINIMAL from eth2spec.test.helpers.constants import MINIMAL
from eth2spec.test.helpers.forks import is_post_electra from eth2spec.test.helpers.forks import is_post_electra
from eth2spec.test.context import ( from eth2spec.test.context import (
@ -268,7 +269,8 @@ def test_many_partial_withdrawals_in_epoch_transition(spec, state):
def _perform_valid_withdrawal(spec, state): def _perform_valid_withdrawal(spec, state):
fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals( fully_withdrawable_indices, partial_withdrawals_indices = prepare_expected_withdrawals(
spec, state, num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 2, spec, state, rng=random.Random(42),
num_partial_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 2,
num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 2) num_full_withdrawals=spec.MAX_WITHDRAWALS_PER_PAYLOAD * 2)
next_slot(spec, state) next_slot(spec, state)

View File

@ -1,4 +1,3 @@
import random
from eth2spec.test.helpers.forks import is_post_electra from eth2spec.test.helpers.forks import is_post_electra
@ -48,8 +47,8 @@ def set_validator_partially_withdrawable(spec, state, index, excess_balance=1000
assert spec.is_partially_withdrawable_validator(validator, state.balances[index]) assert spec.is_partially_withdrawable_validator(validator, state.balances[index])
def prepare_expected_withdrawals(spec, state, def prepare_expected_withdrawals(spec, state, rng,
num_full_withdrawals=0, num_partial_withdrawals=0, rng=random.Random(5566)): num_full_withdrawals=0, num_partial_withdrawals=0):
bound = min(len(state.validators), spec.MAX_VALIDATORS_PER_WITHDRAWALS_SWEEP) bound = min(len(state.validators), spec.MAX_VALIDATORS_PER_WITHDRAWALS_SWEEP)
assert num_full_withdrawals + num_partial_withdrawals <= bound assert num_full_withdrawals + num_partial_withdrawals <= bound
eligible_validator_indices = list(range(bound)) eligible_validator_indices = list(range(bound))