forked from databrickslabs/dbx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
232 lines (192 loc) · 7.42 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
221
222
223
224
225
226
227
228
229
230
231
232
##############################################################################
# NOTE: Make sure you have `pyenv` installed beforehand
# https://github.com/pyenv/pyenv
#
# On a Mac: $ brew install pyenv
##############################################################################
# Make file tutorials: https://makefiletutorial.com/#getting-started
##############################################################################
# Default shell that make will use.
SHELL=/bin/bash
##############################################################################
PYTHON_VERSION=3.8.13
VENV_NAME := $(shell [ -d venv ] && echo venv || echo .venv)
VENV_DIR=${VENV_NAME}
PYTHON=${VENV_DIR}/bin/python
RSTCHECK=${VENV_DIR}/bin/rstcheck
SPHINX_AUTOBUILD=${VENV_DIR}/bin/sphinx-autobuild
SPHINX_BUILD=${VENV_DIR}/bin/sphinx-build
##############################################################################
##############################################################################
# Terminal Colors:
# to see all colors, run
# bash -c 'for c in {0..255}; do tput setaf $c; tput setaf $c | cat -v; echo =$c; done'
# the first 15 entries are the 8-bit colors
# define standard colors
ifneq (,$(findstring xterm,${TERM}))
BOLD := $(shell tput -Txterm bold)
UNDERLINE := $(shell tput -Txterm smul)
STANDOUT := $(shell tput -Txterm smso)
BLACK := $(shell tput -Txterm setaf 0)
RED := $(shell tput -Txterm setaf 1)
GREEN := $(shell tput -Txterm setaf 2)
YELLOW := $(shell tput -Txterm setaf 3)
BLUE := $(shell tput -Txterm setaf 4)
PURPLE := $(shell tput -Txterm setaf 5)
CYAN := $(shell tput -Txterm setaf 6)
WHITE := $(shell tput -Txterm setaf 7)
NORMAL := $(shell tput -Txterm sgr0)
else
BOLD := ""
UNDERLINE := ""
STANDOUT := ""
BLACK := ""
RED := ""
GREEN := ""
YELLOW := ""
BLUE := ""
PURPLE := ""
CYAN := ""
WHITE := ""
NORMAL := ""
endif
##############################################################################
# Makefile TARGETS:
##############################################################################
.PHONY: help helper-line clean venv install install-e install-dev post-install-info lint check fix test test-with-html-report docs docs-serve build
.DEFAULT_GOAL := help
##############################################################################
# Auto document targets by adding comment next to target name
# starting with double pound and space like "## doc text"
##############################################################################
helper-line:
@echo "${BOLD}${BLUE}--------------------------------------------------${NORMAL}"
help: ## Show help documentation.
@make helper-line
@echo "${BOLD}${BLUE}Here are all the targets available with make command.${NORMAL}"
@make helper-line
@echo ""
@echo "Start by running ${YELLOW}'make clean install'${NORMAL}"
@echo ""
@grep -E '^[a-zA-Z_0-9%-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf " ${YELLOW}%-30s${NORMAL} %s\n", $$1, $$2}'
##############################################################################
clean: ## Clean .venv, dist, build
@echo ""
@echo "${YELLOW}Removing virtual environment ${NORMAL}"
@make helper-line
-rm .python-version
@echo ""
@echo "${YELLOW}Remove temp files${NORMAL}"
@make helper-line
-rm -rf $(VENV_DIR)
-rm -rf dist/*
-rm -rf build/*
-rm -rf dbx.egg-info/*
@echo ""
@echo "${YELLOW}Current python:${NORMAL}"
@make helper-line
@python --version
@make docs-clean
##############################################################################
# This chaining exists so that the virtual env target will not be invoked multiple times.
# This config works because there is a file at this path "$(VENV_NAME)/bin/activate"
# Once that file is created, it will not be change unless you run "make clean".
# If the file did not change, then the target below with same name will be skipped.
venv: $(VENV_NAME)/bin/activate
$(VENV_NAME)/bin/activate:
@echo ""
@echo "${YELLOW}Init pyenv${NORMAL}"
@make helper-line
pyenv install -s ${PYTHON_VERSION}
pyenv local ${PYTHON_VERSION}
@echo ""
@echo "${YELLOW}Current python:${NORMAL}"
@make helper-line
@python --version
@echo ""
@echo "${YELLOW}Init venv in ${VENV_DIR}${NORMAL}"
@make helper-line
test -d $(VENV_NAME) || python -m venv $(VENV_NAME)
@echo ""
@echo "${YELLOW}Using ${PYTHON}${NORMAL}"
@make helper-line
$(PYTHON) --version
$(PYTHON) -m pip install --upgrade pip
##############################################################################
install: venv install-e install-dev post-install-info ## >>> MAIN TARGET. Run this to start. <<<
install-e: ## Install project as editable.
@echo ""
@echo "${YELLOW}Install project as editable${NORMAL}"
@make helper-line
$(PYTHON) -m pip install -e .
install-dev: ## Install dev dependencies.
@echo ""
@echo "${YELLOW}Install Dev dependencies.${NORMAL}"
@make helper-line
$(PYTHON) -m pip install -e ".[dev]"
post-install-info: ## Just some post installation info.
@echo ""
@echo "${YELLOW}Post-Install Info:${NORMAL}"
@make helper-line
@echo "See what other make targets are available by running:"
@echo " ${YELLOW}'make'${NORMAL}"
@echo " ${YELLOW}'make help'${NORMAL}"
@echo ""
@echo "${YELLOW}NOTE${NORMAL}: Most of the time, you should be using the predefined make targets."
@echo ""
@echo "${YELLOW}Optionally${NORMAL}: If you really need to, you can activate the venv in your"
@echo "terminal shell by running: "
@echo " ${YELLOW}'source .venv/bin/activate'${NORMAL}"
@echo ""
@echo "This will put any executable python tools installed above in the PATH, allowing you"
@echo "to run the tools from the shell if you really need to."
@echo " ex: ${YELLOW}'pytest'${NORMAL}"
##############################################################################
lint: ## Run the lint and checks
@echo ""
@echo "${YELLOW}Linting code:${NORMAL}"
@make helper-line
$(PYTHON) -m prospector --profile prospector.yaml
$(RSTCHECK) README.rst
@make check
check: ## Run black checks
@echo ""
@echo "${YELLOW}Check code with black:${NORMAL}"
@make helper-line
$(PYTHON) -m black --check .
fix: ## fix the code with black formatter.
@echo ""
@echo "${YELLOW}Fixing code with black:${NORMAL}"
@make helper-line
$(PYTHON) -m black .
##############################################################################
test: ## Run the tests. (option): file=tests/path/to/file.py
@echo ""
@echo "${YELLOW}Running tests:${NORMAL}"
@make helper-line
$(PYTHON) -m pytest -vv --cov dbx $(file) -n auto \
--cov-report=xml \
--cov-report=term-missing:skip-covered
test-with-html-report: ## Run all tests with html reporter.
@echo ""
@echo "${YELLOW}Testing with html report:${NORMAL}"
@make helper-line
$(PYTHON) -m pytest --cov dbx -n auto --cov-report html -s
##############################################################################
DOCS_SOURCE=./docs/source
DOCS_BUILD=./docs/build
docs-clean: ## Clean the docs build folder
@echo ""
@echo "${YELLOW}Clean ${DOCS_BUILD} folder:${NORMAL}"
@make helper-line
-rm -rf ${DOCS_BUILD}/*
docs-serve: ## sphinx autobuild & serve docs on localhost
mkdocs serve
##############################################################################
build: ## Build the package.
@echo ""
@echo "${YELLOW}Building the project:${NORMAL}"
@make helper-line
rm -rf dist/*
rm -rf build/*
$(PYTHON) setup.py clean bdist_wheel