-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
110 lines (86 loc) · 2.9 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
# isort . && black . && bandit -r . && pylint && pre-commit run --all-files
# Get changed files
FILES := $(wildcard **/*.py)
# if you wrap everything in poetry run, it runs slower.
ifeq ($(origin VIRTUAL_ENV),undefined)
VENV := poetry run
else
VENV :=
endif
poetry.lock: pyproject.toml
@echo "Installing dependencies"
@poetry install --with dev
clean-pyc:
@echo "Removing compiled files"
# @find . -name '*.pyc' -exec rm -f {} + || true
# @find . -name '*.pyo' -exec rm -f {} + || true
# @find . -name '__pycache__' -exec rm -fr {} + || true
clean-test:
@echo "Removing coverage data"
@rm -f .coverage || true
@rm -f .coverage.* || true
clean: clean-pyc clean-test
# tests can't be expected to pass if dependencies aren't installed.
# tests are often slow and linting is fast, so run tests on linted code.
test: clean .build_history/pylint .build_history/bandit poetry.lock
@echo "Running unit tests"
# $(VENV) pytest so_pip --doctest-modules # needs one test or it fails
# $(VENV) python -m unittest discover
$(VENV) py.test test/test_fast --cov=so_pip --cov-report=html --cov-fail-under 25
.build_history:
@mkdir -p .build_history
.build_history/isort: .build_history $(FILES)
@echo "Formatting imports"
$(VENV) isort so_pip
@touch .build_history/isort
.PHONY: isort
isort: .build_history/isort
.build_history/black: .build_history .build_history/isort $(FILES)
@echo "Formatting code"
$(VENV) black so_pip test docs --exclude .virtualenv --exclude .tox --exclude .venv
@touch .build_history/black
.PHONY: black
black: .build_history/black
.build_history/pre-commit: .build_history .build_history/isort .build_history/black
@echo "Pre-commit checks"
$(VENV) pre-commit run --all-files
@touch .build_history/pre-commit
.PHONY: pre-commit
pre-commit: .build_history/pre-commit
.build_history/bandit: .build_history $(FILES)
@echo "Security checks"
$(VENV) bandit .
@touch .build_history/bandit
.PHONY: bandit
bandit: .build_history/bandit
.PHONY: pylint
.build_history/pylint: .build_history .build_history/isort .build_history/black $(FILES)
@echo "Linting with pylint"
$(VENV) pylint so_pip --fail-under 9.9 --rcfile .config/.pylintrc
@touch .build_history/pylint
# for when using -j (jobs, run in parallel)
.NOTPARALLEL: .build_history/isort .build_history/black
.build_history/mypy: .build_history $(FILES)
@echo "Mypy checks"
$(VENV) mypy so_pip
@touch .build_history/mypy
.PHONY: mypy
mypy: .build_history/mypy
deploy:
rm -rf dist
poetry version patch
poetry build
pipx uninstall so_pip
pipx install dist/so_pip-*.whl --force
check: test pylint bandit pre-commit mypy
.PHONY: publish
publish: check
rm -rf dist && poetry build
# Use github to publish
#.PHONY: publish
#publish_test:
# rm -rf dist && poetry version minor && poetry build && twine upload -r testpypi dist/*
#
#.PHONY: publish
#publish: test
# echo "rm -rf dist && poetry version minor && poetry build && twine upload dist/*"