From 5aa2e903ea11736cb7eea434194e12b856ba5c0d Mon Sep 17 00:00:00 2001 From: Jason Du Date: Mon, 4 Mar 2024 16:33:41 -0800 Subject: [PATCH] Repo controlled build go version (#2831) --- .github/workflows/deps.yml | 6 ++++-- .go-version | 1 + Makefile | 43 +++++++++++++++++++++----------------- test/agent/Dockerfile | 4 +++- test/agent/Makefile | 7 +++++-- 5 files changed, 37 insertions(+), 24 deletions(-) create mode 100644 .go-version diff --git a/.github/workflows/deps.yml b/.github/workflows/deps.yml index c17655ce72..b8e37c8693 100644 --- a/.github/workflows/deps.yml +++ b/.github/workflows/deps.yml @@ -23,17 +23,19 @@ jobs: uses: actions/checkout@v4 with: show-progress: false + - name: Setup Go Version + run: echo "GO_VERSION=$(cat .go-version)" >> $GITHUB_ENV - id: govulncheck uses: ./.github/actions/govulncheck with: - go-version-input: 1.21.7 + go-version-input: ${{ env.GO_VERSION }} go-version-file: go.mod cache: false repo-checkout: false - id: govulncheck-tests-agent uses: ./.github/actions/govulncheck with: - go-version-input: 1.21.7 + go-version-input: ${{ env.GO_VERSION }} go-version-file: test/agent/go.mod cache: false repo-checkout: false diff --git a/.go-version b/.go-version new file mode 100644 index 0000000000..8819d012ce --- /dev/null +++ b/.go-version @@ -0,0 +1 @@ +1.21.7 diff --git a/Makefile b/Makefile index 205ecd5dd4..2c37e59385 100644 --- a/Makefile +++ b/Makefile @@ -21,8 +21,9 @@ # VERSION is the source revision that executables and images are built from. VERSION ?= $(shell git describe --tags --always --dirty || echo "unknown") +GOLANG_VERSION ?= $(shell cat .go-version) # GOLANG_IMAGE is the building golang container image used. -GOLANG_IMAGE ?= public.ecr.aws/eks-distro-build-tooling/golang:1.21.7-8-gcc-al2 +GOLANG_IMAGE ?= public.ecr.aws/eks-distro-build-tooling/golang:$(GOLANG_VERSION)-gcc-al2 # BASE_IMAGE_CNI is the base layer image for the primary AWS VPC CNI plugin container BASE_IMAGE_CNI ?= public.ecr.aws/eks-distro-build-tooling/eks-distro-minimal-base-iptables:latest.2 # BASE_IMAGE_CNI_INIT is the base layer image for the AWS VPC CNI init container @@ -71,6 +72,9 @@ export CGO_ENABLED = 0 export GO111MODULE = on export GOPROXY = direct +export GOSUMDB = sum.golang.org +export GOTOOLCHAIN = go$(GOLANG_VERSION) + VENDOR_OVERRIDE_FLAG = # aws-sdk-go override in case we need to build against a custom version EC2_SDK_OVERRIDE ?= "n" @@ -92,19 +96,19 @@ CORE_PLUGIN_DIR = $(MAKEFILE_PATH)/core-plugins/ DOCKER_ARGS ?= # DOCKER_RUN_FLAGS is set the flags passed during runs of containers. DOCKER_RUN_FLAGS = --rm -ti $(DOCKER_ARGS) -# DOCKER_BUILD_FLAGS_CNI is the set of flags passed during CNI container image +# DOCKER_BUILD_FLAGS_CNI is the set of flags passed during CNI container image # builds based on the requested build. DOCKER_BUILD_FLAGS_CNI = --build-arg golang_image="$(GOLANG_IMAGE)" \ --build-arg base_image="$(BASE_IMAGE_CNI)" \ --network=host \ $(DOCKER_ARGS) -# DOCKER_BUILD_FLAGS_CNI_INIT is the set of flags passed during CNI init +# DOCKER_BUILD_FLAGS_CNI_INIT is the set of flags passed during CNI init # container image builds based on the requested build. DOCKER_BUILD_FLAGS_CNI_INIT = --build-arg golang_image="$(GOLANG_IMAGE)" \ --build-arg base_image="$(BASE_IMAGE_CNI_INIT)" \ --network=host \ $(DOCKER_ARGS) -# DOCKER_BUILD_FLAGS_CNI_METRICS is the set of flags passed during metrics +# DOCKER_BUILD_FLAGS_CNI_METRICS is the set of flags passed during metrics # container image builds based on the requested build. DOCKER_BUILD_FLAGS_CNI_METRICS = --build-arg golang_image="$(GOLANG_IMAGE)" \ --build-arg base_image="$(BASE_IMAGE_CNI_METRICS)" \ @@ -167,7 +171,7 @@ docker-func-test: docker ## Run the built CNI container image to use in func "$(IMAGE_NAME)" ## Build multi-arch VPC CNI plugin container image. -multi-arch-cni-build: +multi-arch-cni-build: docker buildx build $(DOCKER_BUILD_FLAGS_CNI) \ -f scripts/dockerfiles/Dockerfile.release \ --platform "$(MULTI_PLATFORM_BUILD_TARGETS)"\ @@ -176,7 +180,7 @@ multi-arch-cni-build: . ## Build and push multi-arch VPC CNI plugin container image. -multi-arch-cni-build-push: +multi-arch-cni-build-push: docker buildx build $(DOCKER_BUILD_FLAGS_CNI) \ -f scripts/dockerfiles/Dockerfile.release \ --platform "$(MULTI_PLATFORM_BUILD_TARGETS)"\ @@ -184,8 +188,8 @@ multi-arch-cni-build-push: --push \ . -## Build VPC CNI plugin Init container image. -multi-arch-cni-init-build: +## Build VPC CNI plugin Init container image. +multi-arch-cni-init-build: docker buildx build $(DOCKER_BUILD_FLAGS_CNI_INIT) \ -f scripts/dockerfiles/Dockerfile.init \ --platform "$(MULTI_PLATFORM_BUILD_TARGETS)"\ @@ -194,7 +198,7 @@ multi-arch-cni-init-build: . ## Build and push VPC CNI plugin Init container image. -multi-arch-cni-init-build-push: +multi-arch-cni-init-build-push: docker buildx build $(DOCKER_BUILD_FLAGS_CNI_INIT) \ -f scripts/dockerfiles/Dockerfile.init \ --platform "$(MULTI_PLATFORM_BUILD_TARGETS)"\ @@ -202,7 +206,7 @@ multi-arch-cni-init-build-push: --push \ . -##@ Run Unit Tests +##@ Run Unit Tests # Run unit tests unit-test: export AWS_VPC_K8S_CNI_LOG_FILE=stdout unit-test: ## Run unit tests @@ -222,7 +226,7 @@ unit-test-race: ## Run unit tests with race detection (can only be run nativ go test -v -cover -race -timeout 10s ./pkg/eniconfig/... go test -v -cover -race -timeout 10s ./pkg/ipamd/... -##@ Build and Run Unit Tests +##@ Build and Run Unit Tests # Build the unit test driver container image. build-docker-test: ## Build the unit test driver container image. docker build $(DOCKER_BUILD_FLAGS_CNI) \ @@ -235,16 +239,17 @@ docker-unit-tests: build-docker-test ## Run unit tests inside of the testing docker run $(DOCKER_RUN_ARGS) \ $(TEST_IMAGE_NAME) \ make unit-test - + ##@ Build the Test Binaries files in /test build-test-binaries: mkdir -p ${MAKEFILE_PATH}test/build find ${MAKEFILE_PATH}test/ -name '*suite_test.go' -type f | xargs dirname | xargs ginkgo build find ${MAKEFILE_PATH}test/ -name "*.test" -print0 | xargs -0 -I {} mv {} ${MAKEFILE_PATH}test/build -##@ Build metrics helper agent +##@ Build metrics helper agent # Build metrics helper agent. + build-metrics: ## Build metrics helper agent. go build $(VENDOR_OVERRIDE_FLAG) -ldflags="-s -w" -o cni-metrics-helper ./cmd/cni-metrics-helper @@ -256,7 +261,7 @@ docker-metrics: ## Build metrics helper agent Docker image. . @echo "Built Docker image \"$(METRICS_IMAGE_NAME)\"" -##@ Run metrics helper Unit Tests +##@ Run metrics helper Unit Tests # Run metrics helper unit test suite (must be run natively). metrics-unit-test: CGO_ENABLED=1 @@ -286,7 +291,7 @@ plugins: ## Fetch the CNI plugins mkdir -p $(CORE_PLUGIN_DIR) curl -s -L $(FETCH_URL) | tar xzvf - -C $(CORE_PLUGIN_DIR) -##@ Debug script +##@ Debug script debug-script: FETCH_URL=https://raw.githubusercontent.com/awslabs/amazon-eks-ami/master/log-collector-script/linux/eks-log-collector.sh debug-script: VISIT_URL=https://github.com/awslabs/amazon-eks-ami/tree/master/log-collector-script/linux @@ -299,7 +304,7 @@ debug-script: ## Fetching debug script from awslabs/amazon-eks-ami curl -L $(FETCH_URL) -o ./aws-cni-support.sh chmod +x ./aws-cni-support.sh -##@ Formatting +##@ Formatting # Run all source code checks. check: check-format lint vet ## Run all source code checks. @@ -322,7 +327,7 @@ helm-lint: @${MAKEFILE_PATH}test/helm/helm-lint.sh # Run go vet on source code. -vet: setup-ec2-sdk-override ## Run go vet on source code. +vet: setup-ec2-sdk-override ## Run go vet on source code. go vet $(VENDOR_OVERRIDE_FLAG) $(ALLPKGS) @@ -348,7 +353,7 @@ check-format: format version: @echo ${VERSION} -##@ Generate ENI/IP limits +##@ Generate ENI/IP limits generate: PATH=$(CURDIR)/scripts:$(PATH) go generate -x ./... @@ -385,7 +390,7 @@ cleanup-ec2-sdk-override: @if [ "$(EC2_SDK_OVERRIDE)" = "y" ] ; then \ ./scripts/ec2_model_override/cleanup.sh ; \ fi - + ##@ Cleanup # Clean temporary files and build artifacts from the project. diff --git a/test/agent/Dockerfile b/test/agent/Dockerfile index 6d65310070..70e3159aa7 100644 --- a/test/agent/Dockerfile +++ b/test/agent/Dockerfile @@ -1,4 +1,6 @@ -FROM public.ecr.aws/eks-distro-build-tooling/golang:1.21.7-8-gcc-al2 as builder +ARG golang_image + +FROM $golang_image as builder WORKDIR /workspace ENV GOPROXY direct diff --git a/test/agent/Makefile b/test/agent/Makefile index ec4a2c26e0..3454ba2981 100644 --- a/test/agent/Makefile +++ b/test/agent/Makefile @@ -17,6 +17,9 @@ IMAGE_NAME =aws-vpc-cni-test-helper PUBLIC_REPO_IMAGE=public.ecr.aws/$(REGISTRY_ID)/${IMAGE_NAME}:$(VERSION) PRIVATE_REPO_IMAGE=$(AWS_ACCOUNT).dkr.ecr.$(AWS_REGION).amazonaws.com/$(IMAGE_NAME):$(VERSION) +GOLANG_VERSION ?= $(shell cat ../../.go-version) +GOLANG_IMAGE ?= public.ecr.aws/eks-distro-build-tooling/golang:$(GOLANG_VERSION)-gcc-al2 + fmt: go fmt ./... @@ -26,11 +29,11 @@ vet: publish-private-image: check-env aws ecr get-login-password --region $(AWS_REGION) | docker login --username AWS --password-stdin $(AWS_ACCOUNT).dkr.ecr.$(AWS_REGION).amazonaws.com - docker buildx build --platform "$(MULTI_PLATFORM_BUILD_TARGETS)" -t ${PRIVATE_REPO_IMAGE} --push . + docker buildx build --platform "$(MULTI_PLATFORM_BUILD_TARGETS)" -t ${PRIVATE_REPO_IMAGE} --build-arg golang_image="$(GOLANG_IMAGE)" --push . #Ensure to authenticate to public ECR repo. publish-public-image: check-env-public - docker buildx build --platform "$(MULTI_PLATFORM_BUILD_TARGETS)" -t ${PUBLIC_REPO_IMAGE} --push . + docker buildx build --platform "$(MULTI_PLATFORM_BUILD_TARGETS)" -t ${PUBLIC_REPO_IMAGE} --build-arg golang_image="$(GOLANG_IMAGE)" --push . check-env: @:$(call check_var, AWS_ACCOUNT, AWS account ID for publishing docker images)