forked from Kong/kubernetes-ingress-controller
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
93 lines (74 loc) · 2.07 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
TAG?=1.3.1
RG_TAG?=2.0.0-alpha.1
REGISTRY?=kong
REPO_INFO=$(shell git config --get remote.origin.url)
IMGNAME?=kubernetes-ingress-controller
IMAGE = $(REGISTRY)/$(IMGNAME)
# only for dev
DB?=false
RUN_VERSION?=20
KUBE_VERSION?=v1.20.2
PKG_LIST := ./...
ifndef COMMIT
COMMIT := $(shell git rev-parse --short HEAD)
endif
export GO111MODULE=on
.PHONY: test-all
test-all: lint test
.PHONY: test
test:
go test -race -covermode=atomic -coverpkg=$(PKG_LIST) $(PKG_LIST)
.PHONY: coverage
coverage:
go test -race -v -count=1 -covermode=atomic -coverpkg=$(PKG_LIST) -coverprofile=coverage.out.tmp $(PKG_LIST)
# ignoring generated code for coverage
grep -E -v 'pkg/apis/|pkg/client/|generated.go|generated.deepcopy.go' coverage.out.tmp > coverage.out
rm -f coverage.out.tmp
.PHONY: lint
lint: verify-tidy
golangci-lint run ./...
.PHONY: build
build:
CGO_ENABLED=0 go build -o kong-ingress-controller ./cli/ingress-controller
.PHONY: verify-manifests
verify-manifests:
./hack/verify-manifests.sh
.PHONY: verify-codegen
verify-codegen:
./hack/verify-codegen.sh
.PHONY: update-codegen
update-codegen:
./hack/update-codegen.sh
.PHONY: verify-tidy
verify-tidy:
./hack/verify-tidy.sh
.PHONY: container-alpine
container-alpine:
docker build \
--build-arg TAG=${TAG} --build-arg COMMIT=${COMMIT} \
--build-arg REPO_INFO=${REPO_INFO} \
--target alpine \
-t ${IMAGE}:${TAG}-alpine .
.PHONY: container-redhat
container-redhat:
docker build \
--build-arg TAG=${TAG} --build-arg COMMIT=${COMMIT} \
--build-arg REPO_INFO=${REPO_INFO} \
--target redhat \
-t ${IMAGE}:${TAG}-redhat .
.PHONY: container
container: container-alpine
docker tag "${IMAGE}:${TAG}-alpine" "${IMAGE}:${TAG}"
.PHONY: railgun-container
railgun-container:
docker build \
-f Dockerfile.railgun \
--build-arg TAG=${RG_TAG} --build-arg COMMIT=${COMMIT} \
--build-arg REPO_INFO=${REPO_INFO} \
-t ${IMAGE}:${RG_TAG} .
.PHONY: run
run:
./hack/dev/start.sh ${DB} ${RUN_VERSION}
.PHONY: integration-test
integration-test: container
KIC_IMAGE="${IMAGE}:${TAG}" KUBE_VERSION=${KUBE_VERSION} ./test/integration/test.sh