Clean up the CI workflow, enable web3.py tests

This commit is contained in:
Hsiao-Wei Wang 2020-08-18 00:10:28 +08:00
parent cd22036c53
commit 377b2e3f83
No known key found for this signature in database
GPG Key ID: 95B070122902DEA4
4 changed files with 46 additions and 92 deletions

View File

@ -44,32 +44,19 @@ commands:
venv_name: v22-pyspec
reqs_checksum: cache-{{ checksum "setup.py" }}
venv_path: ./venv
restore_deposit_contract_compiler_cached_venv:
description: "Restore the venv from cache for the deposit contract compiler"
steps:
- restore_cached_venv:
venv_name: v23-deposit-contract-compiler
reqs_checksum: cache-{{ checksum "deposit_contract/compiler/requirements.txt" }}
save_deposit_contract_compiler_cached_venv:
description: "Save the venv to cache for later use of the deposit contract compiler"
steps:
- save_cached_venv:
venv_name: v23-deposit-contract-compiler
reqs_checksum: cache-{{ checksum "deposit_contract/compiler/requirements.txt" }}
venv_path: ./deposit_contract/compiler/venv
restore_deposit_contract_tester_cached_venv:
description: "Restore the venv from cache for the deposit contract tester"
steps:
- restore_cached_venv:
venv_name: v22-deposit-contract-tester
reqs_checksum: cache-{{ checksum "setup.py" }}-{{ checksum "deposit_contract/tester/requirements.txt" }}
venv_name: v23-deposit-contract-tester
reqs_checksum: cache-{{ checksum "setup.py" }}-{{ checksum "solidity_deposit_contract/web3_tester/requirements.txt" }}
save_deposit_contract_tester_cached_venv:
description: "Save the venv to cache for later use of the deposit contract tester"
steps:
- save_cached_venv:
venv_name: v22-deposit-contract-tester
reqs_checksum: cache-{{ checksum "setup.py" }}-{{ checksum "deposit_contract/tester/requirements.txt" }}
venv_path: ./deposit_contract/tester/venv
venv_name: v23-deposit-contract-tester
reqs_checksum: cache-{{ checksum "setup.py" }}-{{ checksum "solidity_deposit_contract/web3_tester/requirements.txt" }}
venv_path: ./solidity_deposit_contract/web3_tester/venv
jobs:
checkout_specs:
docker:
@ -145,53 +132,6 @@ jobs:
- run:
name: Run linter
command: make lint
# install_deposit_contract_compiler:
# docker:
# # The deposit contract compiler is pinned to python 3.7 because of the vyper version pin.
# - image: circleci/python:3.7
# working_directory: ~/specs-repo
# steps:
# - restore_cache:
# key: v3-specs-repo-{{ .Branch }}-{{ .Revision }}
# - restore_deposit_contract_compiler_cached_venv
# - run:
# name: Install deposit contract compiler requirements
# command: make install_deposit_contract_compiler
# - save_deposit_contract_compiler_cached_venv
# install_deposit_contract_tester:
# docker:
# - image: circleci/python:3.8
# working_directory: ~/specs-repo
# steps:
# - restore_cache:
# key: v3-specs-repo-{{ .Branch }}-{{ .Revision }}
# - restore_deposit_contract_tester_cached_venv
# - run:
# name: Install deposit contract tester requirements
# command: make install_deposit_contract_tester
# - save_deposit_contract_tester_cached_venv
# test_compile_deposit_contract:
# docker:
# - image: circleci/python:3.7
# working_directory: ~/specs-repo
# steps:
# - restore_cache:
# key: v3-specs-repo-{{ .Branch }}-{{ .Revision }}
# - restore_deposit_contract_compiler_cached_venv
# - run:
# name: Run deposit contract compile test
# command: make test_compile_deposit_contract
# test_deposit_contract:
# docker:
# - image: circleci/python:3.8
# working_directory: ~/specs-repo
# steps:
# - restore_cache:
# key: v3-specs-repo-{{ .Branch }}-{{ .Revision }}
# - restore_deposit_contract_tester_cached_venv
# - run:
# name: Run deposit contract test
# command: make test_deposit_contract
build_deposit_contract:
docker:
- image: ethereum/solc:0.6.11-alpine
@ -234,6 +174,29 @@ jobs:
key: nix-store-test-v2
paths:
- /nix
install_deposit_contract_web3_tester:
docker:
- image: circleci/python:3.8
working_directory: ~/specs-repo
steps:
- restore_cache:
key: v3-specs-repo-{{ .Branch }}-{{ .Revision }}
- restore_deposit_contract_tester_cached_venv
- run:
name: Install deposit contract tester requirements
command: make install_deposit_contract_web3_tester
- save_deposit_contract_tester_cached_venv
test_deposit_contract_web3_tests:
docker:
- image: circleci/python:3.8
working_directory: ~/specs-repo
steps:
- restore_cache:
key: v3-specs-repo-{{ .Branch }}-{{ .Revision }}
- restore_deposit_contract_tester_cached_venv
- run:
name: Run deposit contract test with web3.py
command: make test_deposit_contract_web3_tests
workflows:
version: 2.1
test_spec:
@ -250,18 +213,12 @@ workflows:
- lint:
requires:
- test
# - install_deposit_contract_compiler:
# requires:
# - checkout_specs
# - test_compile_deposit_contract:
# requires:
# - install_deposit_contract_compiler
# - install_deposit_contract_tester:
# requires:
# - checkout_specs
# - test_deposit_contract:
# requires:
# - install_deposit_contract_tester
- install_deposit_contract_web3_tester:
requires:
- checkout_specs
- test_deposit_contract_web3_tests:
requires:
- install_deposit_contract_web3_tester
build_and_test_deposit_contract:
jobs:
- build_deposit_contract

View File

@ -5,10 +5,10 @@ PY_SPEC_DIR = $(TEST_LIBS_DIR)/pyspec
TEST_VECTOR_DIR = ../eth2.0-spec-tests/tests
GENERATOR_DIR = ./tests/generators
DEPOSIT_CONTRACT_COMPILER_DIR = ./deposit_contract/compiler
DEPOSIT_CONTRACT_TESTER_DIR = ./deposit_contract/tester
SOLIDITY_DEPOSIT_CONTRACT_DIR = ./solidity_deposit_contract
SOLIDITY_DEPOSIT_CONTRACT_SOURCE = ${SOLIDITY_DEPOSIT_CONTRACT_DIR}/deposit_contract.sol
SOLIDITY_FILE_NAME = deposit_contract.json
DEPOSIT_CONTRACT_TESTER_DIR = ${SOLIDITY_DEPOSIT_CONTRACT_DIR}/web3_tester
CONFIGS_DIR = ./configs
# Collect a list of generator names
@ -115,15 +115,6 @@ lint: pyspec
flake8 --config $(LINTER_CONFIG_FILE) ./eth2spec \
&& mypy --config-file $(LINTER_CONFIG_FILE) -p eth2spec.phase0 -p eth2spec.phase1
# install_deposit_contract_tester:
# cd $(DEPOSIT_CONTRACT_TESTER_DIR); python3 -m venv venv; . venv/bin/activate; pip3 install -r requirements.txt
test_deposit_contract:
dapp test -v --fuzz-runs 5
# install_deposit_contract_compiler:
# cd $(DEPOSIT_CONTRACT_COMPILER_DIR); python3.7 -m venv venv; . venv/bin/activate; pip3.7 install -r requirements.txt
compile_deposit_contract:
@cd $(SOLIDITY_DEPOSIT_CONTRACT_DIR)
@git submodule update --recursive --init
@ -134,9 +125,15 @@ compile_deposit_contract:
@cat build/DepositContract.bin >> $(SOLIDITY_FILE_NAME)
@/bin/echo -n '"}' >> $(SOLIDITY_FILE_NAME)
# test_compile_deposit_contract:
# cd $(DEPOSIT_CONTRACT_COMPILER_DIR); . venv/bin/activate; \
# python3.7 -m pytest .
test_deposit_contract:
dapp test -v --fuzz-runs 5
install_deposit_contract_web3_tester:
cd $(DEPOSIT_CONTRACT_TESTER_DIR); python3 -m venv venv; . venv/bin/activate; pip3 install -r requirements.txt
test_deposit_contract_web3_tests:
cd $(DEPOSIT_CONTRACT_TESTER_DIR); . venv/bin/activate; \
python -m pytest .
# Runs a generator, identified by param 1
define run_generator

View File

@ -15,7 +15,7 @@ DIR = os.path.dirname(__file__)
def get_deposit_contract_json():
file_path = os.path.join(DIR, '../../contracts/validator_registration.json')
file_path = os.path.join(DIR, '../../deposit_contract.json')
deposit_contract_json = open(file_path).read()
return json.loads(deposit_contract_json)

View File

@ -6,7 +6,7 @@ from eth2spec.phase0.spec import DepositData
from eth2spec.utils.ssz.ssz_typing import List
from eth2spec.utils.ssz.ssz_impl import hash_tree_root
from deposit_contract.conftest import (
from tests.conftest import (
FULL_DEPOSIT_AMOUNT,
MIN_DEPOSIT_AMOUNT,
)