forked from kiali/kiali
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
287 lines (231 loc) · 10.1 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
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
# Needed for Travis - it won't like the version regex check otherwise
SHELL=/bin/bash
# Identifies the current build.
# These will be embedded in the app and displayed when it starts.
VERSION ?= v0.19.0-SNAPSHOT
COMMIT_HASH ?= $(shell git rev-parse HEAD)
# Indicates which version of the UI console is to be embedded
# in the container image. If "local" the CONSOLE_LOCAL_DIR is
# where the UI project has been git cloned and has its
# content built in its build/ subdirectory.
# WARNING: If you have previously run the 'docker' target but
# later want to change the CONSOLE_VERSION then you must run
# the 'clean' target first before re-running the 'docker' target.
CONSOLE_VERSION ?= latest
CONSOLE_LOCAL_DIR ?= ../../../../../kiali-ui
# Version label is used in the OpenShift/K8S resources to identify
# their specific instances. Kiali resources will have labels of
# "app: kiali" and "version: ${VERSION_LABEL}"
# The default is the VERSION itself.
VERSION_LABEL ?= ${VERSION}
# The minimum Go version that must be used to build the app.
GO_VERSION_KIALI = 1.8.3
# Identifies the container image that will be built and deployed.
CONTAINER_NAME ?= kiali/kiali
CONTAINER_VERSION ?= dev
# These two vars allow Jenkins to override values.
DOCKER_NAME ?= ${CONTAINER_NAME}
QUAY_NAME ?= quay.io/${CONTAINER_NAME}
DOCKER_TAG = ${DOCKER_NAME}:${CONTAINER_VERSION}
QUAY_TAG = ${QUAY_NAME}:${CONTAINER_VERSION}
# Declares the namespace where the objects are to be deployed.
# For OpenShift, this is the name of the project.
NAMESPACE ?= istio-system
# Use default go1.8 GOPATH if it isn't user defined
GOPATH ?= ${HOME}/go
# Environment variables set when running the Go compiler.
GO_BUILD_ENVVARS = \
GOOS=linux \
GOARCH=amd64 \
CGO_ENABLED=0 \
.PHONY: help
all: help
help: Makefile
@echo
@echo "Choose a make target to run:"
@echo
@sed -n 's/^##//p' $< | column -t -s ':' | sed -e 's/^/ /'
@echo
## clean: Clean ${GOPATH}/bin/kiali, ${GOPATH}/pkg/*, _output/docker and the kilai binary
clean:
@echo Cleaning...
@rm -f kiali
@rm -rf ${GOPATH}/bin/kiali
@rm -rf ${GOPATH}/pkg/*
@rm -rf _output/docker
## clean-all: Runs `make clean` internally and remove the _output dir
clean-all: clean
@rm -rf _output
## git-init: Set the hooks under ./git/hooks
git-init:
@echo Setting Git Hooks
cp hack/hooks/* .git/hooks
## go-check: Check if the go version installed is supported by Kiali
go-check:
@hack/check_go_version.sh "${GO_VERSION_KIALI}"
## build: Runs `make go-check` internally and build Kiali binary
build: go-check
@echo Building...
${GO_BUILD_ENVVARS} go build \
-o ${GOPATH}/bin/kiali -ldflags "-X main.version=${VERSION} -X main.commitHash=${COMMIT_HASH}"
## install: Install missing dependencies. Runs `go install` internally
install:
@echo Installing...
${GO_BUILD_ENVVARS} go install \
-ldflags "-X main.version=${VERSION} -X main.commitHash=${COMMIT_HASH}"
## format: Format all the files excluding vendor. Runs `gofmt` internally
format:
@# Exclude more paths find . \( -path './vendor' -o -path <new_path_to_exclude> \) -prune -o -type f -iname '*.go' -print
@for gofile in $$(find . -path './vendor' -prune -o -type f -iname '*.go' -print); do \
gofmt -w $$gofile; \
done
## build-test: Run tests and installing test dependencies, excluding third party tests under vendor. Runs `go test -i` internally
build-test:
@echo Building and installing test dependencies to help speed up test runs.
go test -i $(shell go list ./... | grep -v -e /vendor/)
## test: Run tests, excluding third party tests under vendor. Runs `go test` internally
test:
@echo Running tests, excluding third party tests under vendor
go test $(shell go list ./... | grep -v -e /vendor/)
## test-debug: Run tests in debug mode, excluding third party tests under vendor. Runs `go test -v` internally
test-debug:
@echo Running tests in debug mode, excluding third party tests under vendor
go test -v $(shell go list ./... | grep -v -e /vendor/)
## test-race: Run tests with race detection, excluding third party tests under vendor. Runs `go test -race` internally
test-race:
@echo Running tests with race detection, excluding third party tests under vendor
go test -race $(shell go list ./... | grep -v -e /vendor/)
## test-e2e-setup: Setup Python environment for running test suite
test-e2e-setup:
@echo Setting up E2E tests
cd tests/e2e && ./setup.sh
## test-e2e: Run E2E test suite
test-e2e:
@echo Running E2E tests
cd tests/e2e && source .kiali-e2e/bin/activate && pytest -s tests/
## run: Run kiali binary
run:
@echo Running...
@${GOPATH}/bin/kiali -v 4 -config config.yaml
#
# dep targets - dependency management
#
## dep-install: Install Glide.
dep-install:
@echo Installing Glide itself
@mkdir -p ${GOPATH}/bin
# We want to pin on a specific version
# @curl https://glide.sh/get | sh
@curl https://glide.sh/get | awk '{gsub("get TAG https://glide.sh/version", "TAG=v0.13.1", $$0); print}' | sh
## dep-update: Updating dependencies and storing in vendor directory. Runs `glide update` internally
dep-update:
@echo Updating dependencies and storing in vendor directory
@glide update --strip-vendor
#
# Swagger Documentation
#
## swagger-install: Install swagger. Runs `go get swagger` internally
swagger-install:
go get -u github.com/go-swagger/go-swagger/cmd/swagger
## swagger-validate: Validate that swagger.json is correctly. Runs `swagger validate` internally
swagger-validate:
@swagger validate ./swagger.json
## swagger-gen: Generate that swagger.json from Code. Runs `swagger generate` internally
swagger-gen:
@swagger generate spec -o ./swagger.json
## swagger-serve: Serve the swagger.json in a website in local. Runs `swagger serve` internally
swagger-serve: swagger-validate
@swagger serve ./swagger.json
## swagger-travis: Check that swagger.json is the correct one
swagger-travis: swagger-validate
@swagger generate spec -o ./swagger_copy.json
@cmp -s swagger.json swagger_copy.json; \
RETVAL=$$?; \
if [ $$RETVAL -ne 0 ]; then \
echo "SWAGGER FILE IS NOT CORRECT"; exit 1; \
fi
#
# cloud targets - building images and deploying
#
.prepare-docker-image-files:
@CONSOLE_VERSION=${CONSOLE_VERSION} CONSOLE_LOCAL_DIR=${CONSOLE_LOCAL_DIR} deploy/get-console.sh
@echo Preparing container image files...
@mkdir -p _output/docker
@cp -r deploy/docker/* _output/docker
@cp ${GOPATH}/bin/kiali _output/docker
## docker-build-kiali: Build Kiali container image into local docker daemon.
docker-build-kiali: .prepare-docker-image-files
@echo Building container image for Kiali into local docker daemon...
docker build -t ${DOCKER_TAG} _output/docker
docker tag ${DOCKER_TAG} ${QUAY_TAG}
## docker-build-operator: Build Kiali operator container image into local docker daemon.
docker-build-operator:
@echo Building container image for Kiali operator into local docker daemon...
OPERATOR_IMAGE_VERSION=${CONTAINER_VERSION} $(MAKE) -C operator operator-build
## docker-build: Build Kiali and Kiali operator container images into local docker daemon.
docker-build: docker-build-kiali docker-build-operator
.prepare-minikube:
@minikube addons list | grep -q "ingress: enabled" ; \
if [ "$$?" != "0" ]; then \
echo "Enabling ingress support to minikube" ; \
minikube addons enable ingress ; \
fi
@grep -q kiali /etc/hosts ; \
if [ "$$?" != "0" ]; then \
echo "/etc/hosts should have kiali so you can access the ingress"; \
fi
## minikube-docker: Build container image into minikube docker daemon.
minikube-docker: .prepare-minikube .prepare-docker-image-files
@echo Building container image into minikube docker daemon...
@eval $$(minikube docker-env) ; \
docker build -t ${DOCKER_TAG} _output/docker
docker tag ${DOCKER_TAG} ${QUAY_TAG}
OPERATOR_IMAGE_VERSION=${CONTAINER_VERSION} $(MAKE) -C operator operator-build
container-push-operator:
OPERATOR_IMAGE_VERSION=${CONTAINER_VERSION} $(MAKE) -C operator operator-push
container-push-kiali:
@echo Pushing current image to ${QUAY_TAG}
docker push ${QUAY_TAG}
@echo Pushing current image to ${DOCKER_TAG}
docker push ${DOCKER_TAG}
## container-push: Pushes current container images to remote container repos.
container-push: container-push-kiali container-push-operator
## operator-create: Delgates to the operator-create target of the operator Makefile
operator-create: docker-build-operator
OPERATOR_IMAGE_VERSION=${CONTAINER_VERSION} $(MAKE) -C operator operator-create
.ensure-oc-exists:
@$(eval OC ?= $(shell which istiooc 2>/dev/null || which oc 2>/dev/null || which kubectl))
.ensure-operator-is-running: .ensure-oc-exists
@${OC} get pods -l app=kiali-operator -n kiali-operator 2>/dev/null | grep "^kiali-operator.*Running" > /dev/null ;\
RETVAL=$$?; \
if [ $$RETVAL -ne 0 ]; then \
echo "The Operator is not running. To start it, run: make operator-create"; exit 1; \
fi
## openshift-deploy: Delgates to the kiali-create target of the operator Makefile
openshift-deploy: openshift-undeploy
IMAGE_VERSION=${CONTAINER_VERSION} $(MAKE) -C operator kiali-create
## openshift-undeploy: Delgates to the kiali-delete target of the operator Makefile
openshift-undeploy: .ensure-operator-is-running
IMAGE_VERSION=${CONTAINER_VERSION} $(MAKE) -C operator kiali-delete
## k8s-deploy: Delgates to the kiali-create target of the operator Makefile
k8s-deploy: openshift-deploy
## k8s-undeploy: Delgates to the kiali-delete target of the operator Makefile
k8s-undeploy: openshift-undeploy
## openshift-reload-image: Refreshing image in Openshift project.
openshift-reload-image: .ensure-oc-exists
@echo Refreshing image in OpenShift project ${NAMESPACE}
${OC} delete pod --selector=app=kiali -n ${NAMESPACE}
## k8s-reload-image: Refreshing image in Kubernetes namespace.
k8s-reload-image: openshift-reload-image
## gometalinter-install: Installs gometalinter
gometalinter-install:
go get -u github.com/alecthomas/gometalinter
gometalinter --install
## lint: Runs gometalinter
lint:
gometalinter --disable-all --enable=vet --tests --vendor ./...
## lint-all: Runs gometalinter with items from good to have list but does not run during travis
lint-all:
gometalinter --disable-all --enable=vet --enable=vetshadow --enable=varcheck --enable=structcheck \
--enable=ineffassign --enable=unconvert --enable=goimports -enable=gosimple --enable=staticcheck \
--enable=nakedret --tests --vendor ./...