-
Notifications
You must be signed in to change notification settings - Fork 108
/
Makefile
100 lines (83 loc) · 3.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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#!/usr/bin/env bash
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# If you update this file, please follow
# https://suva.sh/posts/well-documented-makefiles
## --------------------------------------
## General
## --------------------------------------
SHELL:=/usr/bin/env bash
.DEFAULT_GOAL:=help
# Use GOPROXY environment variable if set
GOPROXY := $(shell go env GOPROXY)
ifeq ($(GOPROXY),)
GOPROXY := https://proxy.golang.org
endif
export GOPROXY
# Active module mode, as we use go modules to manage dependencies
export GO111MODULE=on
# The help will print out all targets with their descriptions organized below
# their categories. The categories are represented by `##@` and the target
# descriptions by `##`.
#
# The awk commands is responsible to read the entire set of makefiles included
# in this invocation, looking for lines of the file as xyz: ## something, and
# then pretty-format the target and help. Then, if there's a line with ##@
# something, that gets pretty-printed as a category.
#
# More info over the usage of ANSI control characters for terminal
# formatting:
# https://en.wikipedia.org/wiki/ANSI_escape_code#SGR_parameters
#
# More info over awk command: http://linuxcommand.org/lc3_adv_awk.php
.PHONY: help
help: ## Display this help
@awk 'BEGIN {FS = ":.*##"; printf "\nUsage:\n make \033[36m<target>\033[0m\n"} /^[a-zA-Z_0-9-]+:.*?##/ { printf " \033[36m%-15s\033[0m %s\n", $$1, $$2 } /^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)
## --------------------------------------
## Images
## --------------------------------------
IMAGE_NAME ?= go-generics-the-hard-way
IMAGE_TAG ?= latest
IMAGE ?= $(IMAGE_NAME):$(IMAGE_TAG)
PLATFORMS ?= linux/amd64,linux/arm64
PUSH_ALL ?=
# Please note the `--cap-add=SYS_PTRACE --security-opt seccomp=unconfined`
# flags are required in order to use the `lldb` debugger to attach to a
# .NET process.
IMAGE_RUN_FLAGS ?= -it --rm --cap-add=SYS_PTRACE --security-opt seccomp=unconfined
.PHONY: image-build
image-build: ## Build the docker image
docker build -t $(IMAGE) .
.PHONY: image-build-all
image-build-all: ## Build the docker image for multiple platforms
docker buildx build -t $(IMAGE) --platform $(PLATFORMS) $(PUSH_ALL) .
.PHONY: image-push
image-push: ## Push the docker image
docker push $(IMAGE)
.PHONY: image-push-all
image-push-all: PUSH_ALL=--push
image-push-all: image-build-all
image-push-all: ## Push the docker image for multiple platforms
# Please note the image is run in privileged mode in
# order for the debuggers to attach to processes.
.PHONY: image-run
image-run: ## Launch the docker image
docker run $(IMAGE_RUN_FLAGS) $(IMAGE)
## --------------------------------------
## Testing
## --------------------------------------
.PHONY: test-all
test-all: ## Run all tests
go test -v ./...
.PHONY: test-all-docker
test-all-docker: ## Run all tests in the container
docker run $(IMAGE_RUN_FLAGS) $(IMAGE) make test-all