-
Notifications
You must be signed in to change notification settings - Fork 4
/
Makefile
96 lines (78 loc) · 3.62 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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
ENSURE_GARDENER_MOD := $(shell go get github.com/gardener/gardener@$$(go list -m -f "{{.Version}}" github.com/gardener/gardener))
GARDENER_HACK_DIR := $(shell go list -m -f "{{.Dir}}" github.com/gardener/gardener)/hack
IMAGE_TAG := $(or ${GITHUB_TAG_NAME}, latest)
REGISTRY := ghcr.io/metal-stack
IMAGE_PREFIX := $(REGISTRY)
REPO_ROOT := $(shell dirname "$(realpath $(lastword $(MAKEFILE_LIST)))")
HACK_DIR := $(REPO_ROOT)/hack
HOSTNAME := $(shell hostname)
LD_FLAGS := "-w -X github.com/metal-stack/gardener-extension-audit/pkg/version.Version=$(IMAGE_TAG)"
VERIFY := true
LEADER_ELECTION := false
IGNORE_OPERATION_ANNOTATION := false
WEBHOOK_CONFIG_URL := localhost
GOLANGCI_LINT_VERSION := v1.61.0
GO_VERSION := 1.23
ifeq ($(CI),true)
DOCKER_TTY_ARG=""
else
DOCKER_TTY_ARG=t
endif
export GO111MODULE := on
TOOLS_DIR := $(HACK_DIR)/tools
include $(GARDENER_HACK_DIR)/tools.mk
#################################################################
# Rules related to binary build, Docker image build and release #
#################################################################
.PHONY: tidy
tidy:
@GO111MODULE=on go mod tidy
@mkdir -p $(REPO_ROOT)/.ci/hack && cp $(GARDENER_HACK_DIR)/.ci/* $(REPO_ROOT)/.ci/hack/ && chmod +xw $(REPO_ROOT)/.ci/hack/*
.PHONY: build
build:
go build -ldflags $(LD_FLAGS) -tags netgo -o bin/gardener-extension-audit ./cmd/gardener-extension-audit
.PHONY: install
install: tidy $(HELM)
@LD_FLAGS="-w -X github.com/gardener/$(EXTENSION_PREFIX)-$(NAME)/pkg/version.Version=$(VERSION)" \
bash $(GARDENER_HACK_DIR)/install.sh ./...
.PHONY: docker-image
docker-image:
@docker build --no-cache \
--build-arg VERIFY=$(VERIFY) \
--tag $(IMAGE_PREFIX)/gardener-extension-audit:$(IMAGE_TAG) \
--file Dockerfile --memory 6g .
.PHONY: docker-push
docker-push:
@docker push $(IMAGE_PREFIX)/gardener-extension-audit:$(IMAGE_TAG)
#####################################################################
# Rules for verification, formatting, linting, testing and cleaning #
#####################################################################
.PHONY: clean
clean:
@$(shell find ./example -type f -name "controller-registration.yaml" -exec rm '{}' \;)
@bash $(GARDENER_HACK_DIR)/clean.sh ./cmd/... ./pkg/...
.PHONY: check-generate
check-generate:
@$(REPO_ROOT)/vendor/github.com/gardener/gardener/hack/check-generate.sh $(REPO_ROOT)
.PHONY: generate
generate: $(VGOPATH) $(HELM) $(YQ)
echo $(shell git -c safe.directory=/go/src/github.com/metal-stack/gardener-extension-audit describe --abbrev=0 --tags) > VERSION
@REPO_ROOT=$(REPO_ROOT) VGOPATH=$(VGOPATH) GARDENER_HACK_DIR=$(GARDENER_HACK_DIR) bash $(GARDENER_HACK_DIR)/generate-sequential.sh ./charts/... ./cmd/... ./pkg/...
.PHONY: generate-in-docker
generate-in-docker: tidy install $(HELM) $(YQ)
docker run --rm -i$(DOCKER_TTY_ARG) -v $(PWD):/go/src/github.com/metal-stack/gardener-extension-audit golang:$(GO_VERSION) \
sh -c "cd /go/src/github.com/metal-stack/gardener-extension-audit \
&& make generate \
&& chown -R $(shell id -u):$(shell id -g) ."
.PHONY: test
test:
go test -v ./...
.PHONY: push-to-gardener-local
push-to-gardener-local:
CGO_ENABLED=1 go build \
-ldflags "-extldflags '-static -s -w'" \
-tags 'osusergo netgo static_build' \
-o bin/gardener-extension-audit \
./cmd/gardener-extension-audit
docker build -f Dockerfile.dev -t ghcr.io/metal-stack/gardener-extension-audit:latest .
kind --name gardener-local load docker-image ghcr.io/metal-stack/gardener-extension-audit:latest