.PHONY: tests EF_TESTS = "tests/ef_tests" # Builds the entire workspace in release (optimized). # # Binaries will most likely be found in `./target/release` install: cargo install --path lighthouse --force --locked # Runs the full workspace tests in **release**, without downloading any additional # test vectors. test-release: cargo test --all --release --exclude ef_tests # Runs the full workspace tests in **debug**, without downloading any additional test # vectors. test-debug: cargo test --all --exclude ef_tests # Runs cargo-fmt (linter). cargo-fmt: cargo fmt --all -- --check # Typechecks benchmark code check-benches: cargo check --all --benches # Runs only the ef-test vectors. run-ef-tests: cargo test --release --manifest-path=$(EF_TESTS)/Cargo.toml --features "ef_tests" cargo test --release --manifest-path=$(EF_TESTS)/Cargo.toml --features "ef_tests,fake_crypto" # Downloads and runs the EF test vectors. test-ef: make-ef-tests run-ef-tests # Runs the full workspace tests in release, without downloading any additional # test vectors. test: test-release # Runs the entire test suite, downloading test vectors if required. test-full: cargo-fmt test-release test-debug test-ef # Lints the code for bad style and potentially unsafe arithmetic using Clippy. # Clippy lints are opt-in per-crate for now, which is why we allow all by default. lint: cargo clippy --all -- -A clippy::all # Runs the makefile in the `ef_tests` repo. # # May download and extract an archive of test vectors from the ethereum # repositories. At the time of writing, this was several hundred MB of # downloads which extracts into several GB of test vectors. make-ef-tests: make -C $(EF_TESTS) # Performs a `cargo` clean and cleans the `ef_tests` directory. clean: cargo clean make -C $(EF_TESTS) clean