This repository has been archived by the owner on Mar 1, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
164 lines (125 loc) · 5.57 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
.PHONY: clean clean-test clean-pyc clean-build docs test help typecheck quality
.DEFAULT_GOAL := default
define BROWSER_PYSCRIPT
import os, webbrowser, sys
from urllib.request import pathname2url
webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
endef
export BROWSER_PYSCRIPT
define PRINT_HELP_PYSCRIPT
import re, sys
for line in sys.stdin:
match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
if match:
target, help = match.groups()
print("%-20s %s" % (target, help))
endef
export PRINT_HELP_PYSCRIPT
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
default: quicktypecheck clean-coverage test coverage clean-mypy typecheck typecoverage quality ## run default typechecking, tests and quality
# Does not support coverage reporting and may be unreliable - 'dmypy
# restart' should clear things up if so.
#
quicktypecheck: ## Use dmypy for cached mypy runs.
@dmypy run --timeout 300 *.py tests op_env
# https://app.circleci.com/pipelines/github/apiology/cookiecutter-pypackage/281/workflows/b85985a9-16d0-42c4-93d4-f965a111e090/jobs/366
typecheck: ## run mypy against project
mypy --cobertura-xml-report typecover --html-report typecover op_env
mypy tests
citypecheck: typecheck ## Run type check from CircleCI
typecoverage: typecheck ## Run type checking and then ratchet coverage in metrics/mypy_high_water_mark
@python setup.py mypy_ratchet
clean-mypy: ## Clean out mypy previous results to avoid flaky results
@rm -fr .mypy_cache
citypecoverage: typecoverage ## Run type checking, ratchet coverage, and then complain if ratchet needs to be committed
@echo "Looking for un-checked-in type coverage metrics..."
@git status --porcelain metrics/mypy_high_water_mark
@test -z "$$(git status --porcelain metrics/mypy_high_water_mark)"
clean: clean-build clean-pyc clean-test clean-mypy clean-coverage ## remove all build, test, coverage and Python artifacts
clean-build: ## remove build artifacts
rm -fr build/
rm -fr dist/
rm -fr .eggs/
find . -name '*.egg-info' -exec rm -fr {} +
find . -name '*.egg' -exec rm -f {} +
clean-pyc: ## remove Python file artifacts
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
find . -name '__pycache__' -exec rm -fr {} +
clean-test: ## remove test and coverage artifacts
rm -fr .tox/
rm -f .coverage
rm -fr htmlcov/
rm -fr .pytest_cache
requirements_dev.txt.installed: requirements_dev.txt setup.py
pip install --disable-pip-version-check -r requirements_dev.txt -e .
touch requirements_dev.txt.installed
pip_install: requirements_dev.txt.installed ## Install Python dependencies
# bundle install doesn't get run here so that we can catch it below in
# fresh-checkout and fresh-rbenv cases
Gemfile.lock: Gemfile
# Ensure any Gemfile.lock changes ensure a bundle is installed.
Gemfile.lock.installed: Gemfile.lock
bundle install
touch Gemfile.lock.installed
bundle_install: Gemfile.lock.installed ## Install Ruby dependencies
lint: ## check style with flake8
flake8 op_env tests
test-reports:
mkdir test-reports
citest: test-reports test ## Run unit tests from CircleCI
test: ## run tests quickly with the default Python
@coverage run --source op_env -m pytest
test-all: ## run tests on every Python version with tox
tox
overcommit: ## run precommit quality checks
bundle exec overcommit --run
quality: overcommit ## run precommit quality checks
clean-coverage: ## Clean out previous output of test coverage to avoid flaky results from previous runs
@rm -fr .coverage
coverage: test ## check code coverage and then ratchet coverage in metrics/coverage_high_water_mark
@coverage report -m
@coverage html --directory=cover
@coverage xml
@python setup.py coverage_ratchet
cicoverage: coverage ## check code coverage, ratchet coverage, and then complain if ratchet needs to be committed
@echo "Looking for un-checked-in unit test coverage metrics..."
@git status --porcelain metrics/coverage_high_water_mark
@test -z "$$(git status --porcelain metrics/coverage_high_water_mark)"
docs: ## generate Sphinx HTML documentation, including API docs
rm -f docs/op_env.rst
rm -f docs/modules.rst
sphinx-apidoc -o docs/ op_env
$(MAKE) -C docs clean
$(MAKE) -C docs html
$(BROWSER) docs/_build/html/index.html
servedocs: docs ## compile the docs watching for changes
watchmedo shell-command -p '*.rst' -c '$(MAKE) -C docs html' -R -D .
release: dist ## package and upload a release
set -e; \
new_version=$$(python3 setup.py --version); \
twine upload -u __token__ -p $$(with-op op item get 'PyPI - test' --fields api_key) dist/op-env-$${new_version:?}.tar.gz -r testpypi; \
twine upload -u __token__ -p $$(with-op op item get 'PyPI' --fields api_key) dist/op-env-$${new_version:?}.tar.gz -r pypi
dist: clean ## builds source and wheel package
python setup.py sdist
python setup.py bdist_wheel
ls -l dist
install: clean ## install the package to the active Python's site-packages
python setup.py install
update_from_cookiecutter: ## Bring in changes from template project used to create this repo
bundle exec overcommit --uninstall
IN_COOKIECUTTER_PROJECT_UPGRADER=1 cookiecutter_project_upgrader || true
git checkout cookiecutter-template && git push && git checkout main
git checkout main && git pull && git checkout -b update-from-cookiecutter-$$(date +%Y-%m-%d-%H%M)
git merge cookiecutter-template || true
bundle exec overcommit --install
@echo
@echo "Please resolve any merge conflicts below and push up a PR with:"
@echo
@echo ' gh pr create --title "Update from cookiecutter" --body "Automated PR to update from cookiecutter boilerplate"'
@echo
@echo
repl:
python3