-
Notifications
You must be signed in to change notification settings - Fork 7
/
Makefile
81 lines (62 loc) · 2.98 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
BUILD_IMAGE ?= assisted-events-streams:latest
NAMESPACE ?= assisted-events-streams
IMAGE_NAME ?= quay.io/edge-infrastructure/assisted-events-stream
IMAGE_TAG ?= latest
KIND_CLUSTER_NAME ?= assisted-events-streams
REDIS_IMAGE_NAME ?= "quay.io/edge-infrastructure/redis"
REDIS_IMAGE_TAG ?= 6.2.7-debian-10-r23
REDIS_EXPORTER_IMAGE_NAME ?= "quay.io/edge-infrastructure/redis-exporter"
REDIS_EXPORTER_IMAGE_TAG ?= 1.37.0-debian-10-r63
.PHONY: all
all: validate
.PHONY: 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)
.PHONY: docker-build
docker-build: ## Build docker image
docker build -t $(IMAGE_NAME):$(IMAGE_TAG) -f Dockerfile .
.PHONY: redis-docker-build
redis-docker-build: ## Build docker image
docker build -t $(REDIS_IMAGE_NAME):$(REDIS_IMAGE_TAG) -f Dockerfile.redis .
docker build -t $(REDIS_EXPORTER_IMAGE_NAME):$(REDIS_EXPORTER_IMAGE_TAG) -f Dockerfile.redis-exporter .
.PHONY: kind-create-cluster
kind-create-cluster: ## Create kind cluster
kind create cluster --name $(KIND_CLUSTER_NAME) 2>/dev/null ||:
.PHONY: kind-load-docker
kind-load-docker: docker-build ## Load docker image into the kind cluster
kind load docker-image --name $(KIND_CLUSTER_NAME) $(IMAGE_NAME):$(IMAGE_TAG)
.PHONY: deploy-all
deploy-all: kind-create-cluster kind-load-docker ## Deploy locally all necessary components
oc create --save-config ns ${NAMESPACE} ||:
oc kustomize manifest/overlays/dev/ | oc process -p IMAGE_NAME=$(IMAGE_NAME) -p IMAGE_TAG=$(IMAGE_TAG) --local -f - | oc apply -n $(NAMESPACE) -f -
.PHONY: generate-template
generate-template: ## Generate template in openshift/template.yaml
oc kustomize manifest/overlays/production/ > openshift/template.yaml
.PHONY: check-template-generation ## Check openshift/template.yaml are generated by generate-template target
check-template-generation: generate-template
@git diff --exit-code openshift/template.yaml
.PHONY: generate-mocks
generate-mocks: ## Generate mocks
find -name 'mock_*' -delete
go generate ./...
.PHONY: unit-test
unit-test: generate-mocks ## Run unit tests
ginkgo -r
.PHONY: lint
lint:
golangci-lint run -v
.PHONY: format
format:
golangci-lint run --fix -v
.PHONY: validate
validate: lint unit-test
PRODUCER_COMMAND=oc exec -i -n assisted-events-streams ai-kafka-0 -- kafka-console-producer.sh --topic events-stream-integration --bootstrap-server ai-kafka-0.ai-kafka-headless.assisted-events-streams.svc.cluster.local:9092
.PHONY: push-cluster-event push-cluster-state push-host-state push-infra-env-state
push-cluster-event:
jq -c '.' resources/cluster_event.json | $(PRODUCER_COMMAND)
push-cluster-state:
jq -c '.' resources/cluster_state.json | $(PRODUCER_COMMAND)
push-host-state:
jq -c '.' resources/host_state.json | $(PRODUCER_COMMAND)
push-infra-env-state:
jq -c '.' resources/infra_env_state.json | $(PRODUCER_COMMAND)