-
Notifications
You must be signed in to change notification settings - Fork 17
/
Makefile
265 lines (215 loc) · 8.35 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
# Produce CRDs that work back to Kubernetes 1.11 (no version conversion)
CRD_OPTIONS ?= "crd"
# Get the currently used golang install path (in GOPATH/bin, unless GOBIN is set)
GOBIN := $(shell go env GOBIN)
ifeq (,$(strip ${GOBIN}))
GOBIN := $(shell go env GOPATH)/bin
endif
.DEFAULT_GOAL := all
include project-name.mk
# Makes a recipe passed to a single invocation of the shell.
.ONESHELL:
MAKE_SOURCES:=makefile.mk project-name.mk Makefile
PROJECT_SOURCES:=$(shell find ./main ./controllers/ ./api/ ./pkg/ -regex '.*.\.\(go\|json\)$$')
BUILD_DIR:=build/
RELEASE_DIR:=$(shell mktemp -d)
GITHUB_USER?=$(shell git config --local user.name)
GITHUB_ORG=$(shell git config --get remote.origin.url | sed -nr '/github.com/ s/.*github.com([^"]+).*/\1/p' | cut --characters=2- | cut -f1 -d/)
GITHUB_REPO=$(shell git config --get remote.origin.url | sed -nr '/github.com/ s/.*github.com([^"]+).*/\1/p'| cut --characters=2- | cut -f2 -d/ | cut -f1 -d.)
GIT_BRANCH=$(shell git rev-parse --abbrev-ref HEAD)
export VERSION?=$(shell cat VERSION)
export REPO ?=docker.pkg.github.com/${GITHUB_ORG}/${GITHUB_REPO}
# Image URL to use all building/pushing image targets
IMG ?= ${REPO}/${PROJECT}:${VERSION}
export CHART_VERSION?=$(shell grep version: chart/Chart.yaml | awk '{print $$2}')
export CHART_APP_VERSION?=$(shell grep appVersion: chart/Chart.yaml | awk '{print $$2}')
# Controller Integration test setup
export USE_EXISTING_CLUSTER?=true
export ZAP_LOG_LEVEL?=0
export KRAAN_NAMESPACE?=gotk-system
export KUBECONFIG?=${HOME}/.kube/config
export DATA_PATH?=$(shell mktemp -d -t kraan-XXXXXXXXXX)
export SC_HOST?=localhost:8090
ALL_GO_PACKAGES:=$(shell find ${CURDIR}/main/ ${CURDIR}/controllers/ ${CURDIR}/api/ ${CURDIR}/pkg/ \
-type f -name *.go -exec dirname {} \; | sort --uniq)
GO_CHECK_PACKAGES:=$(shell echo $(subst $() $(),\\n,$(ALL_GO_PACKAGES)) | \
awk '{print $$0}')
CHECK_ARTIFACT:=${BUILD_DIR}${PROJECT}-check-${VERSION}-docker.tar
BUILD_ARTIFACT:=${BUILD_DIR}${PROJECT}-${VERSION}-build-docker.tar
DEV_BUILD_ARTIFACT:=${BUILD_DIR}${PROJECT}-${VERSION}-build-dev-docker.tar
GOMOD_CACHE_ARTIFACT:=${GOMOD_CACHE_DIR}._gomod
GOMOD_ARTIFACT:=_gomod
GO_BIN_ARTIFACT:=${GOBIN}/${PROJECT}
GO_DOCS_ARTIFACTS:=$(shell echo $(subst $() $(),\\n,$(ALL_GO_PACKAGES)) | \
sed 's:\(.*[/\]\)\(.*\):\1\2/\2.md:')
YELLOW:=\033[0;33m
GREEN:=\033[0;32m
NC:=\033[0m
# Targets that do not represent filenames need to be registered as phony or
# Make won't always rebuild them.
.PHONY: all clean ci-check ci-gate go-generate \
clean-gomod gomod gomod-update release \
clean-${PROJECT}-check ${PROJECT}-check clean-${PROJECT}-build \
${PROJECT}-build ${GO_CHECK_PACKAGES} clean-check check \
clean-build build generate manifests deploy docker-push controller-gen \
install uninstall lint-build run ${PROJECT}-integration integration clean-integration docker-push-prerelease
# Stop prints each line of the recipe.
.SILENT:
# Allow secondary expansion of explicit rules.
.SECONDEXPANSION: %.md %-docker.tar
all: go-generate ${PROJECT}-check ${PROJECT}-build
build: gomod ${PROJECT}-check ${PROJECT}-build
dev-build: gomod ${PROJECT}-check integration ${PROJECT}-build
integration: gomod ${PROJECT}-integration
clean-integration: clean-${PROJECT}-integration
clean: clean-gomod clean-${PROJECT}-check \
clean-${PROJECT}-build clean-check clean-build \
clean-dev-build clean-builddir-${BUILD_DIR} mkdir-${BUILD_DIR} \
clean-integration
lint:
golangci-lint run --concurrency=1 -v --print-resources-usage
test:
go test ./...
# Specific CI targets.
# ci-check: Validated the 'check' target works for debug as it cache will be used
# by build.
ci-check: check build
$(MAKE) -C build
clean-builddir-${BUILD_DIR}:
rm -rf ${BUILD_DIR}
mkdir-${BUILD_DIR}:
mkdir -p ${BUILD_DIR}
validate-versions:
./scripts/validate.sh
release:
cp -rf docs ${RELEASE_DIR} || exit
cp -f *.md ${RELEASE_DIR} || exit
helm package --version ${CHART_VERSION} chart || exit
mv kraan-controller-${CHART_VERSION}.tgz ${RELEASE_DIR} || exit
ls -la
git status
git checkout -B gh-pages --track origin/gh-pages || exit
cp -rf ${RELEASE_DIR}/* . || exit
rm -rf ${RELEASE_DIR} || exit
helm repo index --url https://fidelity.github.io/kraan/ . || exit
git add kraan-controller-${CHART_VERSION}.tgz
git status
git commit -a -m "release chart version ${CHART_VERSION}" || exit
git push || exit
git checkout ${GIT_BRANCH} || exit
clean-gomod:
clean-gomod:
rm -rf ${GOMOD_ARTIFACT}
go.mod:
go mod tidy
gomod: go.sum
go.sum: ${GOMOD_ARTIFACT}
%._gomod: go.mod
touch ${GOMOD_ARTIFACT}
${GOMOD_ARTIFACT}: gomod-update
gomod-update: go.mod ${PROJECT_SOURCES}
echo "${YELLOW}go mod tidy${NC}" && \
go mod tidy && \
go build ./...
clean-${PROJECT}-check:
$(foreach target,${GO_CHECK_PACKAGES}, \
$(MAKE) -C ${target} --makefile=${CURDIR}/makefile.mk clean;)
${PROJECT}-check: ${GO_CHECK_PACKAGES}
${GO_CHECK_PACKAGES}: go.sum
$(MAKE) -C $@ --makefile=${CURDIR}/makefile.mk
clean-${PROJECT}-integration:
$(foreach target,${GO_CHECK_PACKAGES}, \
$(MAKE) -C ${target} --makefile=${CURDIR}/makefile.mk clean-integration;)
${PROJECT}-integration: ${GO_CHECK_PACKAGES}
$(foreach target,${GO_CHECK_PACKAGES}, \
$(MAKE) -C ${target} \
--makefile=${CURDIR}/makefile.mk integration || exit;)
# Generate code
go-generate: ${PROJECT_SOURCES}
go generate ./...
clean-${PROJECT}-build:
rm -f ${GO_BIN_ARTIFACT}
${PROJECT}-build: ${GO_BIN_ARTIFACT}
${GO_BIN_ARTIFACT}: go.sum ${MAKE_SOURCES} ${PROJECT_SOURCES}
echo "${YELLOW}Building executable: $@${NC}" && \
EMBEDDED_VERSION="github.com/fidelity/kraan/main" && \
CGO_ENABLED=0 go build \
-ldflags="-s -w -X $${EMBEDDED_VERSION}.serverVersion=${VERSION}" \
-o $@ main/main.go
clean-check:
rm -f ${CHECK_ARTIFACT}
check: DOCKER_SOURCES=Dockerfile-check ${MAKE_SOURCES} ${PROJECT_SOURCES}
check: DOCKER_BUILD_OPTIONS=--target builder --no-cache
check: IMG=${PROJECT}-check:${VERSION}
check: mkdir-${BUILD_DIR} ${CHECK_ARTIFACT}
clean-build:
rm -f ${BUILD_ARTIFACT}
ARCHS := linux/arm64 linux/amd64
build: DOCKER_SOURCES=Dockerfile ${MAKE_SOURCES} ${PROJECT_SOURCES}
build: IMG=${REPO}/${PROJECT}:${VERSION}
build: mkdir-${BUILD_DIR} ${BUILD_ARTIFACT}
%-build-docker.tar: $${DOCKER_SOURCES}
docker buildx create --platform linux/amd64,linux/arm64 --name mybuilder --use
for arch in $(ARCHS); do \
echo "${YELLOW}Building $${arch} image.${NC}" && \
docker buildx build --builder mybuilder --platform $${arch} --rm --pull=true --push \
${DOCKER_BUILD_OPTIONS} \
${DOCKER_BUILD_PROXYS} \
--tag ${IMG} \
--file $< \
. && \
docker save --output $@ ${IMG}-$${arch} ; \
done ;
clean-dev-build:
rm -f ${DEV_BUILD_ARTIFACT}
dev-build: DOCKER_SOURCES=Dockerfile-dev ${MAKE_SOURCES} ${PROJECT_SOURCES}
dev-build: IMG=${REPO}/${PROJECT}-prerelease:${VERSION}
dev-build: mkdir-${BUILD_DIR} ${DEV_BUILD_ARTIFACT}
%-build-dev-docker.tar: $${DOCKER_SOURCES}
docker build --rm --pull=true \
${DOCKER_BUILD_OPTIONS} \
${DOCKER_BUILD_PROXYS} \
--tag ${IMG} \
--file $< \
. && \
docker save --output $@ ${IMG}
# Run against the configured Kubernetes cluster in ~/.kube/config
run: ${PROJECT}-build
scripts/run-controller.sh
# Install CRDs into a cluster
install: manifests
kustomize build config/crd | kubectl apply -f -
# Uninstall CRDs from a cluster
uninstall: manifests
kustomize build config/crd | kubectl delete -f -
# Deploy controller in the configured Kubernetes cluster in ~/.kube/config
deploy: manifests
cd config/manager && kustomize edit set image kraan-controller=${IMG}
kustomize build config/default | kubectl apply -f -
# Generate manifests e.g. CRD, RBAC etc.
manifests: controller-gen
$(CONTROLLER_GEN) crd:trivialVersions=true paths="./..." rbac:roleName=manager-role paths="api/..." output:crd:artifacts:config=config/crd/bases
# Generate code
generate: controller-gen
$(CONTROLLER_GEN) object:headerFile="hack/boilerplate.go.txt" paths="./..."
# Push the docker image
docker-push-prerelease:
docker push ${REPO}/${PROJECT}-prerelease:${VERSION}
docker-push:
docker push ${IMG}
# find or download controller-gen
# download controller-gen if necessary
controller-gen:
ifeq (, $(shell which controller-gen))
@{ \
set -e ;\
CONTROLLER_GEN_TMP_DIR=$$(mktemp -d) ;\
cd $$CONTROLLER_GEN_TMP_DIR ;\
go mod init tmp ;\
go get sigs.k8s.io/controller-tools/cmd/[email protected] ;\
rm -rf $$CONTROLLER_GEN_TMP_DIR ;\
}
CONTROLLER_GEN=$(GOBIN)/controller-gen
else
CONTROLLER_GEN=$(shell which controller-gen)
endif