-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
312 lines (263 loc) · 9.28 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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
SHELL := /usr/bin/env bash
export GO111MODULE=on
.PHONY: all
all: image
TAG=$(shell git describe --tags --abbrev=10 --long)
TAGGED=$(shell git tag --sort=-creatordate --contains | head --lines=1)
ifneq (,$(TAGGED))
# We're tagged. Use the tag explicitly.
VERSION := $(TAGGED)
else
# We're on a dev/PR branch
VERSION := $(TAG)
endif
LOCAL_VALUES_FILE=chart/infra-server/configuration/infra-values-${ENVIRONMENT}.yaml
LOCAL_COMBINED_VALUES_FILE=chart/infra-server/configuration/infra-values-from-files-${ENVIRONMENT}.yaml
ifeq '$(SECRET_VERSION)' ''
SECRET_VERSION := latest
endif
.PHONY: tag
tag:
@echo $(VERSION)
IMAGE=quay.io/rhacs-eng/infra-server:$(VERSION)
.PHONY: image-name
image-name:
@echo $(IMAGE)
##############
## Protobuf ##
##############
# Tool versions.
protoc-version = 3.11.2
protoc-gen-go-version = 1.3.2
protoc-gen-grpc-gateway-version = 1.12.1
protoc-gen-swagger-version = 1.12.1
# Tool binary paths
protoc = $(GOPATH)/bin/protoc
protoc-gen-go = $(GOPATH)/bin/protoc-gen-go
protoc-gen-grpc-gateway = $(GOPATH)/bin/protoc-gen-grpc-gateway
protoc-gen-swagger = $(GOPATH)/bin/protoc-gen-swagger
# The protoc zip url changes depending on if we're running in CI or not.
ifeq ($(shell uname -s),Linux)
PROTOC_ZIP = https://github.com/protocolbuffers/protobuf/releases/download/v$(protoc-version)/protoc-$(protoc-version)-linux-x86_64.zip
endif
ifeq ($(shell uname -s),Darwin)
PROTOC_ZIP = https://github.com/protocolbuffers/protobuf/releases/download/v$(protoc-version)/protoc-$(protoc-version)-osx-x86_64.zip
endif
# This target installs the protoc binary.
$(protoc):
@echo "+ $@"
@echo "Installing protoc $(protoc-version) to $(protoc)"
@mkdir -p $(GOPATH)/bin
@wget -q $(PROTOC_ZIP) -O /tmp/protoc.zip
@unzip -o -q -d /tmp /tmp/protoc.zip bin/protoc
@install /tmp/bin/protoc $(protoc)
# This target installs the protoc-gen-go binary.
$(protoc-gen-go):
@echo "+ $@"
@echo "Installing protoc-gen-go $(protoc-gen-go-version) to $(protoc-gen-go)"
@cd /tmp; go install github.com/golang/protobuf/protoc-gen-go@v$(protoc-gen-go-version)
# This target installs the protoc-gen-grpc-gateway binary.
$(protoc-gen-grpc-gateway):
@echo "+ $@"
@echo "Installing protoc-gen-grpc-gateway $(protoc-gen-grpc-gateway-version) to $(protoc-gen-grpc-gateway)"
@cd /tmp; go install github.com/grpc-ecosystem/grpc-gateway/protoc-gen-grpc-gateway@v$(protoc-gen-grpc-gateway-version)
# This target installs the protoc-gen-swagger binary.
$(protoc-gen-swagger):
@echo "+ $@"
@echo "Installing protoc-gen-swagger $(protoc-gen-swagger-version) to $(protoc-gen-swagger)"
@cd /tmp; go install github.com/grpc-ecosystem/grpc-gateway/protoc-gen-swagger@v$(protoc-gen-swagger-version)
# This target installs all of the protoc related binaries.
.PHONY: protoc-tools
protoc-tools: $(protoc) $(protoc-gen-go) $(protoc-gen-grpc-gateway) $(protoc-gen-swagger)
PROTO_INPUT_DIR = proto/api/v1
PROTO_THIRD_PARTY = proto/third_party
PROTO_FILES = service.proto
PROTO_OUTPUT_DIR = generated/api/v1
# This target compiles proto files into:
# - Go gRPC bindings
# - Go gRPC-Gateway bindings
# - JSON Swagger definitions file
.PHONY: proto-generated-srcs
proto-generated-srcs: protoc-tools
@echo "+ $@"
@mkdir -p $(PROTO_OUTPUT_DIR)
# Generate gRPC bindings
$(protoc) -I$(PROTO_INPUT_DIR) \
-I$(PROTO_THIRD_PARTY) \
--go_out=plugins=grpc:$(PROTO_OUTPUT_DIR) \
$(PROTO_FILES)
# Generate gRPC-Gateway bindings
$(protoc) -I$(PROTO_INPUT_DIR) \
-I$(PROTO_THIRD_PARTY) \
--grpc-gateway_out=logtostderr=true:$(PROTO_OUTPUT_DIR) \
$(PROTO_FILES)
# Generate JSON Swagger manifest
$(protoc) -I$(PROTO_INPUT_DIR) \
-I$(PROTO_THIRD_PARTY) \
--swagger_out=logtostderr=true:$(PROTO_OUTPUT_DIR) \
$(PROTO_FILES)
###########
## Build ##
###########
# server - Builds the infra-server binary
# When run locally, a Darwin binary is built and installed into the user's GOPATH bin.
# When run in CI, a Darwin and Linux binary is built.
.PHONY: server
server:
@echo "+ $@"
GOARCH=amd64 GOOS=linux ./scripts/go-build -o bin/infra-server-linux-amd64 ./cmd/infra-server
# cli - Builds the infractl client binary
# When run in CI or when preparing an image, a Darwin and Linux binary is built.
.PHONY: cli
cli:
@echo "+ $@"
GOARCH=amd64 GOOS=darwin ./scripts/go-build -o bin/infractl-darwin-amd64 ./cmd/infractl
GOARCH=arm64 GOOS=darwin ./scripts/go-build -o bin/infractl-darwin-arm64 ./cmd/infractl
GOARCH=amd64 GOOS=linux ./scripts/go-build -o bin/infractl-linux-amd64 ./cmd/infractl
# cli-local - Builds the infractl client binary
# When run locally, a Darwin binary is built and installed into the user's GOPATH bin.
.PHONY: cli-local
cli-local:
@echo "+ $@"
./scripts/go-build -o $(GOPATH)/bin/infractl ./cmd/infractl
.PHONY: ui
ui:
@echo "+ $@"
@make -C ui all
.PHONY: image
image:
docker build . -t $(IMAGE) -f image/Dockerfile --secret id=npmrc,src=${HOME}/.npmrc
.PHONY: push
push:
docker push $(IMAGE) | cat
#############
## Linting ##
#############
.PHONY: argo-workflow-lint
argo-workflow-lint:
@argo lint ./chart/infra-server/static/workflow*.yaml
.PHONY: shellcheck
shellcheck:
@shellcheck -x -- **/*.{bats,sh}
#############
## Testing ##
#############
.PHONY: unit-test
unit-test: proto-generated-srcs
@echo "+ $@"
@go test -v ./...
.PHONY: bats-e2e-tests
bats-e2e-tests:
@kubectl apply -f "workflows/*.yaml"
@bats --recursive .
.PHONY: go-e2e-tests
go-e2e-tests: proto-generated-srcs
@kubectl apply -f workflows/
@go test ./test/e2e/... -tags=e2e -v -parallel 5 -count 1 -cover -timeout 1h
# Assuming a local dev infra server is running and accessible via a port-forward
# i.e. nohup kubectl -n infra port-forward svc/infra-server-service 8443:8443 &
.PHONY: pull-infractl-from-dev-server
pull-infractl-from-dev-server:
@mkdir -p bin
@rm -f bin/infractl
set -o pipefail; \
curl --retry 3 --insecure --silent --show-error --fail --location https://localhost:8443/v1/cli/$(shell go env GOOS)/$(shell go env GOARCH)/upgrade \
| jq -r ".result.fileChunk" \
| base64 -d \
> bin/infractl
chmod +x bin/infractl
bin/infractl -k -e localhost:8443 version
##########
## Kube ##
##########
dev_context = gke_acs-team-automation_us-west2_infra-development
prod_context = gke_acs-team-automation_us-west2_infra-production
this_context = $(shell kubectl config current-context)
## Meta
.PHONY: pre-check
pre-check:
ifndef ENVIRONMENT
$(error ENVIRONMENT is undefined)
endif
@if [[ "${ENVIRONMENT}" == "development" && "${this_context}" == "${prod_context}" ]]; then \
echo -e "Your kube context is not set to a development infra. Use the following for dev cluster or set it to your PR cluster\n\tkubectl config use-context ${dev_context}\n"; \
exit 1; \
fi
@if [[ "${ENVIRONMENT}" == "production" && "${this_context}" != "${prod_context}" ]]; then \
echo -e "Your kube context is not set to production infra:\n\tkubectl config use-context ${prod_context}"; \
exit 1; \
fi
## Render template
.PHONY: helm-template
helm-template: pre-check
@./scripts/deploy/helm.sh template $(VERSION) $(ENVIRONMENT) $(SECRET_VERSION)
## Deploy
.PHONY: helm-deploy
helm-deploy: pre-check
@./scripts/deploy/helm.sh deploy $(VERSION) $(ENVIRONMENT) $(SECRET_VERSION)
# Pick up any eventual changes to the workflow controller configmap
@make bounce-argo-pods
## Diff
.PHONY: helm-diff
helm-diff: pre-check
@./scripts/deploy/helm.sh diff $(VERSION) $(ENVIRONMENT) $(SECRET_VERSION)
## Bounce pods
.PHONY: bounce-infra-pods
bounce-infra-pods:
kubectl -n infra rollout restart deploy/infra-server-deployment
kubectl -n infra rollout status deploy/infra-server-deployment --watch --timeout=3m
.PHONY: bounce-argo-pods
bounce-argo-pods:
kubectl rollout restart deploy/argo-workflows-workflow-controller -n argo
kubectl rollout status deploy/argo-workflows-workflow-controller -n argo --watch --timeout=3m
kubectl rollout restart deploy/argo-workflows-server -n argo
kubectl rollout status deploy/argo-workflows-server -n argo --watch --timeout=3m
#############
## Secrets ##
#############
.PHONY: secrets-download
secrets-download:
@./scripts/deploy/secrets.sh download_secrets $(ENVIRONMENT)
.PHONY: secrets-upload
secrets-upload:
@./scripts/deploy/secrets.sh upload_secrets $(ENVIRONMENT) $(SECRET_VERSION)
.PHONY: secrets-show
secrets-show:
@./scripts/deploy/secrets.sh show $(ENVIRONMENT) $(SECRET_VERSION)
.PHONY: secrets-edit
secrets-edit:
@./scripts/deploy/secrets.sh edit $(ENVIRONMENT) $(SECRET_VERSION)
.PHONY: secrets-revert
secrets-revert:
@./scripts/deploy/secrets.sh revert $(ENVIRONMENT) $(SECRET_VERSION)
##################
## Dependencies ##
##################
.PHONY: install-argo
install-argo: pre-check
helm repo add argo https://argoproj.github.io/argo-helm
helm upgrade \
argo-workflows \
argo/argo-workflows \
--version 0.16.9 \
--install \
--create-namespace \
--namespace argo
.PHONY: clean-argo-config
clean-argo-config: pre-check
kubectl delete configmap argo-workflows-workflow-controller-configmap -n argo || true
.PHONY: install-monitoring
install-monitoring: pre-check
helm dependency update chart/infra-monitoring
helm upgrade prometheus-stack chart/infra-monitoring \
--install \
--namespace monitoring \
--create-namespace \
--values chart/infra-monitoring/values.yaml \
--wait
###############
## Debugging ##
###############
.PHONY: prepare-local-server-debugging
prepare-local-server-debugging:
@./scripts/local-dev/prepare.sh