-
Notifications
You must be signed in to change notification settings - Fork 9
/
Makefile
224 lines (192 loc) · 7.29 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
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
# Makefile to automate recurring tasks in package development
#
# Usage
# - A make tool like GNU Make can run targets defined in this file.
# It has to be invoked on the command line in the directory that the Makefile is located.
# - General: make <target>
# - Example: make help
#
# References
# - GNU Make
# - https://www.gnu.org/software/make
# - Style checking
# - isort: https://github.com/timothycrosley/isort
# - Flake8: http://flake8.pycqa.org (uses pycodestyle, pyflakes and mccabe)
# - Pylint: https://www.pylint.org
# - pydocstyle: http://www.pydocstyle.org
# - URL checking
# - urlchecker: https://github.com/urlstechie/urlchecker-python
# - Testing
# - pytest: https://docs.pytest.org
# - pytest-cov: https://github.com/pytest-dev/pytest-cov
# - pytest-timeout: https://bitbucket.org/pytest-dev/pytest-timeout
# - tox: https://tox.readthedocs.io
PKG_NAME := gravis
PKG_ABBREVIATION := gv
PKG_DIR := $(PKG_NAME)
DOC_DIR := docs
EXAMPLES_DIR := examples
TEST_DIR := tests
.DEFAULT: help
.PHONY: help
help:
@echo "--------------------------------------------------------------------------------------------"
@echo
@echo "How to use this Makefile with a make tool like GNU Make"
@echo
@echo " Help"
@echo " make help show this help message"
@echo
@echo " Installation"
@echo " make install install the package with pip from this folder"
@echo " make install-edit install the package with pip in editable mode for development"
@echo " make install-dev install development tools and the package in editable mode"
@echo " make uninstall uninstall the package"
@echo
@echo " Usage"
@echo " make run launch a Python shell and import the installed package"
@echo " make run-ipython launch an IPython shell and import the installed package"
@echo
@echo " Development"
@echo ' make clean delete everything that can be generated, including "docs/build"'
@echo ' make docs generate HTML docs with sphinx from "docs/source" to "docs/build"'
@echo " make style-isort stylecheck with isort (check import order)"
@echo " make style-flake8 stylecheck with flake8 (check basic code conventions)"
@echo " make style-pylint stylecheck with pylint (detailed code analysis)"
@echo " make style-docs stylecheck with pydocstyle (check docstring conventions)"
@echo " make test-unit run unit and integration tests with pytest"
@echo " make test-system run system tests in virtual environments with tox"
@echo " make todo check for TODO comments in source code with pylint"
@echo " make urls check if all URLs in code and docs lead to a server response"
@echo
@echo " Deployment"
@echo " make package Create two distribution packages for upload to TestPyPI or PyPI"
@echo " 1. A source distribution (sdist)"
@echo " 2. A built distribution in form of a wheel (bdist_wheel)"
@echo " make upload-test Upload distribution packages (source & built) with twine to TestPyPI"
@echo " make upload-pypi Upload distribution packages (source & built) with twine to PyPI"
@echo
@echo "--------------------------------------------------------------------------------------------"
# Installation
.PHONY: install
install:
pip install .
.PHONY: install-edit
install-edit:
pip install -e .
.PHONY: install-dev
install-dev:
@echo "The following installation assumes an active conda environment with Python 3.7 (for pyntacle) on an Ubuntu system."
@echo
# Graph libraries
conda install -y -c bfxcss -c conda-forge pyntacle
conda install -y -c conda-forge graph-tool igraph networkit networkx notebook
pip install snap-stanford
# Selenium for static exports (requires manual installation of firefox, chrome and their corresponding webdrivers)
pip install selenium
# Linting
pip install isort flake8 pylint pydocstyle
# Testing
pip install pytest pytest-cov pytest-timeout tox
# Documentation generation
# - NLTK for example with linguistic graph
# - sphinx_rtd_theme==0.4.3 to ensure manually modified theme.js fits to rest
pip install nltk sphinx "sphinx_rtd_theme==0.5.1" tornado jupyter nbsphinx urlchecker
# Upload to PyPI
pip install twine
# Package in editable form
pip install -e .
.PHONY: uninstall
uninstall:
pip uninstall -y $(PKG_DIR)
# Usage
.PHONY: run
run:
python -i -c "import $(PKG_NAME) as $(PKG_ABBREVIATION)"
.PHONY: run-ipython
run-ipython:
ipython -i -c "import $(PKG_NAME) as $(PKG_ABBREVIATION)"
# Development
.PHONY: clean
clean:
# Directories
-@rm -rf docs/build
-@rm -rf tests/out* tests/htmlcov tests/.coverage*
-@rm -rf tox_results.json .tox
-@rm -rf build dist
-@rm -f examples/graph2.*
-@find . -type d \
\( \
-name "__pycache__" \
-or -name "*.egg-info" \
-or -name ".cache" \
-or -name ".pytest_cache" \
-or -name "dask-worker-space" \
-or -name ".ipynb_checkpoints" \
\) \
-exec rm -rf {} \; 2> /dev/null || true
# Files
-@find . \( -name '*.pyc' -or -name '*.pyd' -or -name '*.pyo' -or -name '*~' \) \
-exec rm --force {} + 2> /dev/null || true
@echo "Deleted all unnecessary files and directories."
.PHONY: docs
docs:
@cd docs; \
rm -rf build; \
make html
.PHONY: style-isort
style-isort:
isort --lines-after-imports 2 --diff $(PKG_DIR) $(TEST_DIR)
.PHONY: style-flake8
style-flake8:
flake8 $(PKG_DIR) $(TEST_DIR)
.PHONY: style-pylint
style-pylint:
pylint $(PKG_DIR) $(TEST_DIR) --disable=W0511
.PHONY: style-docs
style-docs:
pydocstyle $(PKG_DIR)
.PHONY: test-unit
test-unit: clean
@cd tests; \
rm -rf dask-worker-space output htmlcov .coverage*; \
pytest --timeout=120 --cov=$(PKG_NAME) --cov-report html
.PHONY: test-system
test-system: clean
tox --recreate --result-json tox_results.json
@echo
@echo "Results of system test with tox can be found in tox_results.json"
.PHONY: todo
todo:
pylint $(PKG_DIR) $(TEST_DIR) --disable=all --enable=W0511
.PHONY: urls
urls:
-urlchecker check $(PKG_DIR) --file-types .ipynb,.md,.py,.rst,.txt --white-listed-urls http://127.0.0.1
-urlchecker check $(TEST_DIR) --file-types .ipynb,.md,.py,.rst,.txt --white-listed-urls http://127.0.0.1
-urlchecker check $(DOC_DIR) --file-types .ipynb,.md,.py,.rst,.txt --white-listed-urls http://127.0.0.1
# Deployment
.PHONY: package
package: clean
-@rm -rf build dist
python3 setup.py sdist bdist_wheel
@echo
@echo 'Two distribution packages (source and built) can now be found in directory "dist".'
-@rm -rf build
.PHONY: upload-testpypi
upload-testpypi:
@echo 'Uploading the distribution packages (source and built) from directory "dist" with twine to TestPyPI.'
@echo
@echo "Suggested manual checks afterwards:"
@echo "- Is the upload available at https://test.pypi.org/project/$(PKG_NAME)"
@echo "- Can it be installed with: pip install --index-url https://test.pypi.org/simple --extra-index-url https://pypi.python.org/pypi $(PKG_NAME)"
@echo
twine upload --repository-url https://test.pypi.org/legacy/ dist/*
.PHONY: upload-pypi
upload-pypi:
@echo 'Uploading the distribution packages (source and built) from directory "dist" with twine to PyPI.'
@echo
@echo "Suggested manual checks afterwards:"
@echo "- Is the upload available at https://pypi.org/project/$(PKG_NAME)"
@echo "- Can it be installed with: pip install $(PKG_NAME)"
@echo
twine upload dist/*