# Makefile to help automate key steps .DEFAULT_GOAL := help # Will likely fail on Windows, but Makefiles are in general not Windows # compatible so we're not too worried TEMP_FILE := $(shell mktemp) # A helper script to get short descriptions of each target in the Makefile define PRINT_HELP_PYSCRIPT import re, sys for line in sys.stdin: match = re.match(r'^([\$$\(\)a-zA-Z_-]+):.*?## (.*)$$', line) if match: target, help = match.groups() print("%-30s %s" % (target, help)) endef export PRINT_HELP_PYSCRIPT .PHONY: help help: ## print short description of each target @python3 -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST) .PHONY: checks checks: ## run all the linting checks of the codebase @echo "=== pre-commit ==="; poetry run pre-commit run --all-files || echo "--- pre-commit failed ---" >&2; \ echo "=== mypy ==="; MYPYPATH=stubs poetry run mypy src || echo "--- mypy failed ---" >&2; \ echo "======" .PHONY: ruff-fixes ruff-fixes: ## fix the code using ruff # format before and after checking so that the formatted stuff is checked and # the fixed stuff is formatted poetry run ruff format src tests scripts docs/source/conf.py docs/source/notebooks/*.py poetry run ruff src tests scripts docs/source/conf.py docs/source/notebooks/*.py --fix poetry run ruff format src tests scripts docs/source/conf.py docs/source/notebooks/*.py .PHONY: test test: ## run the tests poetry run pytest src tests -r a -v --doctest-modules --cov=src # Note on code coverage and testing: # You must specify cov=src as otherwise funny things happen when doctests are # involved. # If you want to debug what is going on with coverage, we have found # that adding COVERAGE_DEBUG=trace to the front of the below command # can be very helpful as it shows you if coverage is tracking the coverage # of all of the expected files or not. # We are sure that the coverage maintainers would appreciate a PR that improves # the coverage handling when there are doctests and a `src` layout like ours. .PHONY: docs docs: ## build the docs poetry run sphinx-build -T -b html docs/source docs/build/html .PHONY: changelog-draft changelog-draft: ## compile a draft of the next changelog poetry run towncrier build --draft .PHONY: licence-check licence-check: ## Check that licences of the dependencies are suitable # Will likely fail on Windows, but Makefiles are in general not Windows # compatible so we're not too worried poetry export --without=tests --without=docs --without=dev > $(TEMP_FILE) poetry run liccheck -r $(TEMP_FILE) -R licence-check.txt rm -f $(TEMP_FILE) .PHONY: virtual-environment virtual-environment: ## update virtual environment, create a new one if it doesn't already exist # Ensure that the lock file is up to date, # but don't update dependencies in the process # see https://python-poetry.org/docs/cli/#lock poetry lock --no-update # Put virtual environments in the project poetry config virtualenvs.in-project true poetry install --all-extras poetry run pre-commit install