-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathMakefile
217 lines (170 loc) · 6.73 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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
# A Self-Documenting Makefile: http://marmelab.com/blog/2016/02/29/auto-documented-makefile.html
export PATH := $(abspath bin/):${PATH}
# Setting SHELL to bash allows bash commands to be executed by recipes.
# Options are set to exit when a recipe line exits non-zero or a piped command fails.
SHELL = /usr/bin/env bash -o pipefail
.SHELLFLAGS = -ec
# Default values for environment variables used in the Makefile
KUBECONFIG ?= $(HOME)/.kube/config
TEST_KIND_CLUSTER ?= vault-secrets-reloader
# Target image name
CONTAINER_IMAGE_REF = ghcr.io/bank-vaults/vault-secrets-reloader:dev
# Operator and Webhook image name
OPERATOR_VERSION ?= latest
WEBHOOK_VERSION ?= latest
##@ General
# Targets commented with ## will be visible in "make help" info.
# Comments marked with ##@ will be used as categories for a group of targets.
.PHONY: help
default: help
help: ## Display this help
@awk 'BEGIN {FS = ":.*##"; printf "\nUsage:\n make \033[36m<target>\033[0m\n"} /^[a-zA-Z_0-9-]+:.*?##/ { printf " \033[36m%-15s\033[0m %s\n", $$1, $$2 } /^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)
##@ Development
.PHONY: up-kind
up-kind: create-kind up ## Start kind development environment
.PHONY: create-kind
create-kind: ## Create kind cluster
$(KIND_BIN) create cluster --name $(TEST_KIND_CLUSTER)
.PHONY: up
up: ## Start development environment
$(HELM_BIN) upgrade --install vault-operator oci://ghcr.io/bank-vaults/helm-charts/vault-operator \
--set image.tag=latest \
--set image.bankVaultsTag=latest \
--wait
kubectl create namespace bank-vaults-infra --dry-run=client -o yaml | kubectl apply -f -
kubectl apply -f $(shell pwd)/e2e/deploy/vault/
sleep 60
$(HELM_BIN) upgrade --install secrets-webhook oci://ghcr.io/bank-vaults/helm-charts/secrets-webhook \
--set replicaCount=1 \
--set image.tag=latest \
--set image.pullPolicy=IfNotPresent \
--set podsFailurePolicy=Fail \
--set secretInit.tag=latest \
--namespace bank-vaults-infra
.PHONY: down
down: ## Destroy kind development environment
$(KIND_BIN) delete cluster --name $(TEST_KIND_CLUSTER)
.PHONY: run
run: ## Run manager from your host
go run main.go -log-level=debug -collector-sync-period=30s -reloader-run-period=1m
##@ Build
.PHONY: build
build: ## Build manager binary
@mkdir -p build
go build -race -o build/vault-secrets-reloader .
.PHONY: artifacts
artifacts: container-image helm-chart ## Build artifacts
.PHONY: container-image
container-image: ## Build docker image
docker build -t ${CONTAINER_IMAGE_REF} .
.PHONY: helm-chart
helm-chart: ## Build Helm chart
@mkdir -p build
helm package -d build/ deploy/charts/vault-secrets-reloader
##@ Checks
.PHONY: check
check: test lint ## Run lint checks and tests
.PHONY: test
test: ## Run tests
go clean -testcache
go test -race -v ./...
.PHONY: test-e2e
test-e2e: ## Run e2e tests
go clean -testcache
go test -race -v -timeout 900s -tags e2e ./e2e
.PHONY: test-e2e-local
test-e2e-local: container-image ## Run e2e tests locally
go clean -testcache
LOAD_IMAGE=${CONTAINER_IMAGE_REF} RELOADER_VERSION=dev OPERATOR_VERSION=$(OPERATOR_VERSION) WEBHOOK_VERSION=$(WEBHOOK_VERSION) LOG_VERBOSE=true ${MAKE} test-e2e
.PHONY: lint
lint: lint-go lint-helm lint-docker lint-yaml ## Run lint checks
.PHONY: lint-go
lint-go: # Run golang lint check
$(GOLANGCI_LINT_BIN) run $(if ${CI},--out-format colored-line-number,)
.PHONY: lint-helm
lint-helm: # Run helm lint check
$(HELM_BIN) lint deploy/charts/vault-secrets-reloader
.PHONY: lint-docker
lint-docker: # Run Dockerfile lint check
$(HADOLINT_BIN) Dockerfile
.PHONY: lint-yaml
lint-yaml:
$(YAMLLINT_BIN) $(if ${CI},-f github,) --no-warnings .
.PHONY: fmt
fmt: ## Run go fmt against code
$(GOLANGCI_LINT_BIN) run --fix
.PHONY: license-check
license-check: ## Run license check
$(LICENSEI_BIN) check
$(LICENSEI_BIN) header
##@ Autogeneration
.PHONY: generate
generate: gen-helm-docs ## Generate manifests, code, and docs resources
.PHONY: gen-helm-docs
gen-helm-docs: ## Generate Helm chart documentation
$(HELM_DOCS_BIN) -s file -c deploy/charts/ -t README.md.gotmpl
##@ Deployment
.PHONY: deploy-kind
deploy-kind: upload-kind deploy ## Deploy Reloder controller resources to the kind cluster
.PHONY: upload-kind
upload-kind:
$(KIND_BIN) load docker-image ${CONTAINER_IMAGE_REF} --name $(TEST_KIND_CLUSTER) ## Load docker image to kind cluster
.PHONY: deploy
deploy: ## Deploy Reloader controller resources to the K8s cluster
kubectl create namespace bank-vaults-infra --dry-run=client -o yaml | kubectl apply -f -
$(HELM_BIN) upgrade --install vault-secrets-reloader deploy/charts/vault-secrets-reloader \
--set image.tag=dev \
--set collectorSyncPeriod=30s \
--set reloaderRunPeriod=1m \
--set env.VAULT_ROLE=reloader \
--set env.VAULT_ADDR=https://vault.default.svc.cluster.local:8200 \
--set env.VAULT_TLS_SECRET=vault-tls \
--set env.VAULT_TLS_SECRET_NS=bank-vaults-infra \
--namespace bank-vaults-infra
.PHONY: undeploy
undeploy: ## Clean manager resources from the K8s cluster.
$(HELM_BIN) uninstall vault-secrets-reloader --namespace bank-vaults-infra
##@ Dependencies
deps: bin/golangci-lint bin/licensei bin/kind bin/helm bin/helm-docs
deps: ## Install dependencies
# Dependency versions
GOLANGCI_LINT_VERSION = 1.62.2
LICENSEI_VERSION = 0.9.0
KIND_VERSION = 0.25.0
HELM_VERSION = 3.16.3
HELM_DOCS_VERSION = 1.14.2
# Dependency binaries
GOLANGCI_LINT_BIN := golangci-lint
LICENSEI_BIN := licensei
KIND_BIN := kind
HELM_BIN := helm
HELM_DOCS_BIN := helm-docs
# TODO: add support for hadolint and yamllint dependencies
HADOLINT_BIN := hadolint
YAMLLINT_BIN := yamllint
# If we have "bin" dir, use those binaries instead
ifneq ($(wildcard ./bin/.),)
GOLANGCI_LINT_BIN := bin/$(GOLANGCI_LINT_BIN)
LICENSEI_BIN := bin/$(LICENSEI_BIN)
KIND_BIN := bin/$(KIND_BIN)
HELM_BIN := bin/$(HELM_BIN)
HELM_DOCS_BIN := bin/$(HELM_DOCS_BIN)
endif
bin/golangci-lint:
@mkdir -p bin
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | bash -s -- v${GOLANGCI_LINT_VERSION}
bin/licensei:
@mkdir -p bin
curl -sfL https://raw.githubusercontent.com/goph/licensei/master/install.sh | bash -s -- v${LICENSEI_VERSION}
bin/kind:
@mkdir -p bin
curl -Lo bin/kind https://kind.sigs.k8s.io/dl/v${KIND_VERSION}/kind-$(shell uname -s | tr '[:upper:]' '[:lower:]')-$(shell uname -m | sed -e "s/aarch64/arm64/; s/x86_64/amd64/")
@chmod +x bin/kind
bin/helm:
@mkdir -p bin
curl https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 | USE_SUDO=false HELM_INSTALL_DIR=bin DESIRED_VERSION=v$(HELM_VERSION) bash
@chmod +x bin/helm
bin/helm-docs:
@mkdir -p bin
curl -L https://github.com/norwoodj/helm-docs/releases/download/v${HELM_DOCS_VERSION}/helm-docs_${HELM_DOCS_VERSION}_$(shell uname)_x86_64.tar.gz | tar -zOxf - helm-docs > ./bin/helm-docs
@chmod +x bin/helm-docs