-
-
Notifications
You must be signed in to change notification settings - Fork 8
/
Makefile
75 lines (61 loc) · 2.39 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
.PHONY: help venv conda docker docstyle format style black test lint check coverage docs
.DEFAULT_GOAL = help
PYTHON = python
PIP = pip
CONDA = conda
SHELL = bash
help:
@printf "Usage:\n"
@grep -E '^[a-zA-Z_-]+:.*?# .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?# "}; {printf "\033[1;34mmake %-10s\033[0m%s\n", $$1, $$2}'
conda: # Set up a conda environment for development.
@printf "Creating conda environment...\n"
${CONDA} create --yes --name symbolic-pymc-env python=3.6
( \
${CONDA} activate symbolic-pymc-env; \
${PIP} install -U pip; \
${PIP} install -r requirements.txt; \
${PIP} install -r requirements-dev.txt; \
${CONDA} deactivate; \
)
@printf "\n\nConda environment created! \033[1;34mRun \`conda activate symbolic-pymc-env\` to activate it.\033[0m\n\n\n"
venv: # Set up a Python virtual environment for development.
@printf "Creating Python virtual environment...\n"
rm -rf symbolic-pymc-venv
${PYTHON} -m venv symbolic-pymc-venv
( \
source symbolic-pymc-venv/bin/activate; \
${PIP} install -U pip; \
${PIP} install -r requirements.txt; \
${PIP} install -r requirements-dev.txt; \
deactivate; \
)
@printf "\n\nVirtual environment created! \033[1;34mRun \`source pymc-symbolic-venv/bin/activate\` to activate it.\033[0m\n\n\n"
docker: # Set up a Docker image for development.
@printf "Creating Docker image...\n"
${SHELL} ./scripts/container.sh --build
docstyle:
@printf "Checking documentation with pydocstyle...\n"
pydocstyle symbolic_pymc/
@printf "\033[1;34mPydocstyle passes!\033[0m\n\n"
format:
@printf "Checking code style with black...\n"
black --check symbolic_pymc/ tests/
@printf "\033[1;34mBlack passes!\033[0m\n\n"
style:
@printf "Checking code style with pylint...\n"
pylint symbolic_pymc/ tests/
@printf "\033[1;34mPylint passes!\033[0m\n\n"
black: # Format code in-place using black.
black symbolic_pymc/ tests/
test: # Test code using pytest.
pytest -v tests/ --cov=symbolic_pymc/ --cov-report=xml --html=testing-report.html --self-contained-html
coverage: test
diff-cover coverage.xml --compare-branch=master --fail-under=100
docs:
pushd docs && \
sphinx-apidoc ../symbolic_pymc/ -o source --force && \
make html && \
ghp-import -n -p -r upstream -b gh-pages build/html && \
popd
lint: docstyle format style # Lint code using pydocstyle, black and pylint.
check: lint test coverage # Both lint and test code. Runs `make lint` followed by `make test`.