Merge pull request #2678 from ethereum/run-specific-fork
Run Pytest with specific phase(s)/fork(s) tests
This commit is contained in:
commit
c08a8c90ce
|
@ -1,4 +1,7 @@
|
||||||
from eth2spec.test import context
|
from eth2spec.test import context
|
||||||
|
from eth2spec.test.helpers.constants import (
|
||||||
|
ALL_PHASES,
|
||||||
|
)
|
||||||
from eth2spec.utils import bls as bls_utils
|
from eth2spec.utils import bls as bls_utils
|
||||||
|
|
||||||
# We import pytest only when it's present, i.e. when we are running tests.
|
# We import pytest only when it's present, i.e. when we are running tests.
|
||||||
|
@ -29,6 +32,13 @@ def pytest_addoption(parser):
|
||||||
"--preset", action="store", type=str, default="minimal",
|
"--preset", action="store", type=str, default="minimal",
|
||||||
help="preset: make the pyspec use the specified preset"
|
help="preset: make the pyspec use the specified preset"
|
||||||
)
|
)
|
||||||
|
parser.addoption(
|
||||||
|
"--fork", action="append", type=str,
|
||||||
|
help=(
|
||||||
|
"fork: make the pyspec only run with the specified phase."
|
||||||
|
" To run multiple phases, e.g., --fork=phase0 --fork=altair"
|
||||||
|
)
|
||||||
|
)
|
||||||
parser.addoption(
|
parser.addoption(
|
||||||
"--disable-bls", action="store_true", default=False,
|
"--disable-bls", action="store_true", default=False,
|
||||||
help="bls-default: make tests that are not dependent on BLS run without BLS"
|
help="bls-default: make tests that are not dependent on BLS run without BLS"
|
||||||
|
@ -44,6 +54,16 @@ def preset(request):
|
||||||
context.DEFAULT_TEST_PRESET = request.config.getoption("--preset")
|
context.DEFAULT_TEST_PRESET = request.config.getoption("--preset")
|
||||||
|
|
||||||
|
|
||||||
|
@fixture(autouse=True)
|
||||||
|
def run_phases(request):
|
||||||
|
phases = request.config.getoption("--fork")
|
||||||
|
if phases:
|
||||||
|
phases = [phase.lower() for phase in phases]
|
||||||
|
context.DEFAULT_PYTEST_FORKS = set(phases)
|
||||||
|
else:
|
||||||
|
context.DEFAULT_PYTEST_FORKS = ALL_PHASES
|
||||||
|
|
||||||
|
|
||||||
@fixture(autouse=True)
|
@fixture(autouse=True)
|
||||||
def bls_default(request):
|
def bls_default(request):
|
||||||
disable_bls = request.config.getoption("--disable-bls")
|
disable_bls = request.config.getoption("--disable-bls")
|
||||||
|
|
|
@ -22,6 +22,9 @@ from lru import LRU
|
||||||
# Without pytest CLI arg or pyspec-test-generator 'preset' argument, this will be the config to apply.
|
# Without pytest CLI arg or pyspec-test-generator 'preset' argument, this will be the config to apply.
|
||||||
DEFAULT_TEST_PRESET = MINIMAL
|
DEFAULT_TEST_PRESET = MINIMAL
|
||||||
|
|
||||||
|
# Without pytest CLI arg or pyspec-test-generator 'run-phase' argument, this will be the config to apply.
|
||||||
|
DEFAULT_PYTEST_FORKS = ALL_PHASES
|
||||||
|
|
||||||
|
|
||||||
# TODO: currently phases are defined as python modules.
|
# TODO: currently phases are defined as python modules.
|
||||||
# It would be better if they would be more well-defined interfaces for stronger typing.
|
# It would be better if they would be more well-defined interfaces for stronger typing.
|
||||||
|
@ -351,7 +354,7 @@ def with_phases(phases, other_phases=None):
|
||||||
"""
|
"""
|
||||||
def decorator(fn):
|
def decorator(fn):
|
||||||
def wrapper(*args, **kw):
|
def wrapper(*args, **kw):
|
||||||
run_phases = phases
|
run_phases = set(phases).intersection(DEFAULT_PYTEST_FORKS)
|
||||||
|
|
||||||
# limit phases if one explicitly specified
|
# limit phases if one explicitly specified
|
||||||
if 'phase' in kw:
|
if 'phase' in kw:
|
||||||
|
|
Loading…
Reference in New Issue