forked from kubernetes/cloud-provider-vsphere
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
405 lines (333 loc) · 15.4 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
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
all: build
# Get the absolute path and name of the current directory.
PWD := $(abspath .)
BASE_DIR := $(notdir $(PWD))
# PROJECT_ROOT is used when host access is required when running
# Docker-in-Docker (DinD).
export PROJECT_ROOT ?= $(PWD)
# BUILD_OUT is the root directory containing the build output.
export BUILD_OUT ?= .build
# BIN_OUT is the directory containing the built binaries.
export BIN_OUT ?= $(BUILD_OUT)/bin
# ARTIFACTS is the directory containing artifacts uploaded to the Kubernetes
# test grid at the end of a Prow job.
export ARTIFACTS ?= $(BUILD_OUT)/artifacts
# BRANCH_NAME is the name of current branch.
export BRANCH_NAME ?= $(shell git rev-parse --abbrev-ref HEAD)
################################################################################
## VERIFY GO VERSION ##
################################################################################
# Go 1.11+ required for Go modules.
GO_VERSION_EXP := "go1.11"
GO_VERSION_ACT := $(shell a="$$(go version | awk '{print $$3}')" && test $$(printf '%s\n%s' "$${a}" "$(GO_VERSION_EXP)" | sort | tail -n 1) = "$${a}" && printf '%s' "$${a}")
ifndef GO_VERSION_ACT
$(error Requires Go $(GO_VERSION_EXP)+ for Go module support)
endif
MOD_NAME := $(shell head -n 1 <go.mod | awk '{print $$2}')
################################################################################
## VERIFY BUILD PATH ##
################################################################################
ifneq (on,$(GO111MODULE))
export GO111MODULE := on
# The cloud provider should not be cloned inside the GOPATH.
GOPATH := $(shell go env GOPATH)
ifeq (/src/$(MOD_NAME),$(subst $(GOPATH),,$(PWD)))
$(warning This project uses Go modules and should not be cloned into the GOPATH)
endif
endif
# Use GOPROXY environment variable if set
GOPROXY := $(shell go env GOPROXY)
ifeq (,$(strip $(GOPROXY)))
GOPROXY := https://proxy.golang.org
endif
export GOPROXY
################################################################################
## DEPENDENCIES ##
################################################################################
# Verify the dependencies are in place.
.PHONY: deps
deps:
go mod download && go mod verify
################################################################################
## VERSIONS ##
################################################################################
# Ensure the version is injected into the binaries via a linker flag.
export VERSION ?= $(shell git describe --always --dirty)
.PHONY: version print-ccm-image
version:
@echo $(VERSION)
################################################################################
## BUILD BINARIES ##
################################################################################
# Unless otherwise specified the binaries should be built for linux-amd64.
GOOS ?= linux
GOARCH ?= amd64
LDFLAGS := $(shell cat hack/make/ldflags.txt)
LDFLAGS_CCM := $(LDFLAGS) -X "main.version=$(VERSION)" -X "k8s.io/kubernetes/pkg/version.gitVersion=$(VERSION)" -X "k8s.io/component-base/pkg/version.gitVersion=$(VERSION)"
# The cloud controller binary.
CCM_BIN_NAME := vsphere-cloud-controller-manager
CCM_BIN := $(BIN_OUT)/$(CCM_BIN_NAME).$(GOOS)_$(GOARCH)
build-ccm: $(CCM_BIN)
ifndef CCM_BIN_SRCS
CCM_BIN_SRCS := cmd/$(CCM_BIN_NAME)/main.go go.mod go.sum
CCM_BIN_SRCS += $(addsuffix /*.go,$(shell go list -f '{{ join .Deps "\n" }}' ./cmd/$(CCM_BIN_NAME) | grep $(MOD_NAME) | sed 's~$(MOD_NAME)~.~'))
export CCM_BIN_SRCS
endif
$(CCM_BIN): $(CCM_BIN_SRCS)
CGO_ENABLED=0 GOOS=$(GOOS) GOARCH=$(GOARCH) go build -ldflags '$(LDFLAGS_CCM)' -o $(abspath $@) $<
@touch $@
# The default build target.
build build-bins: $(CCM_BIN)
build-with-docker:
hack/make.sh
# Tooling binaries for e2e
TOOLS_DIR := $(abspath hack/tools)
TOOLS_BIN_DIR := $(TOOLS_DIR)/bin
GINKGO := $(TOOLS_BIN_DIR)/ginkgo
KIND := $(TOOLS_BIN_DIR)/kind
TOOLING_BINARIES := $(GINKGO) $(KIND)
E2E_DIR := $(abspath test/e2e)
################################################################################
## DIST ##
################################################################################
DIST_CCM_NAME := cloud-provider-vsphere-$(VERSION)
DIST_CCM_TGZ := $(BUILD_OUT)/dist/$(DIST_CCM_NAME)-$(GOOS)_$(GOARCH).tar.gz
dist-ccm-tgz: $(DIST_CCM_TGZ)
$(DIST_CCM_TGZ): $(CCM_BIN)
_temp_dir=$$(mktemp -d) && cp $< "$${_temp_dir}/$(CCM_BIN_NAME)" && \
tar czf $(abspath $@) README.md LICENSE -C "$${_temp_dir}" "$(CCM_BIN_NAME)" && \
rm -fr "$${_temp_dir}"
DIST_CCM_ZIP := $(BUILD_OUT)/dist/$(DIST_CCM_NAME)-$(GOOS)_$(GOARCH).zip
dist-ccm-zip: $(DIST_CCM_ZIP)
$(DIST_CCM_ZIP): $(CCM_BIN)
_temp_dir=$$(mktemp -d) && cp $< "$${_temp_dir}/$(CCM_BIN_NAME)" && \
zip -j $(abspath $@) README.md LICENSE "$${_temp_dir}/$(CCM_BIN_NAME)" && \
rm -fr "$${_temp_dir}"
dist-ccm: dist-ccm-tgz dist-ccm-zip
dist: dist-ccm
################################################################################
## DEPLOY ##
################################################################################
# The deploy target is for use by Prow.
.PHONY: deploy
deploy: | $(DOCKER_SOCK)
$(MAKE) check
$(MAKE) build-bins
$(MAKE) unit-test
$(MAKE) integration-test
$(MAKE) release-push
################################################################################
## CLEAN ##
################################################################################
.PHONY: clean
clean:
@rm -f Dockerfile*
@rm -f $(CCM_BIN) $(CCM_BIN).sha256 \
cloud-provider-vsphere-*.tar.gz cloud-provider-vsphere-*.zip \
image-*.tar image-*.d
GO111MODULE=off go clean -i -x . ./cmd/$(CCM_BIN_NAME)
.PHONY: clean-d
clean-d:
@find . -name "*.d" -type f -delete
################################################################################
## CROSS BUILD ##
################################################################################
# Defining X_BUILD_DISABLED prevents the cross-build and cross-dist targets
# from being defined. This is to improve performance when invoking x-build
# or x-dist targets that invoke this Makefile. The nested call does not need
# to provide cross-build or cross-dist targets since it's the result of one.
ifndef X_BUILD_DISABLED
export X_BUILD_DISABLED := 1
# Modify this list to add new cross-build and cross-dist targets.
X_TARGETS ?= darwin_amd64 linux_amd64 linux_386 linux_arm linux_arm64 linux_ppc64le
X_TARGETS := $(filter-out $(GOOS)_$(GOARCH),$(X_TARGETS))
X_CCM_BINS := $(addprefix $(CCM_BIN_NAME).,$(X_TARGETS))
$(X_CCM_BINS):
GOOS=$(word 1,$(subst _, ,$(subst $(CCM_BIN_NAME).,,$@))) GOARCH=$(word 2,$(subst _, ,$(subst $(CCM_BIN_NAME).,,$@))) $(MAKE) build-ccm
x-build-ccm: $(CCM_BIN) $(X_CCM_BINS)
x-build: x-build-ccm
################################################################################
## CROSS DIST ##
################################################################################
X_DIST_CCM_TARGETS := $(X_TARGETS)
X_DIST_CCM_TARGETS := $(addprefix $(DIST_CCM_NAME)-,$(X_DIST_CCM_TARGETS))
X_DIST_CCM_TGZS := $(addsuffix .tar.gz,$(X_DIST_CCM_TARGETS))
X_DIST_CCM_ZIPS := $(addsuffix .zip,$(X_DIST_CCM_TARGETS))
$(X_DIST_CCM_TGZS):
GOOS=$(word 1,$(subst _, ,$(subst $(DIST_CCM_NAME)-,,$@))) GOARCH=$(word 2,$(subst _, ,$(subst $(DIST_CCM_NAME)-,,$(subst .tar.gz,,$@)))) $(MAKE) dist-ccm-tgz
$(X_DIST_CCM_ZIPS):
GOOS=$(word 1,$(subst _, ,$(subst $(DIST_CCM_NAME)-,,$@))) GOARCH=$(word 2,$(subst _, ,$(subst $(DIST_CCM_NAME)-,,$(subst .zip,,$@)))) $(MAKE) dist-ccm-zip
x-dist-ccm-tgzs: $(DIST_CCM_TGZ) $(X_DIST_CCM_TGZS)
x-dist-ccm-zips: $(DIST_CCM_ZIP) $(X_DIST_CCM_ZIPS)
x-dist-ccm: x-dist-ccm-tgzs x-dist-ccm-zips
x-dist: x-dist-ccm
################################################################################
## CROSS CLEAN ##
################################################################################
X_CLEAN_TARGETS := $(addprefix clean-,$(X_TARGETS))
.PHONY: $(X_CLEAN_TARGETS)
$(X_CLEAN_TARGETS):
GOOS=$(word 1,$(subst _, ,$(subst clean-,,$@))) GOARCH=$(word 2,$(subst _, ,$(subst clean-,,$@))) $(MAKE) clean
.PHONY: x-clean
x-clean: clean $(X_CLEAN_TARGETS)
endif # ifndef X_BUILD_DISABLED
################################################################################
## TESTING ##
################################################################################
ifndef PKGS_WITH_TESTS
export PKGS_WITH_TESTS := $(sort $(shell find ./pkg -name "*_test.go" -type f -exec dirname \{\} \;))
endif
TEST_FLAGS ?= -v
.PHONY: unit build-unit-tests
KUBE_BUILDER_VERSION = 2.3.1
KUBE_BUILDER = kubebuilder_${KUBE_BUILDER_VERSION}_${GOOS}_${GOARCH}
KUBE_BUILDER_DIR = "/usr/local/kubebuilder/$(KUBE_BUILDER)"
unit unit-test:
@if [ ! -d $(KUBE_BUILDER_DIR) ]; then \
curl -L https://github.com/kubernetes-sigs/kubebuilder/releases/download/v${KUBE_BUILDER_VERSION}/${KUBE_BUILDER}.tar.gz | tar -xz -C /tmp/ ;\
mv /tmp/${KUBE_BUILDER} /usr/local/kubebuilder; \
export PATH=$PATH:/usr/local/kubebuilder/bin; \
fi
env -u VSPHERE_SERVER -u VSPHERE_PASSWORD -u VSPHERE_USER go test $(TEST_FLAGS) -tags=unit $(PKGS_WITH_TESTS)
build-unit-tests:
$(foreach pkg,$(PKGS_WITH_TESTS),go test $(TEST_FLAGS) -c -tags=unit $(pkg); )
# The default test target.
.PHONY: test build-tests
test: unit
build-tests: build-unit-tests
.PHONY: test-cover
test-cover: TEST_FLAGS += -coverprofile=coverage.out ## Run tests with code coverage and code generate reports
test-cover: test
go tool cover -func=coverage.out -o coverage.txt
go tool cover -html=coverage.out -o coverage.html
tools: $(TOOLING_BINARIES) ## Build tooling binaries
.PHONY: $(TOOLING_BINARIES)
$(TOOLING_BINARIES):
make -C $(TOOLS_DIR) $(@F)
.PHONY: e2e
e2e:
make -C $(E2E_DIR) run
.PHONY: e2e-latest-k8s-version
e2e-latest-k8s-version:
make -C $(E2E_DIR) run-on-latest-k8s-version
.PHONY: integration-test
integration-test: | $(DOCKER_SOCK)
$(MAKE) -C test/integration
.PHONY: conformance-test
conformance-test: | $(DOCKER_SOCK)
ifeq (true,$(DOCKER_IN_DOCKER_ENABLED))
hack/images/ci/conformance.sh
else
docker run -it --rm \
-e "PROJECT_ROOT=$(PROJECT_ROOT)" \
-v $(DOCKER_SOCK):$(DOCKER_SOCK) \
-v "$(PWD)":/go/src/k8s.io/cloud-provider-vsphere \
-e "CLOUD_PROVIDER=$${CLOUD_PROVIDER}" \
-e "E2E_FOCUS=$${E2E_FOCUS}" \
-e "E2E_SKIP=$${E2E_SKIP}" \
-e "K8S_VERSION=$${K8S_VERSION}" \
-e "KUBE_CONFORMANCE_IMAGE=$${KUBE_CONFORMANCE_IMAGE:-akutz/kube-conformance:latest}" \
-e "NUM_BOTH=$${NUM_BOTH}" \
-e "NUM_CONTROLLERS=$${NUM_CONTROLLERS}" \
-e "NUM_WORKERS=$${NUM_WORKERS}" \
-e "ARTIFACTS=/artifacts" -v "$(abspath $(ARTIFACTS))":/artifacts \
-e "CONFIG_ENV=/config.env" -v "$${CONFIG_ENV:-$(abspath config.env)}":/config.env:ro \
gcr.io/k8s-staging-cloud-pv-vsphere/cloud-provider-vsphere \
make conformance-test
endif
.PHONY: quick-conformance-test
quick-conformance-test: export NUM_CONTROLLERS=1
quick-conformance-test: export NUM_WORKERS=1
quick-conformance-test: export E2E_FOCUS=should provide DNS for the cluster[[:space:]]{0,}\\[Conformance\\]
quick-conformance-test: conformance-test
################################################################################
## LINTING ##
################################################################################
.PHONY: fmt vet lint mdlint shellcheck staticcheck check
check: fmt lint mdlint shellcheck staticcheck vet
fmt:
hack/check-format.sh
lint:
hack/check-lint.sh
mdlint:
hack/check-mdlint.sh
shellcheck:
hack/check-shell.sh
staticcheck:
hack/check-staticcheck.sh
vet:
hack/check-vet.sh
################################################################################
## CI IMAGE ##
################################################################################
build-ci-image:
$(MAKE) -C hack/images/ci build
print-ci-image:
@$(MAKE) --no-print-directory -C hack/images/ci print
################################################################################
## CODE-GEN ##
################################################################################
.PHONY: update-codegen verify-codegen
update-codegen:
hack/update-codegen.sh
verify-codegen:
hack/verify-codegen.sh
################################################################################
## HELPERS ##
################################################################################
.PHONY: squash
squash:
hack/git-squash.sh $(MESSAGE)
.PHONY: docker-image
docker-image:
docker build \
-f cluster/images/controller-manager/Dockerfile \
-t "$(IMAGE):$(BRANCH_NAME)" \
--build-arg "VERSION=${VERSION}" . \
################################################################################
## GCP CLOUDBUILD RELEATED ##
################################################################################
# Define DGCP Cloud build related variables.
PROD_REGISTRY ?= registry.k8s.io/cloud-pv-vsphere
STAGING_REGISTRY ?= gcr.io/k8s-staging-cloud-pv-vsphere
STAGING_BUCKET ?= k8s-staging-cloud-pv-vsphere
IMAGE_NAME ?= cloud-provider-vsphere
VERSION ?=$(shell git describe --dirty --always)
# Default image registry and image binary path
IMAGE_PATH := $(STAGING_REGISTRY)/$(IMAGE_NAME):$(VERSION)
BINARY_PATH := gs://$(STAGING_BUCKET)/$(VERSION)/bin/$(GOOS)/$(GOARCH)
LOCAL_BINARY_PATH := $(abspath $(BIN_OUT))/vsphere-cloud-controller-manager.$(GOOS)_$(GOARCH)
.PHONY: docker-build-and-push
docker-build-and-push:
docker build \
-f cluster/images/controller-manager/Dockerfile \
-t $(IMAGE_PATH) \
--build-arg "VERSION=${VERSION}" \
--build-arg "GOPROXY=${GOPROXY}" \
.
docker push "$(IMAGE_PATH)"
.PHONY: ccm-bin-push
ccm-bin-push:
$(shell { sha256sum $(LOCAL_BINARY_PATH) || shasum -a 256 $(LOCAL_BINARY_PATH); } 2>/dev/null > $(LOCAL_BINARY_PATH).sha256)
gsutil cp "$(LOCAL_BINARY_PATH)" "$(BINARY_PATH)/vsphere-cloud-controller-manager"
gsutil cp "$(LOCAL_BINARY_PATH).sha256" "$(BINARY_PATH)/vsphere-cloud-controller-manager.sha256"
.PHONY: pr-staging
pr-staging:
$(MAKE) IMAGE_PATH=$(STAGING_REGISTRY)/pr/$(IMAGE_NAME):$(VERSION) docker-build-and-push
$(MAKE) build-bins
$(MAKE) BINARY_PATH=gs://$(STAGING_BUCKET)/pr/$(VERSION)/bin/$(GOOS)/$(GOARCH) ccm-bin-push
.PHONY: ci-staging
ci-staging:
$(MAKE) IMAGE_PATH=$(STAGING_REGISTRY)/ci/$(IMAGE_NAME):$(VERSION) docker-build-and-push
$(MAKE) build-bins
$(MAKE) BINARY_PATH=gs://$(STAGING_BUCKET)/ci/$(VERSION)/bin/$(GOOS)/$(GOARCH) ccm-bin-push
.PHONY: release-staging-nightly
release-staging-nightly:
$(MAKE) IMAGE_PATH=$(STAGING_REGISTRY)/nightly/$(IMAGE_NAME):$(VERSION)-$(shell date +'%Y%m%d') docker-build-and-push
$(MAKE) build-bins
$(MAKE) BINARY_PATH=gs://$(STAGING_BUCKET)/nightly/$(VERSION)-$(shell date +'%Y%m%d')/bin/$(GOOS)/$(GOARCH) ccm-bin-push
.PHONY: release-staging
release-staging:
$(MAKE) docker-build-and-push
$(MAKE) build-bins
$(MAKE) ccm-bin-push