SOURCES := $(shell find . -name '*.go') BINARY := kube-bench DOCKER_ORG ?= aquasec VERSION ?= $(shell git rev-parse --short=7 HEAD) KUBEBENCH_VERSION ?= $(shell git describe --tags --abbrev=0) IMAGE_NAME ?= $(DOCKER_ORG)/$(BINARY):$(VERSION) GOOS ?= linux BUILD_OS := linux uname := $(shell uname -s) ARCHS ?= amd64 arm64 GOARCH ?= $@ ifneq ($(findstring Microsoft,$(shell uname -r)),) BUILD_OS := windows else ifeq ($(uname),Linux) BUILD_OS := linux else ifeq ($(uname),Darwin) BUILD_OS := darwin endif # kind cluster name to use KIND_PROFILE ?= kube-bench KIND_CONTAINER_NAME=$(KIND_PROFILE)-control-plane # build a multi-arch image and push to Docker hub .PHONY: docker docker: publish manifests # build and push an arch-specific image .PHONY: $(ARCHS) manifests publish publish: $(ARCHS) $(ARCHS): @echo "Building Docker image for $@" docker build -t ${DOCKER_ORG}/${BINARY}:$(GOOS)-$(GOARCH)-${VERSION} \ --build-arg GOOS=$(GOOS) --build-arg GOARCH=$(GOARCH) ./ @echo "Push $@ Docker image to ${DOCKER_ORG}/${BINARY}" docker push ${DOCKER_ORG}/${BINARY}:$(GOOS)-$(GOARCH)-${VERSION} docker manifest create --amend "${DOCKER_ORG}/${BINARY}:${VERSION}" "${DOCKER_ORG}/${BINARY}:$(GOOS)-$(GOARCH)-${VERSION}" docker manifest annotate "${DOCKER_ORG}/${BINARY}:${VERSION}" "${DOCKER_ORG}/${BINARY}:$(GOOS)-$(GOARCH)-${VERSION}" --os=$(GOOS) --arch=$(GOARCH) # push the multi-arch manifest manifests: @echo "Push manifest for ${DOCKER_ORG}/${BINARY}:${VERSION}" docker manifest push "${DOCKER_ORG}/${BINARY}:${VERSION}" build: $(BINARY) $(BINARY): $(SOURCES) GOOS=$(GOOS) go build -ldflags "-X github.com/aquasecurity/kube-bench/cmd.KubeBenchVersion=$(KUBEBENCH_VERSION)" -o $(BINARY) . # builds the current dev docker version build-docker: docker build --build-arg BUILD_DATE=$(shell date -u +"%Y-%m-%dT%H:%M:%SZ") \ --build-arg VCS_REF=$(VERSION) \ --build-arg KUBEBENCH_VERSION=$(KUBEBENCH_VERSION) \ -t $(IMAGE_NAME) . # unit tests tests: GO111MODULE=on go test -short -race -timeout 30s -coverprofile=coverage.txt -covermode=atomic ./... # integration tests using kind integration-tests: build-docker GO111MODULE=on go test ./integration/... -v -tags integration -timeout 1200s -args -kubebenchImg=$(IMAGE_NAME) # creates a kind cluster to be used for development. HAS_KIND := $(shell command -v kind;) kind-test-cluster: ifndef HAS_KIND go get -u sigs.k8s.io/kind endif @if [ -z $$(kind get clusters | grep $(KIND_PROFILE)) ]; then\ echo "Could not find $(KIND_PROFILE) cluster. Creating...";\ kind create cluster --name $(KIND_PROFILE) --image kindest/node:v1.15.3 --wait 5m;\ fi # pushes the current dev version to the kind cluster. kind-push: build-docker kind load docker-image $(IMAGE_NAME) --name $(KIND_PROFILE) # runs the current version on kind using a job and follow logs kind-run: KUBECONFIG = "./kubeconfig.kube-bench" kind-run: ensure-stern kind-push sed "s/\$${VERSION}/$(VERSION)/" ./hack/kind.yaml > ./hack/kind.test.yaml kind get kubeconfig --name="$(KIND_PROFILE)" > $(KUBECONFIG) -KUBECONFIG=$(KUBECONFIG) \ kubectl delete job kube-bench KUBECONFIG=$(KUBECONFIG) \ kubectl apply -f ./hack/kind.test.yaml KUBECONFIG=$(KUBECONFIG) \ stern -l app=kube-bench --container kube-bench # ensures that stern is installed HAS_STERN := $(shell command -v stern;) ensure-stern: ifndef HAS_STERN curl -LO https://github.com/wercker/stern/releases/download/1.10.0/stern_$(BUILD_OS)_amd64 && \ chmod +rx ./stern_$(BUILD_OS)_amd64 && \ mv ./stern_$(BUILD_OS)_amd64 /usr/local/bin/stern endif