-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
144 lines (111 loc) · 4 KB
/
Makefile
File metadata and controls
144 lines (111 loc) · 4 KB
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
FLAKE8_FORMAT ?= '$${cyan}%(path)s$${reset}:$${yellow_bold}%(row)d$${reset}:$${green_bold}%(col)d$${reset}: $${red_bold}%(code)s$${reset} %(text)s'
PYLINT_FORMAT ?= colorized
# This needs to go before we fiddle with paths.
SYSTEM_PYTHON := $(shell which python2.7)
#ifdef VIRTUAL_ENV
#$(error This Makefile cannot be run from inside a virtualenv)
#endif
VIRTUAL_ENV := $(abspath .virtualenv)
export VIRTUAL_ENV
PATH := $(abspath .virtualenv/bin):$(PATH)
export PATH
PYTHONPATH := $(abspath app):$(PYTHONPATH)
export PYTHONPATH
PIP := $(VIRTUAL_ENV)/bin/pip
TESTS ?= tests
NOSETESTS := $(VIRTUAL_ENV)/bin/nosetests
TOX := $(VIRTUAL_ENV)/bin/tox
FLAKE8 := $(VIRTUAL_ENV)/bin/flake8
PYLINT := $(VIRTUAL_ENV)/bin/pylint
VULTURE := $(VIRTUAL_ENV)/bin/vulture
RADON := $(VIRTUAL_ENV)/bin/radon
SPHINX_APIDOC := $(VIRTUAL_ENV)/bin/sphinx-apidoc
TESTS_ABS := $(foreach path,$(TESTS),$(abspath $(path)))
# The virtualenv is supposed to mirror what will already be present on
# app-engine. It also contains test dependencies.
.virtualenv:
# Building python virtual environment
$(SYSTEM_PYTHON) -m virtualenv -p $(SYSTEM_PYTHON) .virtualenv
$(PIP) install --upgrade pip
$(PIP) install --upgrade -r requirements/requirements.txt
$(PIP) install --upgrade -r requirements/requirements-dev.txt
$(PIP) install --upgrade -r requirements/requirements-test.txt
# Update the last modified date on .virtualenv so that, if nothing has
# changed, make knows not to rebuild it next time it runs.
touch .virtualenv
.PHONY: build
build: .virtualenv
.PHONY: clean clean-test clean-pyc clean-build docs help
.DEFAULT_GOAL := help
define BROWSER_PYSCRIPT
import os, webbrowser, sys
try:
from urllib import pathname2url
except:
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
BROWSER := python -c "$$BROWSER_PYSCRIPT"
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
clean: clean-build clean-pyc clean-test ## 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/
lint: ## check style with flake8
$(FLAKE8) amargan setup.py
$(PYLINT) amargan setup.py
test: ## run tests quickly with the default Python
$(NOSETESTS) $(TESTS_ABS) -v --logging-level=INFO \
--processes=-1 --process-timeout=240
test-all: ## run tests on every Python version with tox
tox
coverage: ## check code coverage quickly with the default Python
$(NOSETESTS) $(TESTS_ABS) -v --logging-level=INFO \
--processes=-1 --process-timeout=240 \
--with-coverage --cover-erase \
--cover-package=amargan \
--cover-html --cover-branches
coverage report -m
coverage html
$(BROWSER) htmlcov/index.html
docs: ## generate Sphinx HTML documentation, including API docs
rm -f docs/amargan.rst
rm -f docs/modules.rst
$(SPHINX_APIDOC) -o docs/amargan . setup.py
$(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: clean ## package and upload a release
python setup.py sdist upload
python setup.py bdist_wheel upload
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