-
Notifications
You must be signed in to change notification settings - Fork 24
/
Makefile
107 lines (91 loc) · 4.16 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
.PHONY: help install docs format check test check-and-test
LIB_NAME = gpflux
TESTS_NAME = tests
ARCHS_NAME = experiments
LINT_NAMES = $(LIB_NAME) $(TESTS_NAME) docs/notebooks
TYPE_NAMES = $(LIB_NAME)
SUCCESS='\033[0;32m'
UNAME_S = $(shell uname -s)
PANDOC_DEB = https://github.com/jgm/pandoc/releases/download/2.10.1/pandoc-2.10.1-1-amd64.deb
# the --per-file-ignores are to ignore "unused import" warnings in __init__.py files (F401)
# the F403 ignore in gpflux/__init__.py allows the `from .<submodule> import *`
LINT_FILE_IGNORES = "$(LIB_NAME)/__init__.py:F401,F403 \
$(LIB_NAME)/architectures/__init__.py:F401 \
$(LIB_NAME)/encoders/__init__.py:F401 \
$(LIB_NAME)/experiment_support/__init__.py:F401 \
$(LIB_NAME)/initializers/__init__.py:F401 \
$(LIB_NAME)/layers/__init__.py:F401 \
$(LIB_NAME)/layers/basis_functions/__init__.py:F401 \
$(LIB_NAME)/models/__init__.py:F401 \
$(LIB_NAME)/optimization/__init__.py:F401 \
$(LIB_NAME)/sampling/__init__.py:F401 \
$(LIB_NAME)/utils/__init__.py:F401"
# Older Python versions use separate test requirements files
ifeq ("$(VERSION_PYTHON)", "3.7")
TEST_REQUIREMENTS = "tests_requirements_37.txt"
else ifeq ($(filter $(VERSION_PYTHON),3.8 3.9),$(VERSION_PYTHON))
TEST_REQUIREMENTS = "tests_requirements_38_39.txt"
else
TEST_REQUIREMENTS = "tests_requirements.txt"
endif
help: ## Shows this help message
# $(MAKEFILE_LIST) is set by make itself; the following parses the `target: ## help line` format and adds color highlighting
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-24s\033[0m %s\n", $$1, $$2}'
install: ## Install repo for developement
@echo "\n=== pip install package with dev requirements =============="
pip install --upgrade --upgrade-strategy eager \
-r notebook_requirements.txt \
-r $(TEST_REQUIREMENTS) \
tensorflow${VERSION_TF} \
keras${VERSION_KERAS} \
tensorflow-probability${VERSION_TFP} \
-e .
docs: ## Build the documentation
@echo "\n=== pip install doc requirements =============="
pip install -r docs/docs_requirements.txt
@echo "\n=== install pandoc =============="
ifeq ("$(UNAME_S)", "Linux")
$(eval TEMP_DEB=$(shell mktemp))
@echo "Checking for pandoc installation..."
@(which pandoc) || ( echo "\nPandoc not found." \
&& echo "Trying to install automatically...\n" \
&& wget -O "$(TEMP_DEB)" $(PANDOC_DEB) \
&& echo "\nInstalling pandoc using dpkg -i from $(PANDOC_DEB)" \
&& echo "(If this step does not work, manually install pandoc, see http://pandoc.org/)\n" \
&& sudo dpkg -i "$(TEMP_DEB)" \
)
@rm -f "$(TEMP_DEB)"
endif
ifeq ($(UNAME_S),Darwin)
brew install pandoc
endif
@echo "\n=== build docs =============="
(cd docs ; make html)
@echo "\n${SUCCESS}=== Docs are available at docs/_build/html/index.html ============== ${SUCCESS}"
format: ## Formats code with `black` and `isort`
@echo "\n=== isort =============================================="
isort .
@echo "\n=== black =============================================="
black --line-length=100 $(LINT_NAMES)
check: ## Runs all static checks such as code formatting checks, linting, mypy
@echo "\n=== black (formatting) ================================="
black --check --line-length=100 $(LINT_NAMES)
@echo "\n=== flake8 (linting)===================================="
flake8 --statistics \
--per-file-ignores=$(LINT_FILE_IGNORES) \
--exclude=.ipynb_checkpoints ./gpflux
@echo "\n=== mypy (static type checking) ========================"
mypy $(TYPE_NAMES)
test: ## Run unit and integration tests with pytest
pytest --cov=$(LIB_NAME) \
--cov-report html:cover_html \
--cov-config .coveragerc \
--cov-report term \
--cov-report xml \
--cov-fail-under=94 \
--junitxml=reports/junit.xml \
-v --tb=short --durations=10 \
$(TESTS_NAME)
quicktest: ## Run the tests, start with the failing ones and break on first fail.
pytest -vv -x --ff -rN -Wignore -s
check-and-test: check test ## Run pytest and static tests