-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathMakefile
67 lines (55 loc) · 2.09 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
# BuildKit is a next generation container image builder. You can enable it using
# an environment variable or using the Engine config, see:
# https://docs.docker.com/develop/develop-images/build_enhancements/#to-enable-buildkit-builds
export DOCKER_BUILDKIT=1
GIT_TAG?=$(shell git describe --tags --match "v[0-9]*" 2> /dev/null)
ifeq ($(GIT_TAG),)
GIT_TAG=edge
endif
# Docker image tagging:
HUB_USER?=${USER}
# When you create your secret use the DockerHub in the name and this will find it
HUB_PULL_SECRET?=$(shell docker secret list | grep arn | grep DockerHub | cut -f1 -d' ')
REPO?=$(shell basename ${PWD})
TAG?=${GIT_TAG}
DEV_IMAGE?=${REPO}:latest
PROD_IMAGE?=${HUB_USER}/${REPO}:${TAG}
# Local development happens here!
# This starts your application and bind mounts the source into the container so
# that changes are reflected in real time.
# Once you see the message "Running on http://0.0.0.0:5000/", open a Web browser at
# http://localhost:5000
.PHONY: dev
all: dev
dev:
@COMPOSE_DOCKER_CLI_BUILD=1 docker-compose -f docker-compose.dev.yml up --build
# Run the unit tests.
.PHONY: build-test unit-test test
unit-test:
@docker --context default build --progress plain --target test ./app
test: unit-test
# Build a production image for the application.
.PHONY: build
build:
@docker --context default build --target prod --tag ${PROD_IMAGE} ./app
# Push the production image to a registry.
.PHONY: push
push: build
@docker --context default push ${PROD_IMAGE}
# Run the production image either via compose or run
.PHONY: deploy run
deploy: build push check-env
HUB_PULL_SECRET=${HUB_PULL_SECRET} PROD_IMAGE=${PROD_IMAGE} docker compose up
run: build
@docker --context default run -d -p 5000:5000 ${PROD_IMAGE}
# Remove the dev container, dev image, test image, and clear the builder cache.
.PHONY: clean
clean:
@docker-compose -f docker-compose.dev.yml down
@docker rmi ${DEV_IMAGE} || true
@docker builder prune --force --filter type=exec.cachemount --filter=unused-for=24h
.PHONY: check-env
check-env:
ifndef HUB_PULL_SECRET
$(error HUB_PULL_SECRET is undefined. Use docker ecs secret ls to find the ARN)
endif