-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathMakefile
220 lines (175 loc) · 7.84 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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
# Autodocumented Makefile
# see: https://marmelab.com/blog/2016/02/29/auto-documented-makefile.html
#
# Dependencies : python3 venv internal module
# Recall: .PHONY defines special targets not associated with files
#
# Some Makefile global variables can be set in make command line:
# PANDORA2D_VENV: Change directory of installed venv (default local "venv" dir)
#
############### GLOBAL VARIABLES ######################
.DEFAULT_GOAL := help
# Set shell to BASH
SHELL := /bin/bash
# Set Virtualenv directory name
# Example: PANDORA2D_VENV="other-venv/" make install
ifndef PANDORA2D_VENV
PANDORA2D_VENV = "venv"
endif
# Check python3 globally
PYTHON=$(shell command -v python3)
ifeq (, $(PYTHON))
$(error "PYTHON=$(PYTHON) not found in $(PATH)")
endif
# Check Python version supported globally
PYTHON_VERSION_MIN = 3.8
PYTHON_VERSION_CUR=$(shell $(PYTHON) -c 'import sys; print("%d.%d"% sys.version_info[0:2])')
PYTHON_VERSION_OK=$(shell $(PYTHON) -c 'import sys; cur_ver = sys.version_info[0:2]; min_ver = tuple(map(int, "$(PYTHON_VERSION_MIN)".split("."))); print(int(cur_ver >= min_ver))')
ifeq ($(PYTHON_VERSION_OK), 0)
$(error "Requires python version >= $(PYTHON_VERSION_MIN). Current version is $(PYTHON_VERSION_CUR)")
endif
################ MAKE targets by sections ######################
.PHONY: help
help: ## this help
@echo " PANDORA2D MAKE HELP"
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'| sort
## Install section
.PHONY: venv
venv: ## create virtualenv in PANDORA2D_VENV directory if not exists
@test -d ${PANDORA2D_VENV} || python3 -m venv ${PANDORA2D_VENV}
@${PANDORA2D_VENV}/bin/python -m pip install --upgrade pip setuptools wheel # no check to upgrade each time
@touch ${PANDORA2D_VENV}/bin/activate
.PHONY: install
install: venv ## install pandora2D (pip editable mode) without plugins
@test -f ${PANDORA2D_VENV}/bin/pandora2d || ${PANDORA2D_VENV}/bin/pip install -e .[dev,docs,notebook]
@test -f .git/hooks/pre-commit || echo " Install pre-commit hook"
@test -f .git/hooks/pre-commit || ${PANDORA2D_VENV}/bin/pre-commit install
@echo "PANDORA2D installed in dev mode in virtualenv ${PANDORA2D_VENV}"
@echo "PANDORA2D venv usage : source ${PANDORA2D_VENV}/bin/activate; pandora2d -h"
.PHONY: install-plugin
install-plugin: venv ## install pandora2D (pip editable mode) without plugins
@test -f ${PANDORA2D_VENV}/bin/pandora-plugin-mccnn || ${PANDORA2D_VENV}/bin/pip install pandora-plugin-mccnn
@test -f .git/hooks/pre-commit || echo echo " Install pre-commit hook"
@test -f .git/hooks/pre-commit || ${PANDORA2D_VENV}/bin/pre-commit install
@echo "PANDORA2D installed in dev mode in virtualenv ${PANDORA2D_VENV}"
@echo "PANDORA2D venv usage : source ${PANDORA2D_VENV}/bin/activate; pandora2d -h"
## Test section
.PHONY: test
test: install test-unit test-functional ## run unit tests and functional tests
.PHONY: test-all
test-all: install test-unit test-functional test-resource test-performance test-notebook test-plugin ## run all tests
.PHONY: test-unit
test-unit: install ## run unit tests only (for dev) + coverage (source venv before)
@echo "Run unit tests"
@${PANDORA2D_VENV}/bin/pytest -m "unit_tests and not notebook_tests and not plugin_tests" --html=unit-test-report.html --cov-config=.coveragerc --cov-report xml --cov
.PHONY: test-functional
test-functional: install ## run functional tests only (for dev and validation plan)
@echo "Run functional tests"
@${PANDORA2D_VENV}/bin/pytest -m "functional_tests" --html=functional-test-report.html
.PHONY: test-resource
test-resource: install ## run resource tests only (for validation plan)
@echo "Run resource tests"
@rm -f tests/resource_tests/.pymon
@${PANDORA2D_VENV}/bin/pytest -m "resource_tests and not metrics" --db tests/resource_tests/.pymon
@${PANDORA2D_VENV}/bin/pytest tests/resource_tests/test_metrics.py --database tests/resource_tests/.pymon --html=resource-test-report.html
.PHONY: test-performance
test-performance: install ## run performance tests only (for validation plan)
@echo "Run performance tests"
@${PANDORA2D_VENV}/bin/pytest -m "performance_tests" --html=performance-test-report.html
.PHONY: test-notebook
test-notebook: install ## run notebook tests only
@${PANDORA2D_VENV}/bin/pytest -m "notebook_tests" --html=notebook-test-report.html
.PHONY: test-plugin
test-plugin: install-plugin ## run plugins tests only
@${PANDORA2D_VENV}/bin/pytest -m "plugin_tests" --html=plugin-test-report.html
## Code quality, linting section
### Format with black
.PHONY: format
format: install format/black ## run black formatting (depends install)
.PHONY: format/black
format/black: install ## run black formatting (depends install) (source venv before)
@echo "+ $@"
@${PANDORA2D_VENV}/bin/black pandora2d tests ./*.py notebooks/snippets/*.py
### Check code quality and linting : black, mypy, pylint
.PHONY: lint
lint: install lint/black lint/mypy lint/pylint ## check code quality and linting (source venv before)
.PHONY: lint/black
lint/black: ## check global style with black
@echo "+ $@"
@${PANDORA2D_VENV}/bin/black --check pandora2d tests ./*.py notebooks/snippets/*.py
.PHONY: lint/mypy
lint/mypy: ## check linting with mypy
@echo "+ $@"
@${PANDORA2D_VENV}/bin/mypy pandora2d tests
.PHONY: lint/pylint
lint/pylint: ## check linting with pylint
@echo "+ $@"
@set -o pipefail; ${PANDORA2D_VENV}/bin/pylint pandora2d tests ./*.py --rcfile=.pylintrc --output-format=parseable --msg-template="{path}:{line}: [{msg_id}({symbol}), {obj}] {msg}" # | tee pylint-report.txt # pipefail to propagate pylint exit code in bash
## Documentation section
.PHONY: docs
docs: install ## build sphinx documentation (source venv before)
@${PANDORA2D_VENV}/bin/sphinx-build -M clean docs/source/ docs/build
@${PANDORA2D_VENV}/bin/sphinx-build -M html docs/source/ docs/build -W --keep-going
## Notebook section
.PHONY: notebook
notebook: install ## install Jupyter notebook kernel with venv and pandora2D install (source venv before)
@echo "Install Jupyter Kernel in virtualenv dir"
@${PANDORA2D_VENV}/bin/python -m ipykernel install --sys-prefix --name=pandora2D-dev --display-name=pandora2D-dev
@echo "Use jupyter kernelspec list to know where is the kernel"
@echo " --> After PANDORA2D virtualenv activation, please use following command to launch local jupyter notebook to open PANDORA2D Notebooks:"
@echo "jupyter notebook"
## Clean section
.PHONY: clean-notebook-output ## Clean Jupyter notebooks outputs
clean-notebook-output:
@echo "Clean Jupyter notebooks"
jupyter nbconvert --ClearOutputPreprocessor.enabled=True --inplace notebooks/*.ipynb notebooks/advanced_examples/*.ipynb
.PHONY: clean
clean: clean-venv clean-build clean-precommit clean-pyc clean-test clean-doc clean-notebook clean-mypy ## remove all build, test, coverage and Python artifacts
.PHONY: clean-venv
clean-venv:
@echo "+ $@"
@rm -rf ${PANDORA2D_VENV}
.PHONY: clean-build
clean-build:
@echo "+ $@"
@rm -fr build/
@rm -fr .eggs/
@find . -name '*.egg-info' -exec rm -fr {} +
@find . -name '*.egg' -exec rm -f {} +
.PHONY: clean-precommit
clean-precommit:
@rm -f .git/hooks/pre-commit
@rm -f .git/hooks/pre-push
.PHONY: clean-pyc
clean-pyc:
@echo "+ $@"
@find . -type f -name "*.py[co]" -exec rm -fr {} +
@find . -type d -name "__pycache__" -exec rm -fr {} +
@find . -name '*~' -exec rm -fr {} +
.PHONY: clean-test
clean-test:
@echo "+ $@"
@rm -fr .tox/
@rm -f .coverage
@rm -rf .coverage.*
@rm -rf coverage.xml
@rm -fr htmlcov/
@rm -fr .pytest_cache
@rm -f pylint-report.txt
@rm -f debug.log
@rm -f .pymon
@rm -f tests/resource_tests/.pymon
@rm -f *-test-report.html
.PHONY: clean-doc
clean-doc:
@echo "+ $@"
@rm -rf docs/build/
@rm -rf docs/source/api_reference/
.PHONY: clean-notebook
clean-notebook:
@echo "+ $@"
@find . -type d -name ".ipynb_checkpoints" -exec rm -fr {} +
.PHONY: clean-mypy
clean-mypy:
@echo "+ $@"
@rm -rf .mypy_cache/