From 0a26cd77785224dffd7d8b3d41a0a417831c50a4 Mon Sep 17 00:00:00 2001 From: Tobias Klauser Date: Wed, 14 Jul 2021 09:46:01 +0200 Subject: [PATCH] Makefile: introduce GO_BUILD variable This allows users to overwrite the GO environment variable while still using CGO_ENABLED=0. This for example is useful when testing pre-releases of the Go toolchain, e.g. `make GO=go1.17rc1`. Follows cilium/hubble#560 Signed-off-by: Tobias Klauser --- Makefile | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/Makefile b/Makefile index 799cd73f56..27cc4b95ca 100644 --- a/Makefile +++ b/Makefile @@ -1,4 +1,5 @@ -GO := CGO_ENABLED=0 go +GO := go +GO_BUILD = CGO_ENABLED=0 $(GO) build GO_TAGS ?= TARGET=cilium INSTALL = $(QUIET)install @@ -15,7 +16,7 @@ GOLANGCILINT_WANT_VERSION = 1.40.1 GOLANGCILINT_VERSION = $(shell golangci-lint version 2>/dev/null) $(TARGET): - $(GO) build $(if $(GO_TAGS),-tags $(GO_TAGS)) \ + $(GO_BUILD) $(if $(GO_TAGS),-tags $(GO_TAGS)) \ -ldflags "-w -s \ -X 'github.com/cilium/cilium-cli/internal/cli/cmd.GitBranch=${GIT_BRANCH}' \ -X 'github.com/cilium/cilium-cli/internal/cli/cmd.GitHash=$(GIT_HASH)' \ @@ -47,7 +48,7 @@ local-release: clean for ARCH in $$ARCHS; do \ echo Building release binary for $$OS/$$ARCH...; \ test -d release/$$OS/$$ARCH|| mkdir -p release/$$OS/$$ARCH; \ - env GOOS=$$OS GOARCH=$$ARCH $(GO) build $(if $(GO_TAGS),-tags $(GO_TAGS)) -ldflags "-w -s -X 'github.com/cilium/cilium-cli/internal/cli/cmd.Version=${VERSION}'" -o release/$$OS/$$ARCH/$(TARGET)$$EXT ./cmd/cilium; \ + env GOOS=$$OS GOARCH=$$ARCH $(GO_BUILD) $(if $(GO_TAGS),-tags $(GO_TAGS)) -ldflags "-w -s -X 'github.com/cilium/cilium-cli/internal/cli/cmd.Version=${VERSION}'" -o release/$$OS/$$ARCH/$(TARGET)$$EXT ./cmd/cilium; \ tar -czf release/$(TARGET)-$$OS-$$ARCH.tar.gz -C release/$$OS/$$ARCH $(TARGET)$$EXT; \ (cd release && sha256sum $(TARGET)-$$OS-$$ARCH.tar.gz > $(TARGET)-$$OS-$$ARCH.tar.gz.sha256sum); \ done; \ @@ -66,10 +67,10 @@ clean: rm -rf ./release test: - go test -timeout=$(TEST_TIMEOUT) -race -cover $$(go list ./...) + $(GO) test -timeout=$(TEST_TIMEOUT) -race -cover $$($(GO) list ./...) bench: - go test -timeout=30s -bench=. $$(go list ./...) + $(GO) test -timeout=30s -bench=. $$($(GO) list ./...) ifneq (,$(findstring $(GOLANGCILINT_WANT_VERSION),$(GOLANGCILINT_VERSION))) check: