-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathMakefile
82 lines (68 loc) · 2.92 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
.PHONY: help install docs format check test check-and-test
LIB_NAME = tsgm
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
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===== install TSGM and requirements ====="
pip install --upgrade --upgrade-strategy eager \
-r requirements/docs_requirements.txt \
-r requirements/tests_requirements.txt \
-r requirements/requirements.txt \
-e .
docs: ## Build the documentation
@echo "\n=== pip install doc requirements =============="
pip install -r requirements/docs_requirements.txt \
-e .
@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 \
--exclude=.ipynb_checkpoints ./tsgm
@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=97 \
--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