-
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Makefile
85 lines (65 loc) · 2.68 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
PYTHON_BINARY := python3
VIRTUAL_ENV := venv
VIRTUAL_BIN := $(VIRTUAL_ENV)/bin
PROJECT_NAME := dizqueTV
TEST_DIR := tests
## help - Display help about make targets for this Makefile
help:
@cat Makefile | grep '^## ' --color=never | cut -c4- | sed -e "`printf 's/ - /\t- /;'`" | column -s "`printf '\t'`" -t
## build - Builds the project in preparation for release
build:
$(VIRTUAL_BIN)/python setup.py sdist bdist_wheel
## clean - Remove the virtual environment and clear out .pyc files
clean:
rm -rf $(VIRTUAL_ENV) dist/ build/ *.egg-info/ .pytest_cache .mypy_cache
find . -name '*.pyc' -delete
## coverage - Test the project and generate an HTML coverage report
coverage:
$(VIRTUAL_BIN)/pytest --cov=$(PROJECT_NAME) --cov-branch --cov-report=html --cov-report=term-missing
## black - Runs the Black Python formatter against the project
black:
$(VIRTUAL_BIN)/black $(PROJECT_NAME)/ $(TEST_DIR)/
## black-check - Checks if the project is formatted correctly against the Black rules
black-check:
$(VIRTUAL_BIN)/black $(PROJECT_NAME)/ $(TEST_DIR)/ --check
## build-docs - Build the project documentation
build-docs:
$(VIRTUAL_BIN)/sphinx-build -b html -d docs/build/doctrees docs/source docs/build/html
## format - Runs all formatting tools against the project
format: black isort
## format-check - Checks if the project is formatted correctly against all formatting rules
format-check: black-check isort-check lint mypy
## hooks - Run pre-commit hooks against the project
hooks:
$(VIRTUAL_BIN)/pre-commit run --all-files
## install - Install the project locally
install:
$(PYTHON_BINARY) -m venv $(VIRTUAL_ENV)
$(VIRTUAL_BIN)/pip install -r requirements.txt
$(VIRTUAL_BIN)/pip install -r dev_requirements.txt
## isort - Sorts imports throughout the project
isort:
$(VIRTUAL_BIN)/isort $(PROJECT_NAME)/ $(TEST_DIR)/
## isort-check - Checks that imports throughout the project are sorted correctly
isort-check:
$(VIRTUAL_BIN)/isort $(PROJECT_NAME)/ $(TEST_DIR)/ --check-only
## lint - Lint the project
lint:
$(VIRTUAL_BIN)/flake8 $(PROJECT_NAME)/ $(TEST_DIR)/
## mypy - Run mypy type checking on the project
mypy:
$(VIRTUAL_BIN)/mypy $(PROJECT_NAME)/ $(TEST_DIR)/
## publish - Publish the project to PyPI
publish:
$(VIRTUAL_BIN)/twine upload dist/*
## release - Cuts a release for the project on GitHub (requires GitHub CLI)
# tag = The associated tag title of the release
release:
gh release create ${tag} dist/*
## scan - Scans the project for security issues with Bandit
scan:
$(VIRTUAL_BIN)/bandit -r $(PROJECT_NAME)
## test - Test the project
test:
$(VIRTUAL_BIN)/pytest
.PHONY: help build clean coverage black black-check format format-check install isort isort-check lint mypy publish release scan test