2017-06-19 20:17:19 +00:00
|
|
|
SOURCES := $(shell find . -name '*.go')
|
2017-06-20 08:38:15 +00:00
|
|
|
BINARY := kube-bench
|
2019-03-07 17:02:43 +00:00
|
|
|
DOCKER_REGISTRY ?= aquasec
|
|
|
|
VERSION ?= $(shell git rev-parse --short=7 HEAD)
|
2019-06-12 08:41:09 +00:00
|
|
|
KUBEBENCH_VERSION ?= $(shell git describe --tags --abbrev=0)
|
2019-03-07 17:02:43 +00:00
|
|
|
IMAGE_NAME ?= $(DOCKER_REGISTRY)/$(BINARY):$(VERSION)
|
2019-10-12 22:53:17 +00:00
|
|
|
TARGET_OS ?= linux
|
2019-03-07 17:02:43 +00:00
|
|
|
BUILD_OS := linux
|
|
|
|
uname := $(shell uname -s)
|
|
|
|
|
|
|
|
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: kube-bench
|
2017-06-19 20:17:19 +00:00
|
|
|
|
2017-06-20 08:38:15 +00:00
|
|
|
$(BINARY): $(SOURCES)
|
2019-06-12 08:41:09 +00:00
|
|
|
GOOS=$(TARGET_OS) go build -ldflags "-X github.com/aquasecurity/kube-bench/cmd.KubeBenchVersion=$(KUBEBENCH_VERSION)" -o $(BINARY) .
|
2017-06-19 20:17:19 +00:00
|
|
|
|
2019-03-07 17:02:43 +00:00
|
|
|
# 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=$(shell git rev-parse --short HEAD) \
|
2019-10-12 22:53:17 +00:00
|
|
|
--build-arg KUBEBENCH_VERSION=$(KUBEBENCH_VERSION) \
|
2019-03-07 17:02:43 +00:00
|
|
|
-t $(IMAGE_NAME) .
|
|
|
|
|
|
|
|
tests:
|
2019-07-16 18:11:51 +00:00
|
|
|
GO111MODULE=on go test -v -short -race -timeout 30s -coverprofile=coverage.txt -covermode=atomic ./...
|
2019-03-07 17:02:43 +00:00
|
|
|
|
|
|
|
# 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...";\
|
2019-09-03 12:42:07 +00:00
|
|
|
kind create cluster --name $(KIND_PROFILE) --image kindest/node:v1.15.3 --wait 5m;\
|
2019-03-07 17:02:43 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
# pushses the current dev version to the kind cluster.
|
|
|
|
kind-push:
|
|
|
|
docker save $(IMAGE_NAME) -o kube-bench.tar.gz; \
|
|
|
|
docker cp kube-bench.tar.gz $(KIND_CONTAINER_NAME):/kube-bench.tar.gz; \
|
|
|
|
docker exec $(KIND_CONTAINER_NAME) docker load -i /kube-bench.tar.gz;
|
|
|
|
-rm -f kube-bench.tar.gz
|
|
|
|
|
|
|
|
# runs the current version on kind using a job and follow logs
|
|
|
|
kind-run: KUBECONFIG = "$(shell kind get kubeconfig-path --name="$(KIND_PROFILE)")"
|
|
|
|
kind-run: ensure-stern
|
|
|
|
sed "s/\$${VERSION}/$(VERSION)/" ./hack/kind.yaml > ./hack/kind.test.yaml
|
|
|
|
-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
|