forked from scylladb/scylla-manager
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
215 lines (177 loc) · 7.22 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
all: help
# Prevent invoking make with a package specific test without a constraining a
# package.
ifneq "$(filter pkg-%,$(MAKECMDGOALS))" ""
ifeq "$(PKG)" ""
$(error Please specify package name with PKG e.g. PKG=./pkg/scyllaclient)
endif
endif
# Default package
PKG := ./pkg/...
GIT_ROOT = $(shell git rev-parse --show-toplevel)
GOBIN ?= $(shell pwd)/bin
GOFILES = go list -f '{{range .GoFiles}}{{ $$.Dir }}/{{ . }} {{end}}{{range .TestGoFiles}}{{ $$.Dir }}/{{ . }} {{end}}' $(PKG)
.PHONY: fmt
fmt: ## Format source code
@$(GOBIN)/golangci-lint run -c .golangci-fmt.yml --fix $(PKG)
.PHONY: check
check: ## Perform static code analysis
check: .check-go-version .check-copyright .check-comments .check-errors-wrap \
.check-log-capital-letter .check-timeutc .check-lint .check-vendor
.PHONY: .check-go-version
.check-go-version:
@[[ "`go version`" =~ "`cat .go-version`" ]] || echo "[WARNING] Required Go version `cat .go-version` found `go version | grep -o -E '1\.[0-9\.]+'`"
.PHONY: .check-copyright
.check-copyright:
@set -e; for f in `$(GOFILES)`; do \
[[ $$f =~ /mock_.*_test\.go ]] || \
[[ $$f =~ _gen\.go ]] || \
[[ `head -n 1 $$f` =~ '// Copyright (C) ' ]] || [[ `head -n 1 $$f` =~ 'DO NOT EDIT' ]] || (echo $$f; false); \
done
.PHONY: .check-comments
.check-comments:
@set -e; for f in `$(GOFILES)`; do \
[[ $$f =~ _string\.go ]] || \
! e=`grep -Pzo '\n\n\s+//\s*[a-z].*' $$f` || \
(echo $$f $$e; false); \
done
.PHONY: .check-errors-wrap
.check-errors-wrap:
@set -e; for f in `$(GOFILES)`; do \
! e=`grep -n -E 'errors\.(Errorf|New|Wrap|Wrapf)' $$f | grep -E '("| )fail'` || \
(echo $$f $$e; false); \
done
.PHONY: .check-log-capital-letter
.check-log-capital-letter:
@set -e; for f in `$(GOFILES)`; do \
! e=`grep -n -E '\.(Error|Info|Debug)\(ctx, "[a-z]' $$f` || \
(echo $$f $$e; false); \
done
.PHONY: .check-timeutc
.check-timeutc:
@set -e; for f in `$(GOFILES)`; do \
[[ $$f =~ /timeutc/ ]] || \
! e=`grep -n 'time.\(Now\|Parse(\|Since\)' $$f` || \
(echo $$f $$e; false); \
done
.PHONY: .check-lint
.check-lint:
@$(GOBIN)/golangci-lint run $(PKG)
.PHONY: .check-vendor
.check-vendor:
@e=`go mod verify` || (echo $$e; false)
.PHONY: test
test: ## Run unit and integration tests
test: unit-test integration-test
.PHONY: unit-test
unit-test: ## Run unit tests
@echo "==> Running tests (race)"
@go test -cover -race $(PKG)
.PHONY: integration-test
integration-test: ## Run integration tests
integration-test:
@$(MAKE) pkg-integration-test PKG=./pkg/ping/cqlping
@$(MAKE) pkg-integration-test PKG=./pkg/ping/dynamoping
@$(MAKE) pkg-integration-test PKG=./pkg/scyllaclient
@$(MAKE) pkg-integration-test PKG=./pkg/service/backup
@$(MAKE) pkg-integration-test PKG=./pkg/service/cluster
@$(MAKE) pkg-integration-test PKG=./pkg/service/healthcheck
@$(MAKE) pkg-integration-test PKG=./pkg/service/repair
@$(MAKE) pkg-integration-test PKG=./pkg/service/scheduler
@$(MAKE) pkg-integration-test PKG=./pkg/store
@$(MAKE) pkg-integration-test PKG=./pkg/schema/migrate
@$(MAKE) pkg-integration-test PKG=./pkg/util/netwait
# Load Minio config for INTEGRATION_TEST_ARGS
include testing/.env
INTEGRATION_TEST_ARGS := -cluster 192.168.100.100 \
-managed-cluster 192.168.100.11,192.168.100.12,192.168.100.13,192.168.100.21,192.168.100.22,192.168.100.23 \
-user cassandra -password cassandra \
-agent-auth-token token \
-s3-data-dir ./testing/minio/data -s3-provider Minio -s3-endpoint $(MINIO_ENDPOINT) -s3-access-key-id $(MINIO_USER_ACCESS_KEY) -s3-secret-access-key $(MINIO_USER_SECRET_KEY)
SSL_FLAGS := -ssl-ca-file ./testing/$(SSL_AUTHORITY_CRT) -ssl-key-file ./testing/$(SSL_CLIENT_KEY) -ssl-cert-file ./testing/$(SSL_CLIENT_CRT) -gocql.port $(SSL_PORT)
CURRENT_UID = $(shell id -u)
CURRENT_GID = $(shell id -g)
.PHONY: pkg-integration-test
pkg-integration-test: ## Run integration tests for a package, requires PKG parameter
pkg-integration-test: RUN=Integration
pkg-integration-test:
@echo "==> Running integration tests for package $(PKG)"
@CGO_ENABLED=0 GOOS=linux go test -tags integration -c -o ./integration-test.dev $(PKG)
@docker run --name "scylla_manager_server" \
--network scylla_manager_public \
-v "/tmp:/tmp" \
-v "$(PWD)/integration-test.dev:/usr/bin/integration-test:ro" \
-v "$(PWD)/testing:/integration-test/testing" \
-v "$(PWD)/$(PKG)/testdata:/integration-test/testdata" \
-w "/integration-test" \
-u $(CURRENT_UID):$(CURRENT_GID) \
-it --read-only --rm ubuntu integration-test -test.v -test.run $(RUN) $(INTEGRATION_TEST_ARGS) $(SSL_FLAGS) $(ARGS)
.PHONY: pkg-stress-test
pkg-stress-test: ## Run unit tests for a package in parallel in a loop to detect sporadic failures, requires PKG parameter
pkg-stress-test: RUN=Test
pkg-stress-test:
@echo "==> Running stress tests for package $(PKG) (race)"
@go test -race -c -o stress.test $(PKG)
@cd $(PKG); $(GOBIN)/stress $(PWD)/stress.test -test.run $(RUN)
.PHONY: start-dev-env
start-dev-env: ## Start testing containers and run server
start-dev-env: .testing-up deploy-agent build-cli run-server
.PHONY: .testing-up
.testing-up:
@make -C testing build down up
.PHONY: dev-env-status
dev-env-status: ## Checks status of docker containers and cluster nodes
@make -C testing status
.PHONY: build-agent
build-agent: ## Build development agent binary
@echo "==> Building agent"
@CGO_ENABLED=0 GOOS=linux go build -trimpath -mod=vendor -o ./scylla-manager-agent.dev ./pkg/cmd/agent
.PHONY: deploy-agent
deploy-agent: build-agent ## Deploy it to testing containers
@echo "==> Deploying agent to testing containers"
@make -C testing deploy-agent restart-agent
.PHONY: build-cli
build-cli: ## Build development cli binary
@echo "==> Building sctool"
@go build -trimpath -mod=vendor -o ./sctool.dev ./pkg/cmd/sctool
.PHONY: build-server
build-server: ## Build development server
@echo "==> Building scylla-manager"
@CGO_ENABLED=0 GOOS=linux go build -trimpath -mod=vendor -o ./scylla-manager.dev ./pkg/cmd/scylla-manager
.PHONY: run-server
run-server: build-server ## Build and run development server
@docker run --name "scylla_manager_server" \
--network scylla_manager_public \
-p "5080:5080" \
-p "5443:5443" \
-p "5090:5090" \
-v "$(PWD)/scylla-manager.dev:/usr/bin/scylla-manager:ro" \
-v "$(PWD)/testing/scylla-manager/scylla-manager.yaml:/etc/scylla-manager/scylla-manager.yaml:ro" \
-it --read-only --rm scylladb/scylla-manager-dev scylla-manager
.PHONY: build
build: build-cli build-agent build-server ## Build all project binaries
.PHONY: docs
docs: ## Update docs/source with generated code
@rm -rf docs/source/sctool/partials
@SCYLLA_MANAGER_CLUSTER="" ./sctool doc -o docs/source/sctool/partials
.PHONY: filler-tool
filler-tool: ## Build "filler" tool
@echo "==> Building filler"
@go build -trimpath -mod=vendor ./pkg/tools/filler/cmd/filler
.PHONY: clean
clean: ## Remove dev build artifacts (*.dev files)
@rm -rf agent.dev sctool.dev scylla-manager.dev stress.test \
filler
.PHONY: mrproper
mrproper: ## Clean go caches
@go clean -r -cache -testcache -modcache ./...
.PHONY: generate
generate: ## Recreate autogenerated resources
@go generate $(PKG)
.PHONY: vendor
vendor: ## Fix dependencies and make vendored copies
@go mod tidy
@go mod vendor
.PHONY: help
help:
@awk -F ':|##' '/^[^\t].+?:.*?##/ {printf "\033[36m%-25s\033[0m %s\n", $$1, $$NF}' $(MAKEFILE_LIST)