-
-
Notifications
You must be signed in to change notification settings - Fork 25
/
Makefile
67 lines (53 loc) · 3.13 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
.PHONY: c clean \
f format \
h help \
local \
multiarch_image \
publish \
t test \
wheel
h: help
c: clean
f: format
t: test
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'
MODULE_VERSION=$(shell grep '^version' pyproject.toml | cut -d= -f2 | sed s/\"//g | sed s/\ //g)
clean-synology-fuckery: ## Deal with Synology's obsession with adding executable bits everywhere
chmod 600 poetry.lock Docker* LICENSE Makefile *.toml .gitignore .editorconfig .flake8 *.y*ml .*.y*ml .*.json .trivyignore
find . -iname '*.py' -exec chmod 644 '{}' ';'
find . -iname '*.md' -exec chmod 644 '{}' ';'
find . -iname '*.txt' -exec chmod 644 '{}' ';'
find .github -type f -exec chmod 644 '{}' ';'
find tests -type f -exec chmod 644 '{}' ';'
clean: clean-synology-fuckery ## Cleans out stale wheels, generated tar files, .pyc and .pyo files
rm -fv dist/*.tar dist/*.whl
find . -iname '*.py[co]' -delete
format: ## Runs 'ruff' on all our python source files
poetry run ruff check ha_mqtt_discoverable tests
test: ## Run tests with 'nosetests'
nosestests -v
install_hooks: ## Install the git hooks
poetry run pre-commit install
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 unixorn/ha-mqtt-discoverable-test:$(MODULE_VERSION) -f Dockerfile.testing .
docker tag unixorn/ha-mqtt-discoverable-test:$(MODULE_VERSION) unixorn/ha-mqtt-discoverable-test:latest
trial: wheel
docker buildx build --no-cache --build-arg application_version=${MODULE_VERSION} --load -t unixorn/ha-mqtt-discoverable:$(MODULE_VERSION) .
multiarch_image: wheel ## Makes a multi-architecture docker image for linux/arm64, linux/amd64 and linux/arm/v7 and pushes it to dockerhub
docker buildx build --no-cache --build-arg application_version=${MODULE_VERSION} --platform linux/arm64,linux/amd64,linux/arm/v7 --push -t unixorn/ha-mqtt-discoverable .
docker buildx build --build-arg application_version=${MODULE_VERSION} --platform linux/arm64,linux/amd64,linux/arm/v7 --push -t unixorn/ha-mqtt-discoverable:$(MODULE_VERSION) .
docker pull unixorn/ha-mqtt-discoverable
docker pull unixorn/ha-mqtt-discoverable:$(MODULE_VERSION)
wheel: clean format ## Builds a wheel for our modules. 'poetry' bakes the dependencies into the wheel metadata.
poetry build
publish: multiarch_image ## Builds a multi-architecture docker image and publishes the module to pypi
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: 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