eth2.0-specs/Makefile

111 lines
4.2 KiB
Makefile
Raw Normal View History

SPEC_DIR = ./specs
SCRIPT_DIR = ./scripts
2019-03-28 00:35:46 +08:00
TEST_LIBS_DIR = ./test_libs
PY_SPEC_DIR = $(TEST_LIBS_DIR)/pyspec
2019-04-20 12:28:50 +10:00
YAML_TEST_DIR = ./eth2.0-spec-tests/tests
2019-03-28 00:35:46 +08:00
GENERATOR_DIR = ./test_generators
DEPOSIT_CONTRACT_DIR = ./deposit_contract
2019-04-11 19:25:00 +10:00
CONFIGS_DIR = ./configs
2019-03-28 00:35:46 +08:00
# Collect a list of generator names
GENERATORS = $(sort $(dir $(wildcard $(GENERATOR_DIR)/*/)))
# Map this list of generator paths to a list of test output paths
YAML_TEST_TARGETS = $(patsubst $(GENERATOR_DIR)/%, $(YAML_TEST_DIR)/%, $(GENERATORS))
GENERATOR_VENVS = $(patsubst $(GENERATOR_DIR)/%, $(GENERATOR_DIR)/%venv, $(GENERATORS))
2019-04-03 14:18:17 +11:00
PY_SPEC_PHASE_0_TARGETS = $(PY_SPEC_DIR)/eth2spec/phase0/spec.py
2019-05-08 23:30:08 +01:00
PY_SPEC_PHASE_0_DEPS = $(SPEC_DIR)/core/0_*.md
2019-05-08 23:41:44 +01:00
PY_SPEC_PHASE_1_TARGETS = $(PY_SPEC_DIR)/eth2spec/phase1/spec.py
2019-05-08 23:30:08 +01:00
PY_SPEC_PHASE_1_DEPS = $(SPEC_DIR)/core/1_*.md
2019-05-09 00:42:59 +01:00
PY_SPEC_ALL_TARGETS = $(PY_SPEC_PHASE_0_TARGETS) $(PY_SPEC_PHASE_1_TARGETS)
.PHONY: clean all test citest gen_yaml_tests pyspec phase0 phase1 install_test
2019-03-28 00:35:46 +08:00
all: $(PY_SPEC_ALL_TARGETS) $(YAML_TEST_DIR) $(YAML_TEST_TARGETS)
clean:
2019-03-28 00:35:46 +08:00
rm -rf $(YAML_TEST_DIR)
2019-03-29 00:05:40 +08:00
rm -rf $(GENERATOR_VENVS)
2019-04-24 11:59:13 -06:00
rm -rf $(PY_SPEC_DIR)/venv $(PY_SPEC_DIR)/.pytest_cache
2019-03-28 00:35:46 +08:00
rm -rf $(PY_SPEC_ALL_TARGETS)
2019-03-29 00:05:40 +08:00
# "make gen_yaml_tests" to run generators
gen_yaml_tests: $(PY_SPEC_ALL_TARGETS) $(YAML_TEST_TARGETS)
# installs the packages to run pyspec tests
install_test:
2019-04-24 11:59:13 -06:00
cd $(PY_SPEC_DIR); python3 -m venv venv; . venv/bin/activate; pip3 install -r requirements-testing.txt;
test: $(PY_SPEC_ALL_TARGETS)
cd $(PY_SPEC_DIR); . venv/bin/activate; python -m pytest eth2spec
citest: $(PY_SPEC_ALL_TARGETS)
2019-05-16 12:51:36 +02:00
cd $(PY_SPEC_DIR); mkdir -p test-reports/eth2spec; . venv/bin/activate; \
2019-05-31 12:44:34 +02:00
python -m pytest --junitxml=test-reports/eth2spec/test_results_phase0.xml eth2spec
2019-05-09 13:11:07 +08:00
2019-05-16 16:34:07 +08:00
lint: $(PY_SPEC_ALL_TARGETS)
2019-05-09 13:11:07 +08:00
cd $(PY_SPEC_DIR); . venv/bin/activate; \
2019-06-05 15:29:26 +02:00
flake8 --ignore=E252,W504,W503 --max-line-length=120 ./eth2spec;
2019-05-09 13:11:07 +08:00
2019-05-30 13:26:36 +08:00
compile_deposit_contract:
cd $(PY_SPEC_DIR); python3 -m venv venv; . venv/bin/activate; \
cd ../..; cd $(DEPOSIT_CONTRACT_DIR); \
python tool/compile_deposit_contract.py contracts/validator_registration.v.py;
install_deposit_contract_test:
cd $(PY_SPEC_DIR); python3 -m venv venv; . venv/bin/activate; \
cd ../..; cd $(DEPOSIT_CONTRACT_DIR); \
pip3 install -r requirements-testing.txt
test_deposit_contract: $(PY_SPEC_ALL_TARGETS)
cd $(PY_SPEC_DIR); python3 -m venv venv; . venv/bin/activate; \
2019-05-27 18:48:40 +08:00
cd ../.. && cd $(DEPOSIT_CONTRACT_DIR); \
pip3 install -r requirements-testing.txt; \
python -m pytest .
2019-03-28 00:35:46 +08:00
# "make pyspec" to create the pyspec for all phases.
pyspec: $(PY_SPEC_ALL_TARGETS)
2019-03-18 16:30:16 -06:00
2019-05-16 16:36:35 +02:00
$(PY_SPEC_PHASE_0_TARGETS): $(PY_SPEC_PHASE_0_DEPS)
python3 $(SCRIPT_DIR)/build_spec.py -p0 $(SPEC_DIR)/core/0_beacon-chain.md $@
2019-03-28 00:35:46 +08:00
2019-05-08 23:41:44 +01:00
$(PY_SPEC_DIR)/eth2spec/phase1/spec.py: $(PY_SPEC_PHASE_1_DEPS)
2019-05-26 14:14:48 +02:00
python3 $(SCRIPT_DIR)/build_spec.py -p1 $(SPEC_DIR)/core/0_beacon-chain.md $(SPEC_DIR)/core/1_custody-game.md $(SPEC_DIR)/core/1_shard-data-chains.md $@
2019-03-28 00:35:46 +08:00
2019-03-29 00:05:40 +08:00
CURRENT_DIR = ${CURDIR}
2019-03-28 00:35:46 +08:00
# The function that builds a set of suite files, by calling a generator for the given type (param 1)
define build_yaml_tests
# Started!
# Create output directory
# Navigate to the generator
# Create a virtual environment, if it does not exist already
# Activate the venv, this is where dependencies are installed for the generator
# Install all the necessary requirements
# Run the generator. The generator is assumed to have an "main.py" file.
# We output to the tests dir (generator program should accept a "-o <filepath>" argument.
echo "generator $(1) started"; \
mkdir -p $(YAML_TEST_DIR)$(1); \
cd $(GENERATOR_DIR)$(1); \
if ! test -d venv; then python3 -m venv venv; fi; \
. venv/bin/activate; \
pip3 install -r requirements.txt; \
python3 main.py -o $(CURRENT_DIR)/$(YAML_TEST_DIR)$(1) -c $(CURRENT_DIR)/$(CONFIGS_DIR); \
echo "generator $(1) finished"
2019-03-28 00:35:46 +08:00
endef
# The tests dir itself is simply build by creating the directory (recursively creating deeper directories if necessary)
$(YAML_TEST_DIR):
2019-03-29 00:05:40 +08:00
$(info creating directory, to output yaml targets to: ${YAML_TEST_TARGETS})
2019-03-28 00:35:46 +08:00
mkdir -p $@
$(YAML_TEST_DIR)/:
$(info ignoring duplicate yaml tests dir)
2019-03-28 00:35:46 +08:00
# For any target within the tests dir, build it using the build_yaml_tests function.
2019-03-29 00:24:18 +08:00
# (creation of output dir is a dependency)
$(YAML_TEST_DIR)%: $(PY_SPEC_ALL_TARGETS) $(YAML_TEST_DIR)
2019-03-28 00:35:46 +08:00
$(call build_yaml_tests,$*)