This repository has been archived by the owner on Oct 15, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 8
/
Makefile
259 lines (208 loc) · 8.83 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
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
SOURCES_DIRS = cmd pkg
SOURCES_DIRS_GO = ./pkg/... ./cmd/...
SOURCES_API_DIR = ./pkg/apis/kubic
GO := GO111MODULE=on GO15VENDOREXPERIMENT=1 go
GO_NOMOD := GO111MODULE=off go
GO_VERSION := $(shell $(GO) version | sed -e 's/^[^0-9.]*\([0-9.]*\).*/\1/')
GOLINT := ${GOPATH}/bin/golint
# go source files, ignore vendor directory
REGS_OPER_SRCS = $(shell find $(SOURCES_DIRS) -type f -name '*.go' -not -path "*generated*")
REGS_OPER_MAIN_SRCS = $(shell find $(SOURCES_DIRS) -type f -name '*.go' -not -path "*_test.go")
REGS_OPER_GEN_SRCS = $(shell grep -l -r "//go:generate" $(SOURCES_DIRS) 2>/dev/null)
REGS_OPER_CRD_TYPES_SRCS = $(shell find $(SOURCES_API_DIR) -type f -name "*_types.go")
DEEPCOPY_FILENAME := zz_generated.deepcopy.go
# the list of all the deepcopy.go files we are going to generate
DEEPCOPY_GENERATED_FILES := $(foreach file,$(REGS_OPER_GEN_SRCS),$(dir $(file))$(DEEPCOPY_FILENAME))
DEEPCOPY_GENERATOR := ${GOPATH}/bin/deepcopy-gen
DEEPCOPY_DEPS := ${GOPATH}/src/k8s.io/apimachinery ${GOPATH}/src/k8s.io/api
REGS_OPER_EXE = cmd/registries-operator/registries-operator
REGS_OPER_MAIN = cmd/registries-operator/main.go
.DEFAULT_GOAL: $(REGS_OPER_EXE)
IMAGE_BASENAME = registries-operator
IMAGE_NAME = opensuse/$(IMAGE_BASENAME)
IMAGE_TAR_GZ = $(IMAGE_BASENAME)-latest.tar.gz
IMAGE_DEPS = $(REGS_OPER_EXE) Dockerfile
# should be non-empty when these exes are installed
DEP_EXE := $(shell command -v dep 2> /dev/null)
KUSTOMIZE_EXE := $(shell command -v kustomize 2> /dev/null)
# These will be provided to the target
REGS_OPER_VERSION := 1.0.0
REGS_OPER_BUILD := `git rev-parse HEAD 2>/dev/null`
# Use linker flags to provide version/build settings to the target
REGS_OPER_LDFLAGS = -ldflags "-X=main.Version=$(REGS_OPER_VERSION) -X=main.Build=$(REGS_OPER_BUILD)"
# sudo command (and version passing env vars)
SUDO = sudo
SUDO_E = $(SUDO) -E
# the default kubeconfig program generated by kubeadm (used for running things locally)
KUBECONFIG = /etc/kubernetes/admin.conf
# the deployment manifest for the operator
REGS_DEPLOY = deployments/registries-operator-full.yaml
# the kubebuilder generator
CONTROLLER_GEN := sigs.k8s.io/controller-tools/cmd/controller-gen
CONTROLLER_GEN_EXE := $(shell basename $(CONTROLLER_GEN))
# CONTROLLER_GEN_RBAC_NAME = ":controller"
# increase to 8 for detailed kubeadm logs...
# Example: make local-run VERBOSE_LEVEL=8
VERBOSE_LEVEL = 5
CONTAINER_VOLUMES = \
-v /sys/fs/cgroup:/sys/fs/cgroup \
-v /var/run:/var/run
#############################################################
# Build targets
#############################################################
all: $(REGS_OPER_EXE)
$(DEEPCOPY_DEPS):
@[ -n "${GOPATH}" ] || ( echo "GOPATH not defined" ; exit 1 ; )
@[ -d "${GOPATH}/bin" ] || ( echo "${GOPATH}/bin does not exist" ; exit 1 ; )
@echo ">>> Getting deepcopy dependencies..."
-@$(GO_NOMOD) get -u k8s.io/apimachinery
-@$(GO_NOMOD) get -u k8s.io/api
# NOTE: deepcopy-gen doesn't support go1.11's modules, so we must 'go get' it
$(DEEPCOPY_GENERATOR): $(DEEPCOPY_DEPS)
@echo ">>> Getting deepcopy-gen (for $(DEEPCOPY_GENERATOR))"
-@$(GO_NOMOD) get -u k8s.io/code-generator/cmd/deepcopy-gen
define _CREATE_DEEPCOPY_TARGET
$(1): $(DEEPCOPY_GENERATOR) $(shell grep -l "//go:generate" $(dir $1)*.go 2>/dev/null)
@echo ">>> Updating deepcopy files in $(dir $1)"
$(GO) generate -x $(shell grep -l "//go:generate" $(dir $1)*.go 2>/dev/null)
endef
# Use macro to generate targets for all the DEEPCOPY_GENERATED_FILES files
$(foreach file,$(DEEPCOPY_GENERATED_FILES),$(eval $(call _CREATE_DEEPCOPY_TARGET,$(file))))
clean-generated:
rm -f $(DEEPCOPY_GENERATED_FILES)
generate: $(DEEPCOPY_GENERATOR) $(DEEPCOPY_GENERATED_FILES)
.PHONY: generate
# Create a new CRD object XXXXX with:
# kubebuilder create api --namespaced=false --group kubic --version v1beta1 --kind XXXXX
kustomize-exe:
ifndef KUSTOMIZE_EXE
@echo ">>> kustomize does not seem to be installed. installing kustomize..."
$(GO) get sigs.k8s.io/kustomize
endif
#
# NOTE: we are currently not using the RBAC rules generated by kubebuilder:
# we are just assigning the "cluster-admin" role to the manager (as we
# must generate ClusterRoles/ClusterRoleBindings)
# TODO: investigate if we can reduce these privileges...
#
# manifests-rbac:
# @echo ">>> Creating RBAC manifests..."
# @rm -rf config/rbac/*.yaml
# @$(CONTROLLER_GEN_EXE) rbac --name $(CONTROLLER_GEN_RBAC_NAME)
#
manifests-crd: $(REGS_OPER_CRD_TYPES_SRCS)
@echo ">>> Getting $(CONTROLLER_GEN_EXE)..."
@$(GO_NOMOD) get $(CONTROLLER_GEN)
@echo ">>> Creating CRDs manifests..."
@rm -rf config/crds/*.yaml
@$(CONTROLLER_GEN_EXE) crd --domain "opensuse.org"
$(REGS_DEPLOY): kustomize-exe manifests-crd
@echo ">>> Collecting all the manifests for generating $(REGS_DEPLOY)..."
@rm -f $(REGS_DEPLOY)
@echo "#" >> $(REGS_DEPLOY)
@echo "# DO NOT EDIT! Generated automatically with 'make $(REGS_DEPLOY)'" >> $(REGS_DEPLOY)
@echo "# from files in 'config/*'" >> $(REGS_DEPLOY)
@echo "#" >> $(REGS_DEPLOY)
@for i in config/sas/*.yaml config/crds/*.yaml ; do \
echo -e "\n---" >> $(REGS_DEPLOY) ; \
cat $$i >> $(REGS_DEPLOY) ; \
done
@echo -e "\n---" >> $(REGS_DEPLOY)
@kustomize build config/default >> $(REGS_DEPLOY)
# Generate manifests e.g. CRD, RBAC etc.
manifests: $(REGS_DEPLOY)
$(REGS_OPER_EXE): $(REGS_OPER_MAIN_SRCS) $(DEEPCOPY_GENERATED_FILES)
@echo ">>> Building $(REGS_OPER_EXE)..."
$(GO) build $(REGS_OPER_LDFLAGS) -o $(REGS_OPER_EXE) $(REGS_OPER_MAIN)
.PHONY: fmt
fmt: $(REGS_OPER_SRCS)
@echo ">>> Reformatting code"
@$(GO) fmt $(SOURCES_DIRS_GO)
.PHONY: simplify
simplify:
@gofmt -s -l -w $(REGS_OPER_SRCS)
$(GOLINT):
-@$(GO_NOMOD) get golang.org/x/lint/golint
.PHONY: check
check: $(GOLINT)
@test -z $(shell gofmt -l $(REGS_OPER_MAIN) | tee /dev/stderr) || echo "[WARN] Fix formatting issues with 'make fmt'"
@for d in $$($(GO) list ./... | grep -v /vendor/); do $(GOLINT) $${d}; done
@$(GO) tool vet ${REGS_OPER_SRCS}
.PHONY: test
test:
@$(GO) test -short -v $(SOURCES_DIRS_GO) -coverprofile cover.out
.PHONY: integration
integration:
@$(GO) test -v $(SOURCES_DIRS_GO) -coverprofile cover.out
.PHONY: check
clean: docker-image-clean
rm -f $(REGS_OPER_EXE)
rm -rf `find . -name zz_generated.deepcopy.go`
#############################################################
# Some simple run targets
# (for testing things locally)
#############################################################
# assuming the k8s cluster is accessed with $(KUBECONFIG),
# deploy the registries-operator manifest file in this cluster.
local-deploy: $(REGS_DEPLOY) docker-image-local
@echo ">>> (Re)deploying..."
@[ -r $(KUBECONFIG) ] || $(SUDO_E) chmod 644 $(KUBECONFIG)
@echo ">>> Deleting any previous resources..."
-@kubectl get ldapconnectors -o jsonpath="{..metadata.name}" | \
xargs -r kubectl delete --all=true ldapconnector 2>/dev/null
-@kubectl get dexconfigurations -o jsonpath="{..metadata.name}" | \
xargs -r kubectl delete --all=true dexconfiguration 2>/dev/null
@sleep 30
-@kubectl delete --all=true --cascade=true -f $(REGS_DEPLOY) 2>/dev/null
@echo ">>> Regenerating manifests..."
@make manifests
@echo ">>> Loading manifests..."
kubectl apply --kubeconfig $(KUBECONFIG) -f $(REGS_DEPLOY)
clean-local-deploy:
@make manifests
@echo ">>> Uninstalling manifests..."
kubectl delete --kubeconfig $(KUBECONFIG) -f $(REGS_DEPLOY)
# Usage:
# - Run it locally:
# make local-run VERBOSE_LEVEL=5
# - Start a Deployment with the manager:
# make local-run EXTRA_ARGS="--"
#
local-run: $(REGS_OPER_EXE)
[ -r $(KUBECONFIG) ] || $(SUDO_E) chmod 644 $(KUBECONFIG)
@echo ">>> Running $(REGS_OPER_EXE) as _root_"
$(REGS_OPER_EXE) manager \
-v $(VERBOSE_LEVEL) \
--kubeconfig $(KUBECONFIG) \
$(EXTRA_ARGS)
docker-run: $(IMAGE_TAR_GZ)
@echo ">>> Running $(IMAGE_NAME):latest in the local Docker"
docker run -it --rm \
--privileged=true \
--net=host \
--security-opt seccomp:unconfined \
--cap-add=SYS_ADMIN \
--name=$(IMAGE_BASENAME) \
$(CONTAINER_VOLUMES) \
$(IMAGE_NAME):latest $(EXTRA_ARGS)
local-$(IMAGE_TAR_GZ): $(REGS_OPER_EXE)
@echo ">>> Creating Docker image (Local build)..."
docker build -f Dockerfile.local \
--build-arg BUILT_EXE=$(REGS_OPER_EXE) \
-t $(IMAGE_NAME):latest .
@echo ">>> Creating tar for image (Local build)"
docker save $(IMAGE_NAME):latest | gzip > local-$(IMAGE_TAR_GZ)
docker-image-local: local-$(IMAGE_TAR_GZ)
$(IMAGE_TAR_GZ):
@echo ">>> Creating Docker image..."
docker build -t $(IMAGE_NAME):latest .
@echo ">>> Creating tar for image..."
docker save $(IMAGE_NAME):latest | gzip > $(IMAGE_TAR_GZ)
docker-image: $(IMAGE_TAR_GZ)
docker-image-clean:
-[ -f $(IMAGE_TAR_GZ) ] && docker rmi $(IMAGE_NAME)
rm -f $(IMAGE_TAR_GZ)
#############################################################
# Other stuff
#############################################################
-include Makefile.local