-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathMakefile
95 lines (75 loc) · 2.67 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
# Makefile for plugin-lib-python
# Copyright (C) 2003-2025 ITRS Group Ltd. All rights reserved
# List special make targets that are not associated with files
.PHONY: help venv3 version verify test tox3 lint doc format clean
# Use bash as shell (Note: Ubuntu now uses dash which doesn't support PIPESTATUS).
SHELL=/bin/bash
# Project name
PROJECT=plugnpy
# Project version
VERSION=$(shell cat VERSION)
# Current directory
CURRENTDIR=$(dir $(realpath $(firstword $(MAKEFILE_LIST))))
# Path to python
PYTHON3_BIN=/opt/opsview/python3/bin/python3
# --- MAKE TARGETS ---
# Display general help about this command
help:
@echo ""
@echo "$(PROJECT) Makefile."
@echo "The following commands are available:"
@echo ""
@echo " make venv3 : Set up development virtual environment"
@echo " make version : Set version from VERSION file"
@echo " make build : Build a Wheel package"
@echo " make verify : Run tests and linting"
@echo " make test : Execute tests in py3 env"
@echo " make lint : Evaluate code"
@echo " make doc : Start a server to display source code documentation"
@echo " make format : Format the source code"
@echo " make clean : Remove any build artifact"
@echo ""
all: help
# Build dev env for python3
venv3: venv3/bin/activate
venv3/bin/activate: requirements.txt setup.py
test -d .venv3 || (${PYTHON3_BIN} -m venv .venv3 \
&& .venv3/bin/pip install -r requirements.txt \
&& .venv3/bin/pip install -e '.[test]' \
&& .venv3/bin/pip install -e '.[examples]')
# Set the version from VERSION file
version:
sed -i "s/__version__.*$$/__version__ = '$(VERSION)'/" plugnpy/__init__.py
# Build a Wheel package
build: clean version venv3
cp LICENSE README.md plugnpy; \
source .venv3/bin/activate ; \
python setup.py sdist bdist_wheel; \
rm plugnpy/LICENSE plugnpy/README.md
# Run tests and linting
verify: lint test
# Test using tox
test: venv3
source .venv3/bin/activate ; \
python -m tox ; \
coverage html
# Run tests on python3
tox3: venv3
source .venv3/bin/activate ; \
python -m tox -e py3
# Evaluate code
lint: venv3
source .venv3/bin/activate ; \
pyflakes ${PROJECT} ; \
pylint ${PROJECT} ; \
pycodestyle --max-line-length=120 ${PROJECT}
# Generate source code documentation
doc:
pydoc -p 1234 $(PROJECT)
# Format the source code
format:
find . -path ./target -prune -o -type f -name '*.py' -exec autopep8 --in-place --max-line-length=240 {} \;
# Remove any build artifact
clean:
rm -rf .venv .venv3 .tox target htmlcov build dist .cache .benchmarks ./test/*.so ./test/__pycache__ ./plugnpy/__pycache__ ./plugnpy.egg-info .pytest_cache .coverage .junit.xml
find . -type f -name '*.pyc' -exec rm -f {} \;