-
Notifications
You must be signed in to change notification settings - Fork 2
/
Makefile
66 lines (53 loc) · 1.86 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
.PHONY: help clean clean-pyc clean-build list test test-all coverage docs release sdist
help:
@echo "clean-build - remove build artifacts"
@echo "clean-pyc - remove Python file artifacts"
@echo "lint - check style with flake8"
@echo "test - run tests quickly with the default Python"
@echo "test-all - run tests on every Python version with tox"
@echo "coverage - check code coverage quickly with the default Python"
@echo "docs - generate Sphinx HTML documentation, including API docs"
@echo "release - package and upload a release"
@echo "sdist - package"
@echo "upgrade-all - upgrades all python packages to the latest version"
clean: clean-build clean-pyc
clean-build:
rm -fr build/
rm -fr dist/
rm -fr *.egg-info
clean-pyc:
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
lint:
flake8 PyTM test
covtest:
py.test --cov-report json --cov
test: covtest
sed -i "s/coverage-[0-9]\+%25/coverage-$(shell jq -r .totals.percent_covered_display coverage.json)%25/g" README.rst
rm -rf coverage.json
coverage:
coverage run --source PyTM setup.py test
coverage report -m
coverage html
sensible-browser 'htmlcov/index.html'
docs:
rm -f docs/modules.rst
sphinx-apidoc -o docs/ PyTM
$(MAKE) -C docs clean
$(MAKE) -C docs html
rm -f docs/PyTM.rst
rm -f docs/PyTM.commands.rst
rm -f docs/PyTM.core.rst
rm -f docs/modules.rst
sensible-browser 'docs/_build/html/index.html'
release: clean
python setup.py sdist
twine upload --verbose dist/*
sdist: clean
python setup.py sdist
ls -l dist
upgrade-all:
sed -i 's/==/>=/g' requirements.txt
python -m pip install -r requirements.txt --upgrade
python -m pip freeze > requirements.txt