-
Notifications
You must be signed in to change notification settings - Fork 128
/
Copy pathMakefile
110 lines (87 loc) · 2.8 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
PROJECT_PACKAGE := machina
TEST_PACKAGE := tests
init:
poetry install
# DEVELOPMENT
# ~~~~~~~~~~~
# The following rules can be used during development in order to compile staticfiles, generate
# locales, build documentation, etc.
# --------------------------------------------------------------------------------------------------
.PHONY: c console
## Alias of "console".
c: console
## Launch a development console.
console:
poetry run ipython
## Generates assets packaged with django-machina.
staticfiles:
npm run gulp
## Generate the project's .po files.
messages:
cd machina && poetry run python -m django makemessages --no-wrap --no-location -a
## Compiles the project's .po files.
compiledmessages:
cd machina && poetry run python -m django compilemessages
.PHONY: docs
## Builds the documentation.
docs:
cd docs && rm -rf _build && poetry run make html
# QUALITY ASSURANCE
# ~~~~~~~~~~~~~~~~~
# The following rules can be used to check code quality, import sorting, etc.
# --------------------------------------------------------------------------------------------------
.PHONY: qa
## Trigger all quality assurance checks.
qa: lint isort
.PHONY: lint
## Trigger Python code quality checks (flake8).
lint:
poetry run flake8
.PHONY: isort
## Check Python imports sorting.
isort:
poetry run isort --check-only --diff $(PROJECT_PACKAGE) $(TEST_PACKAGE)
# TESTING
# ~~~~~~~
# The following rules can be used to trigger tests execution and produce coverage reports.
# --------------------------------------------------------------------------------------------------
.PHONY: t tests
## Alias of "tests".
t: tests
## Run the Python test suite.
tests:
poetry run py.test
.PHONY: coverage
## Collects code coverage data.
coverage:
poetry run py.test --cov-report term-missing --cov $(PROJECT_PACKAGE)
.PHONY: spec
## Run the tests in "spec" mode.
spec:
poetry run py.test --spec -p no:sugar
# MAKEFILE HELPERS
# ~~~~~~~~~~~~~~~~
# The following rules can be used to list available commands and to display help messages.
# --------------------------------------------------------------------------------------------------
# COLORS
GREEN := $(shell tput -Txterm setaf 2)
YELLOW := $(shell tput -Txterm setaf 3)
WHITE := $(shell tput -Txterm setaf 7)
RESET := $(shell tput -Txterm sgr0)
.PHONY: help
## Print Makefile help.
help:
@echo ''
@echo 'Usage:'
@echo ' ${YELLOW}make${RESET} ${GREEN}<action>${RESET}'
@echo ''
@echo 'Actions:'
@awk '/^[a-zA-Z\-\_0-9]+:/ { \
helpMessage = match(lastLine, /^## (.*)/); \
if (helpMessage) { \
helpCommand = substr($$1, 0, index($$1, ":")-1); \
helpMessage = substr(lastLine, RSTART + 3, RLENGTH); \
printf " ${YELLOW}%-$(TARGET_MAX_CHAR_NUM)-30s${RESET}\t${GREEN}%s${RESET}\n", helpCommand, helpMessage; \
} \
} \
{ lastLine = $$0 }' $(MAKEFILE_LIST) | sort -t'|' -sk1,1