forked from rancher/security-scan
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
66 lines (52 loc) · 2.32 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
# To avoid poluting the Makefile, versions and checksums for tooling and
# dependencies are defined at hack/make/deps.mk.
include hack/make/deps.mk
# Include logic that can be reused across projects.
include hack/make/build.mk
include hack/make/tools.mk
# Define target platforms, image builder and the fully qualified image name.
TARGET_PLATFORMS ?= linux/amd64,linux/arm64
REPO ?= rancher
IMAGE = $(REPO)/security-scan:$(TAG)
TARGET_BIN ?= build/bin/kb-summarizer
ARCH ?= $(shell docker info --format '{{.ClientInfo.Arch}}')
BUILD_ACTION = --load
.DEFAULT_GOAL := ci
ci: build test validate e2e ## run the targets needed to validate a PR in CI.
clean: ## clean up project.
rm -rf bin build
test: ## run unit tests.
@echo "Running tests"
go test -race -cover ./...
.PHONY: build
build: # build project and output binary to TARGET_BIN.
CGO_ENABLED=0 $(GO) build -trimpath -ldflags "-X main.VERSION=$(VERSION) $(LINKFLAGS)" -o $(TARGET_BIN) ./cmd/kb-summarizer/
$(TARGET_BIN) --version
md5sum $(TARGET_BIN)
image-test: buildx-machine ## build the container image for all target architecures.
# Instead of loading image, target all platforms, effectivelly testing
# the build for the target architectures.
$(MAKE) image-build BUILD_ACTION="--platform=$(TARGET_PLATFORMS)"
.PHONY: image-build
image-build: buildx-machine ## build (and load) the container image targeting the current platform.
$(IMAGE_BUILDER) build -f package/Dockerfile \
--builder $(MACHINE) $(IMAGE_ARGS) \
--build-arg VERSION=$(VERSION) -t "$(IMAGE)" $(BUILD_ACTION) .
@echo "Built $(IMAGE)"
.PHONY: image-push
image-push: buildx-machine ## build the container image targeting all platforms defined by TARGET_PLATFORMS and push to a registry.
$(IMAGE_BUILDER) build -f package/Dockerfile \
--builder $(MACHINE) $(IMAGE_ARGS) $(IID_FILE_FLAG) $(BUILDX_ARGS) \
--build-arg VERSION=$(VERSION) --platform=$(TARGET_PLATFORMS) -t "$(IMAGE)" --push .
@echo "Pushed $(IMAGE)"
e2e: $(KIND) image-build ## run E2E tests.
@KUBERNETES_VERSION=$(KUBERNETES_VERSION) IMAGE=$(IMAGE) \
SONOBUOY_IMAGE=$(SONOBUOY_IMAGE) ARCH=$(ARCH) \
./hack/e2e
validate: validate-go validate-yaml ## run validation checks.
validate-yaml: yamllint $(KUBE_BENCH)
@PATH=$(PATH):$(TOOLS_BIN) \
./hack/validate-yaml
validate-go: $(GOIMPORTS) $(GOLINT)
@PATH=$(PATH):$(TOOLS_BIN) \
./hack/validate-go