update block operations generator
This commit is contained in:
parent
a019b03ae0
commit
6b1d4839d8
|
@ -1,25 +1,16 @@
|
||||||
from typing import Iterable
|
from typing import Iterable
|
||||||
|
|
||||||
from eth2spec.test.phase0.block_processing import (
|
from importlib import import_module
|
||||||
test_process_attestation,
|
|
||||||
test_process_attester_slashing,
|
|
||||||
test_process_block_header,
|
|
||||||
test_process_deposit,
|
|
||||||
test_process_proposer_slashing,
|
|
||||||
test_process_voluntary_exit,
|
|
||||||
)
|
|
||||||
|
|
||||||
from gen_base import gen_runner, gen_typing
|
from gen_base import gen_runner, gen_typing
|
||||||
from gen_from_tests.gen import generate_from_tests
|
from gen_from_tests.gen import generate_from_tests
|
||||||
from importlib import reload
|
from importlib import reload
|
||||||
from eth2spec.config import config_util
|
from eth2spec.config import config_util
|
||||||
from eth2spec.phase0 import spec as spec_phase0
|
from eth2spec.phase0 import spec as spec_phase0
|
||||||
from eth2spec.phase1 import spec as spec_phase1
|
from eth2spec.phase1 import spec as spec_phase1
|
||||||
from eth2spec.test.context import PHASE0
|
from eth2spec.test.context import PHASE0, PHASE1
|
||||||
|
|
||||||
|
|
||||||
def create_provider(handler_name: str, tests_src, config_name: str) -> gen_typing.TestProvider:
|
def create_provider(fork_name: str, handler_name: str, tests_src_mod_name: str, config_name: str) -> gen_typing.TestProvider:
|
||||||
|
|
||||||
def prepare_fn(configs_path: str) -> str:
|
def prepare_fn(configs_path: str) -> str:
|
||||||
config_util.prepare_config(configs_path, config_name)
|
config_util.prepare_config(configs_path, config_name)
|
||||||
reload(spec_phase0)
|
reload(spec_phase0)
|
||||||
|
@ -27,28 +18,46 @@ def create_provider(handler_name: str, tests_src, config_name: str) -> gen_typin
|
||||||
return config_name
|
return config_name
|
||||||
|
|
||||||
def cases_fn() -> Iterable[gen_typing.TestCase]:
|
def cases_fn() -> Iterable[gen_typing.TestCase]:
|
||||||
|
tests_src = import_module(tests_src_mod_name)
|
||||||
return generate_from_tests(
|
return generate_from_tests(
|
||||||
runner_name='operations',
|
runner_name='operations',
|
||||||
handler_name=handler_name,
|
handler_name=handler_name,
|
||||||
src=tests_src,
|
src=tests_src,
|
||||||
fork_name=PHASE0,
|
fork_name=fork_name,
|
||||||
)
|
)
|
||||||
|
|
||||||
return gen_typing.TestProvider(prepare=prepare_fn, make_cases=cases_fn)
|
return gen_typing.TestProvider(prepare=prepare_fn, make_cases=cases_fn)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
gen_runner.run_generator("operations", [
|
phase_0_mods = [(key, 'eth2spec.test.phase0.block_processing.test_process_' + key) for key in [
|
||||||
create_provider('attestation', test_process_attestation, 'minimal'),
|
'attestation',
|
||||||
create_provider('attestation', test_process_attestation, 'mainnet'),
|
'attester_slashing',
|
||||||
create_provider('attester_slashing', test_process_attester_slashing, 'minimal'),
|
'block_header',
|
||||||
create_provider('attester_slashing', test_process_attester_slashing, 'mainnet'),
|
'deposit',
|
||||||
create_provider('block_header', test_process_block_header, 'minimal'),
|
'proposer_slashing',
|
||||||
create_provider('block_header', test_process_block_header, 'mainnet'),
|
'voluntary_exit',
|
||||||
create_provider('deposit', test_process_deposit, 'minimal'),
|
]]
|
||||||
create_provider('deposit', test_process_deposit, 'mainnet'),
|
phase_1_mods = [(key, 'eth2spec.test.phase1.block_processing.test_process_' + key) for key in [
|
||||||
create_provider('proposer_slashing', test_process_proposer_slashing, 'minimal'),
|
'attestation',
|
||||||
create_provider('proposer_slashing', test_process_proposer_slashing, 'mainnet'),
|
'chunk_challenge',
|
||||||
create_provider('voluntary_exit', test_process_voluntary_exit, 'minimal'),
|
'custody_key_reveal',
|
||||||
create_provider('voluntary_exit', test_process_voluntary_exit, 'mainnet'),
|
'custody_slashing',
|
||||||
|
'early_derived_secret_reveal',
|
||||||
|
'shard_transition',
|
||||||
|
]] + phase_0_mods # also run the previous phase 0 tests (but against phase 1 spec)
|
||||||
|
|
||||||
|
gen_runner.run_generator(f"phase0/operations", [
|
||||||
|
create_provider(PHASE0, key, mod_name, 'minimal') for key, mod_name in phase_0_mods
|
||||||
])
|
])
|
||||||
|
# TODO: disabled for testing
|
||||||
|
# gen_runner.run_generator(f"phase0/operations", [
|
||||||
|
# create_provider(key, mod_name, 'mainnet') for key, mod_name in phase_0_mods
|
||||||
|
# ])
|
||||||
|
gen_runner.run_generator(f"phase1/operations", [
|
||||||
|
create_provider(PHASE1, key, mod_name, 'minimal') for key, mod_name in phase_1_mods
|
||||||
|
])
|
||||||
|
# Disabled for now
|
||||||
|
# gen_runner.run_generator(f"phase1/operations", [
|
||||||
|
# create_provider(PHASE1, key, mod_name, 'mainnet') for key, mod_name in phase_1_mods
|
||||||
|
# ])
|
||||||
|
|
Loading…
Reference in New Issue