-
Notifications
You must be signed in to change notification settings - Fork 2
/
Makefile
139 lines (111 loc) · 3.2 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
.PHONY: \
black \
clean \
clean-build \
clean-pyc \
clean-test \
clean-test-lite \
coverage \
develop \
dist \
docs \
format \
help \
install \
isort \
lint \
mypy \
release \
security \
servedocs \
test \
test-all
.DEFAULT_GOAL := help
define BROWSER_PYSCRIPT
import os, webbrowser, sys
from urllib.request import pathname2url
webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
endef
export BROWSER_PYSCRIPT
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("%-20s %s" % (target, help))
endef
export PRINT_HELP_PYSCRIPT
BROWSER := python -c "$$BROWSER_PYSCRIPT"
black: ## format python with black
black tiramisu_brulee
black tests
clean: clean-build clean-pyc clean-test-lite ## remove all build, test, coverage and Python artifacts
clean-build: ## remove build artifacts
rm -fr build/
rm -fr dist/
rm -fr .eggs/
find . -name '*.egg-info' -exec rm -fr {} +
find . -name '*.egg' -exec rm -f {} +
clean-pyc: ## remove Python file artifacts
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
find . -name '__pycache__' -exec rm -fr {} +
clean-test: clean-test-lite ## remove test and coverage artifacts
rm -fr .tox/
rm -fr .mypy_cache
clean-test-lite: ## remove test artifacts minus tox
rm -fr file:.
rm -fr private
rm -fr tests/private
rm -f .coverage
rm -fr htmlcov/
rm -fr .pytest_cache
rm -fr Users/
rm -fr lightning_logs/
rm -fr mlruns/
coverage: ## check code coverage quickly with the default Python
coverage run --source tiramisu_brulee -m pytest
coverage report -m
coverage html
$(BROWSER) htmlcov/index.html
develop: clean ## install the package to the active Python's site-packages
python setup.py develop
dist: clean ## builds source and wheel package
python setup.py sdist
python setup.py bdist_wheel
ls -l dist
docs: ## generate Sphinx HTML documentation, including API docs
rm -f docs/tiramisu_brulee.*rst
rm -f docs/tiramisu_brulee.rst
rm -f docs/modules.rst
sphinx-apidoc -o docs/ tiramisu_brulee
$(MAKE) -C docs clean
$(MAKE) -C docs html
$(BROWSER) docs/_build/html/index.html
format: black isort mypy lint security ## run various code quality checks and formatters
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
install: clean ## install the package to the active Python's site-packages
python setup.py install
isort: ## format python code with isort
isort tiramisu_brulee
isort tests
lint: ## check style with flake8
flake8 tiramisu_brulee tests
mypy: ## type-check python with mypy
mypy tiramisu_brulee
mypy tests
release: dist ## package and upload a release
twine upload dist/*
security: ## run various security checks on the python code
bandit -r tiramisu_brulee -c pyproject.toml
bandit -r tests -c pyproject.toml
snyk test --file=requirements_dev.txt --package-manager=pip --fail-on=all
servedocs: docs ## compile the docs watching for changes
watchmedo shell-command -p '*.rst' -c '$(MAKE) -C docs html' -R -D .
test: ## run tests quickly with the default Python
pytest
test-all: ## run tests on every Python version with tox
tox