63 lines
2.3 KiB
Python
63 lines
2.3 KiB
Python
from typing import Iterable
|
|
|
|
from gen_base import gen_runner, gen_typing
|
|
from gen_from_tests.gen import generate_from_tests
|
|
from importlib import reload, import_module
|
|
from eth2spec.config import config_util
|
|
from eth2spec.phase0 import spec as spec_phase0
|
|
from eth2spec.phase1 import spec as spec_phase1
|
|
from eth2spec.test.context import PHASE0, PHASE1
|
|
from eth2spec.utils import bls
|
|
|
|
|
|
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:
|
|
config_util.prepare_config(configs_path, config_name)
|
|
reload(spec_phase0)
|
|
reload(spec_phase1)
|
|
bls.use_milagro()
|
|
return config_name
|
|
|
|
def cases_fn() -> Iterable[gen_typing.TestCase]:
|
|
tests_src = import_module(tests_src_mod_name)
|
|
return generate_from_tests(
|
|
runner_name='operations',
|
|
handler_name=handler_name,
|
|
src=tests_src,
|
|
fork_name=fork_name,
|
|
)
|
|
|
|
return gen_typing.TestProvider(prepare=prepare_fn, make_cases=cases_fn)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
phase_0_mods = [(key, 'eth2spec.test.phase0.block_processing.test_process_' + key) for key in [
|
|
'attestation',
|
|
'attester_slashing',
|
|
'block_header',
|
|
'deposit',
|
|
'proposer_slashing',
|
|
'voluntary_exit',
|
|
]]
|
|
phase_1_mods = [(key, 'eth2spec.test.phase1.block_processing.test_process_' + key) for key in [
|
|
'attestation',
|
|
'chunk_challenge',
|
|
'custody_key_reveal',
|
|
'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"operations", [
|
|
create_provider(PHASE0, key, mod_name, 'minimal') for key, mod_name in phase_0_mods
|
|
])
|
|
gen_runner.run_generator(f"operations", [
|
|
create_provider(PHASE0, key, mod_name, 'mainnet') for key, mod_name in phase_0_mods
|
|
])
|
|
gen_runner.run_generator(f"operations", [
|
|
create_provider(PHASE1, key, mod_name, 'minimal') for key, mod_name in phase_1_mods
|
|
])
|
|
gen_runner.run_generator(f"operations", [
|
|
create_provider(PHASE1, key, mod_name, 'mainnet') for key, mod_name in phase_1_mods
|
|
])
|