-
Notifications
You must be signed in to change notification settings - Fork 12
/
Makefile
107 lines (81 loc) · 2.95 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
# black openmock && bandit -r openmock && pylint openmock && 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 "Skipping clean, too slow"
# @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) py.test tests --cov=openmock --cov-report=html --cov-fail-under 50
.build_history:
@mkdir -p .build_history
.build_history/black: .build_history $(FILES)
@echo "Formatting code"
$(VENV) black .
@touch .build_history/black
.PHONY: black
black: .build_history/black
.build_history/pre-commit: .build_history .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 openmock -r
@touch .build_history/bandit
.PHONY: bandit
bandit: .build_history/bandit
.PHONY: pylint
.build_history/pylint: .build_history .build_history/black $(FILES)
@echo "Linting with pylint"
$(VENV) pylint openmock --fail-under 10
@touch .build_history/pylint
# for when using -j (jobs, run in parallel)
.NOTPARALLEL: .build_history/black
check: test pylint bandit pre-commit
.PHONY: build
build: check
rm -rf dist && poetry build
#.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/*"
check_docs:
$(VENV) interrogate openmock --verbose
$(VENV) pydoctest --config .pydoctest.json | grep -v "__init__" | grep -v "__main__" | grep -v "Unable to parse"
make_docs:
pdoc openmock --html -o docs --force
check_md:
$(VENV) mdformat README.md docs/*.md
# $(VENV) linkcheckMarkdown README.md # it is attempting to validate ssl certs
$(VENV) markdownlint README.md --config .markdownlintrc
check_spelling:
$(VENV) pylint openmock --enable C0402 --rcfile=.pylintrc_spell
$(VENV) codespell README.md --ignore-words=private_dictionary.txt
$(VENV) codespell openmock --ignore-words=private_dictionary.txt
check_changelog:
$(VENV) changelogmanager validate