-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
57 lines (45 loc) · 2.92 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
.PHONY: c clean \
f format \
h help \
publish \
wheel
h: help
c: clean
f: format
help:
@echo "Options:"
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
# If this pukes trying to import paho, try running 'poetry install'
# Or on Raspberry PI try export PYTHON_KEYRING_BACKEND=keyring.backends.null.Keyring
MODULE_VERSION=$(shell poetry run python3 -c 'import toml;print(toml.loads(open("pyproject.toml", "r").read())["tool"]["poetry"]["version"])' )
MODULE_USER=aixnpanes
MODULE_NAME=discoverable-garage-door
MODULE_DIR=$(shell echo $(MODULE_NAME) | tr '-' '_')
MODULE_TEST=$(MODULE_NAME)-test
MODULE_TAG=$(shell echo "$(MODULE_NAME)" | tr '-' '_')
MODULE_TAG_LATEST=$(shell echo $(MODULE_NAME) | tr '-' '_')
clean: ## Cleans out stale wheels, generated tar files, .pyc and .pyo files
rm -fv dist/*.tar dist/*.whl
find . -iname '*.py[co]' -delete
format: ## Runs 'black' on all our python source files
poetry run black $(MODULE_DIR)
install_hooks: ## Install the git hooks
poetry run pre-commit install
wheel: clean format ## Builds a wheel for our modules. 'poetry' bakes the dependencies into the wheel metadata.
poetry build
local: wheel requirements.txt ## Makes a docker image for only the architecture we're running on. Does not push to dockerhub.
docker buildx build --load -t $(MODULE_USER)/$(MODULE_TAG):$(MODULE_VERSION) -f Dockerfile.testing .
docker tag $(MODULE_USER)/$(MODULE_TAG):$(MODULE_VERSION) $(MODULE_USER)/$(MODULE_TAG):latest
multiarch_image: wheel ## Makes a multi-architecture docker image for linux/arm64, linux/amd64 and linux/arm/v7 and pushes it to dockerhub, if this fails try docker buildx create --name mybuilder; docker buildx use mybuilder; docker buildx inspect --bootstrap ALSO docker login
docker buildx build --no-cache --build-arg application_version=${MODULE_VERSION} --platform linux/arm64,linux/amd64,linux/arm/v7 --push -t $(MODULE_USER)/$(MODULE_TAG):$(MODULE_VERSION) -t $(MODULE_USER)/$(MODULE_TAG):latest .
make local
publish: ## Publishes the module to pypi --- if this fails use poetry config pypi-token.pypi [token], log in to pypi.org and get an API token
poetry publish
# We use this to enable the Dockerfile.testing have a separate layer for the
# dependencies so we don't have to reinstall every time we test a new change.
# Our wheel includes its dependencies in the metadata so you don't need a
# requirements.txt file to use them
requirements.txt: wheel poetry.lock pyproject.toml Makefile ## Builds a requirements.txt to Dockerfile.testing can cache installing the python dependencies. poetry includes the deps in our wheel metadata, requirements.txt is not needed other than for test images.
poetry export -o requirements.txt
testing: ## Builds a local image for testing
docker buildx build -f Dockerfile.testing . --load -t $(MODULE_USER)/$(MODULE_TAG):$(MODULE_VERSION) -t $(MODULE_USER)/$(MODULE_TAG):latest