Makefile 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567
  1. # Copyright (C) 2019-2020 Zilliz. All rights reserved.
  2. #
  3. # Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
  4. # with the License. You may obtain a copy of the License at
  5. #
  6. # http://www.apache.org/licenses/LICENSE-2.0
  7. #
  8. # Unless required by applicable law or agreed to in writing, software distributed under the License
  9. # is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
  10. # or implied. See the License for the specific language governing permissions and limitations under the License.
  11. GO ?= go
  12. PWD := $(shell pwd)
  13. GOPATH := $(shell $(GO) env GOPATH)
  14. SHELL := /bin/bash
  15. OBJPREFIX := "github.com/milvus-io/milvus/cmd/milvus"
  16. MILVUS_GO_BUILD_TAGS := "dynamic,sonic"
  17. INSTALL_PATH := $(PWD)/bin
  18. LIBRARY_PATH := $(PWD)/lib
  19. PGO_PATH := $(PWD)/configs/pgo
  20. OS := $(shell uname -s)
  21. mode = Release
  22. use_disk_index = OFF
  23. ifdef disk_index
  24. use_disk_index = ${disk_index}
  25. endif
  26. use_asan = OFF
  27. ifdef USE_ASAN
  28. use_asan =${USE_ASAN}
  29. CGO_LDFLAGS := $(shell go env CGO_LDFLAGS) -fsanitize=address -fno-omit-frame-pointer
  30. CGO_CFLAGS := $(shell go env CGO_CFLAGS) -fsanitize=address -fno-omit-frame-pointer
  31. MILVUS_GO_BUILD_TAGS := $(MILVUS_GO_BUILD_TAGS),use_asan
  32. endif
  33. use_dynamic_simd = ON
  34. ifdef USE_DYNAMIC_SIMD
  35. use_dynamic_simd = ${USE_DYNAMIC_SIMD}
  36. endif
  37. use_opendal = OFF
  38. ifdef USE_OPENDAL
  39. use_opendal = ${USE_OPENDAL}
  40. endif
  41. # golangci-lint
  42. GOLANGCI_LINT_VERSION := 1.55.2
  43. GOLANGCI_LINT_OUTPUT := $(shell $(INSTALL_PATH)/golangci-lint --version 2>/dev/null)
  44. INSTALL_GOLANGCI_LINT := $(findstring $(GOLANGCI_LINT_VERSION), $(GOLANGCI_LINT_OUTPUT))
  45. # mockery
  46. MOCKERY_VERSION := 2.46.0
  47. MOCKERY_OUTPUT := $(shell $(INSTALL_PATH)/mockery --version 2>/dev/null)
  48. INSTALL_MOCKERY := $(findstring $(MOCKERY_VERSION),$(MOCKERY_OUTPUT))
  49. # gci
  50. GCI_VERSION := 0.11.2
  51. GCI_OUTPUT := $(shell $(INSTALL_PATH)/gci --version 2>/dev/null)
  52. INSTALL_GCI := $(findstring $(GCI_VERSION),$(GCI_OUTPUT))
  53. # gofumpt
  54. GOFUMPT_VERSION := 0.5.0
  55. GOFUMPT_OUTPUT := $(shell $(INSTALL_PATH)/gofumpt --version 2>/dev/null)
  56. INSTALL_GOFUMPT := $(findstring $(GOFUMPT_VERSION),$(GOFUMPT_OUTPUT))
  57. # gotestsum
  58. GOTESTSUM_VERSION := 1.11.0
  59. GOTESTSUM_OUTPUT := $(shell $(INSTALL_PATH)/gotestsum --version 2>/dev/null)
  60. INSTALL_GOTESTSUM := $(findstring $(GOTESTSUM_VERSION),$(GOTESTSUM_OUTPUT))
  61. # protoc-gen-go
  62. PROTOC_GEN_GO_VERSION := 1.33.0
  63. PROTOC_GEN_GO_OUTPUT := $(shell echo | $(INSTALL_PATH)/protoc-gen-go --version 2>/dev/null)
  64. INSTALL_PROTOC_GEN_GO := $(findstring $(PROTOC_GEN_GO_VERSION),$(PROTOC_GEN_GO_OUTPUT))
  65. # protoc-gen-go-grpc
  66. PROTOC_GEN_GO_GRPC_VERSION := 1.3.0
  67. PROTOC_GEN_GO_GRPC_OUTPUT := $(shell echo | $(INSTALL_PATH)/protoc-gen-go-grpc --version 2>/dev/null)
  68. INSTALL_PROTOC_GEN_GO_GRPC := $(findstring $(PROTOC_GEN_GO_GRPC_VERSION),$(PROTOC_GEN_GO_GRPC_OUTPUT))
  69. index_engine = knowhere
  70. export GIT_BRANCH=master
  71. ifeq (${ENABLE_AZURE}, false)
  72. AZURE_OPTION := -Z
  73. endif
  74. milvus: build-cpp print-build-info build-go
  75. build-go:
  76. @echo "Building Milvus ..."
  77. @source $(PWD)/scripts/setenv.sh && \
  78. mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && \
  79. CGO_LDFLAGS="$(CGO_LDFLAGS)" CGO_CFLAGS="$(CGO_CFLAGS)" GO111MODULE=on $(GO) build -pgo=$(PGO_PATH)/default.pgo -ldflags="-r $${RPATH} -X '$(OBJPREFIX).BuildTags=$(BUILD_TAGS)' -X '$(OBJPREFIX).BuildTime=$(BUILD_TIME)' -X '$(OBJPREFIX).GitCommit=$(GIT_COMMIT)' -X '$(OBJPREFIX).GoVersion=$(GO_VERSION)'" \
  80. -tags $(MILVUS_GO_BUILD_TAGS) -o $(INSTALL_PATH)/milvus $(PWD)/cmd/main.go 1>/dev/null
  81. milvus-gpu: build-cpp-gpu print-gpu-build-info
  82. @echo "Building Milvus-gpu ..."
  83. @source $(PWD)/scripts/setenv.sh && \
  84. mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && \
  85. CGO_LDFLAGS="$(CGO_LDFLAGS)" CGO_CFLAGS="$(CGO_CFLAGS)" GO111MODULE=on $(GO) build -pgo=$(PGO_PATH)/default.pgo -ldflags="-r $${RPATH} -X '$(OBJPREFIX).BuildTags=$(BUILD_TAGS_GPU)' -X '$(OBJPREFIX).BuildTime=$(BUILD_TIME)' -X '$(OBJPREFIX).GitCommit=$(GIT_COMMIT)' -X '$(OBJPREFIX).GoVersion=$(GO_VERSION)'" \
  86. -tags $(MILVUS_GO_BUILD_TAGS) -o $(INSTALL_PATH)/milvus $(PWD)/cmd/main.go 1>/dev/null
  87. get-build-deps:
  88. @(env bash $(PWD)/scripts/install_deps.sh)
  89. # attention: upgrade golangci-lint should also change Dockerfiles in build/docker/builder/cpu/<os>
  90. getdeps:
  91. @mkdir -p $(INSTALL_PATH)
  92. @if [ -z "$(INSTALL_GOLANGCI_LINT)" ]; then \
  93. echo "Installing golangci-lint into ./bin/" && curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(INSTALL_PATH) v${GOLANGCI_LINT_VERSION} ; \
  94. else \
  95. echo "golangci-lint v@$(GOLANGCI_LINT_VERSION) already installed"; \
  96. fi
  97. @if [ -z "$(INSTALL_MOCKERY)" ]; then \
  98. echo "Installing mockery v$(MOCKERY_VERSION) to ./bin/" && GOBIN=$(INSTALL_PATH) go install github.com/vektra/mockery/v2@v$(MOCKERY_VERSION); \
  99. else \
  100. echo "Mockery v$(MOCKERY_VERSION) already installed"; \
  101. fi
  102. @if [ -z "$(INSTALL_GOTESTSUM)" ]; then \
  103. echo "Install gotestsum v$(GOTESTSUM_VERSION) to ./bin/" && GOBIN=$(INSTALL_PATH) go install -ldflags="-X 'gotest.tools/gotestsum/cmd.version=$(GOTESTSUM_VERSION)'" gotest.tools/gotestsum@v$(GOTESTSUM_VERSION); \
  104. else \
  105. echo "gotestsum v$(GOTESTSUM_VERSION) already installed";\
  106. fi
  107. get-proto-deps:
  108. @mkdir -p $(INSTALL_PATH) # make sure directory exists
  109. @if [ -z "$(INSTALL_PROTOC_GEN_GO)" ]; then \
  110. echo "install protoc-gen-go $(PROTOC_GEN_GO_VERSION) to $(INSTALL_PATH)" && GOBIN=$(INSTALL_PATH) go install google.golang.org/protobuf/cmd/protoc-gen-go@v$(PROTOC_GEN_GO_VERSION); \
  111. else \
  112. echo "protoc-gen-go@v$(PROTOC_GEN_GO_VERSION) already installed";\
  113. fi
  114. @if [ -z "$(INSTALL_PROTOC_GEN_GO_GRPC)" ]; then \
  115. echo "install protoc-gen-go-grpc $(PROTOC_GEN_GO_GRPC_VERSION) to $(INSTALL_PATH)" && GOBIN=$(INSTALL_PATH) go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@v$(PROTOC_GEN_GO_GRPC_VERSION); \
  116. else \
  117. echo "protoc-gen-go-grpc@v$(PROTOC_GEN_GO_GRPC_VERSION) already installed";\
  118. fi
  119. tools/bin/revive: tools/check/go.mod
  120. cd tools/check; \
  121. $(GO) build -pgo=$(PGO_PATH)/default.pgo -o ../bin/revive github.com/mgechev/revive
  122. cppcheck:
  123. @#(env bash ${PWD}/scripts/core_build.sh -l)
  124. @(env bash ${PWD}/scripts/check_cpp_fmt.sh)
  125. fmt:
  126. ifdef GO_DIFF_FILES
  127. @echo "Running $@ check"
  128. @GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh $(GO_DIFF_FILES)
  129. else
  130. @echo "Running $@ check"
  131. @GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh cmd/
  132. @GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh internal/
  133. @GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh tests/integration/
  134. @GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh tests/go/
  135. @GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh pkg/
  136. endif
  137. lint-fix: getdeps
  138. @mkdir -p $(INSTALL_PATH)
  139. @if [ -z "$(INSTALL_GCI)" ]; then \
  140. echo "Installing gci v$(GCI_VERSION) to ./bin/" && GOBIN=$(INSTALL_PATH) go install github.com/daixiang0/gci@v$(GCI_VERSION); \
  141. else \
  142. echo "gci v$(GCI_VERSION) already installed"; \
  143. fi
  144. @if [ -z "$(INSTALL_GOFUMPT)" ]; then \
  145. echo "Installing gofumpt v$(GOFUMPT_VERSION) to ./bin/" && GOBIN=$(INSTALL_PATH) go install mvdan.cc/gofumpt@v$(GOFUMPT_VERSION); \
  146. else \
  147. echo "gofumpt v$(GOFUMPT_VERSION) already installed"; \
  148. fi
  149. @echo "Running gofumpt fix"
  150. @$(INSTALL_PATH)/gofumpt -l -w internal/
  151. @$(INSTALL_PATH)/gofumpt -l -w cmd/
  152. @$(INSTALL_PATH)/gofumpt -l -w pkg/
  153. @$(INSTALL_PATH)/gofumpt -l -w client/
  154. @$(INSTALL_PATH)/gofumpt -l -w tests/go_client/
  155. @$(INSTALL_PATH)/gofumpt -l -w tests/integration/
  156. @echo "Running gci fix"
  157. @$(INSTALL_PATH)/gci write cmd/ --skip-generated -s standard -s default -s "prefix(github.com/milvus-io)" --custom-order
  158. @$(INSTALL_PATH)/gci write internal/ --skip-generated -s standard -s default -s "prefix(github.com/milvus-io)" --custom-order
  159. @$(INSTALL_PATH)/gci write pkg/ --skip-generated -s standard -s default -s "prefix(github.com/milvus-io)" --custom-order
  160. @$(INSTALL_PATH)/gci write client/ --skip-generated -s standard -s default -s "prefix(github.com/milvus-io)" --custom-order
  161. @$(INSTALL_PATH)/gci write tests/ --skip-generated -s standard -s default -s "prefix(github.com/milvus-io)" --custom-order
  162. @echo "Running golangci-lint auto-fix"
  163. @source $(PWD)/scripts/setenv.sh && GO111MODULE=on $(INSTALL_PATH)/golangci-lint run --fix --timeout=30m --config $(PWD)/.golangci.yml;
  164. @source $(PWD)/scripts/setenv.sh && cd pkg && GO111MODULE=on $(INSTALL_PATH)/golangci-lint run --fix --timeout=30m --config $(PWD)/.golangci.yml
  165. @source $(PWD)/scripts/setenv.sh && cd client && GO111MODULE=on $(INSTALL_PATH)/golangci-lint run --fix --timeout=30m --config $(PWD)/client/.golangci.yml
  166. #TODO: Check code specifications by golangci-lint
  167. static-check: getdeps
  168. @echo "Running $@ check"
  169. @echo "Start check core packages"
  170. @source $(PWD)/scripts/setenv.sh && GO111MODULE=on GOFLAGS=-buildvcs=false $(INSTALL_PATH)/golangci-lint run --build-tags dynamic,test --timeout=30m --config $(PWD)/.golangci.yml
  171. @echo "Start check pkg package"
  172. @source $(PWD)/scripts/setenv.sh && cd pkg && GO111MODULE=on GOFLAGS=-buildvcs=false $(INSTALL_PATH)/golangci-lint run --build-tags dynamic,test --timeout=30m --config $(PWD)/.golangci.yml
  173. @echo "Start check client package"
  174. @source $(PWD)/scripts/setenv.sh && cd client && GO111MODULE=on GOFLAGS=-buildvcs=false $(INSTALL_PATH)/golangci-lint run --timeout=30m --config $(PWD)/client/.golangci.yml
  175. @echo "Start check go_client e2e package"
  176. @source $(PWD)/scripts/setenv.sh && cd tests/go_client && GO111MODULE=on GOFLAGS=-buildvcs=false $(INSTALL_PATH)/golangci-lint run --build-tags L0,L1,L2,test --timeout=30m --config $(PWD)/tests/go_client/.golangci.yml
  177. verifiers: build-cpp getdeps cppcheck fmt static-check
  178. # Build various components locally.
  179. binlog:
  180. @echo "Building binlog ..."
  181. @source $(PWD)/scripts/setenv.sh && \
  182. mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && \
  183. GO111MODULE=on $(GO) build -pgo=$(PGO_PATH)/default.pgo -ldflags="-r $${RPATH}" -o $(INSTALL_PATH)/binlog $(PWD)/cmd/tools/binlog/main.go 1>/dev/null
  184. MIGRATION_PATH = $(PWD)/cmd/tools/migration
  185. meta-migration:
  186. @echo "Building migration tool ..."
  187. @source $(PWD)/scripts/setenv.sh && \
  188. mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && \
  189. GO111MODULE=on $(GO) build -pgo=$(PGO_PATH)/default.pgo -ldflags="-r $${RPATH} -X '$(OBJPREFIX).BuildTags=$(BUILD_TAGS)' -X '$(OBJPREFIX).BuildTime=$(BUILD_TIME)' -X '$(OBJPREFIX).GitCommit=$(GIT_COMMIT)' -X '$(OBJPREFIX).GoVersion=$(GO_VERSION)'" \
  190. -tags dynamic -o $(INSTALL_PATH)/meta-migration $(MIGRATION_PATH)/main.go 1>/dev/null
  191. INTERATION_PATH = $(PWD)/tests/integration
  192. integration-test: getdeps
  193. @echo "Building integration tests ..."
  194. @(env bash $(PWD)/scripts/run_intergration_test.sh "$(INSTALL_PATH)/gotestsum --")
  195. BUILD_TAGS = $(shell git describe --tags --always --dirty="-dev")
  196. BUILD_TAGS_GPU = ${BUILD_TAGS}-gpu
  197. BUILD_TIME = $(shell date -u)
  198. GIT_COMMIT = $(shell git rev-parse --short HEAD)
  199. GO_VERSION = $(shell go version)
  200. print-build-info:
  201. $(shell git config --global --add safe.directory '*')
  202. @echo "Build Tag: $(BUILD_TAGS)"
  203. @echo "Build Time: $(BUILD_TIME)"
  204. @echo "Git Commit: $(GIT_COMMIT)"
  205. @echo "Go Version: $(GO_VERSION)"
  206. print-gpu-build-info:
  207. $(shell git config --global --add safe.directory '*')
  208. @echo "Build Tag: $(BUILD_TAGS_GPU)"
  209. @echo "Build Time: $(BUILD_TIME)"
  210. @echo "Git Commit: $(GIT_COMMIT)"
  211. @echo "Go Version: $(GO_VERSION)"
  212. update-milvus-api: download-milvus-proto
  213. @echo "Update milvus/api version ..."
  214. @(env bash $(PWD)/scripts/update-api-version.sh $(PROTO_API_VERSION))
  215. download-milvus-proto:
  216. @echo "Download milvus-proto repo ..."
  217. @(env bash $(PWD)/scripts/download_milvus_proto.sh)
  218. build-3rdparty:
  219. @echo "Build 3rdparty ..."
  220. @(env bash $(PWD)/scripts/3rdparty_build.sh -o ${use_opendal})
  221. generated-proto-without-cpp: download-milvus-proto get-proto-deps
  222. @echo "Generate proto ..."
  223. @(env bash $(PWD)/scripts/generate_proto.sh ${INSTALL_PATH})
  224. generated-proto: download-milvus-proto build-3rdparty get-proto-deps
  225. @echo "Generate proto ..."
  226. @(env bash $(PWD)/scripts/generate_proto.sh ${INSTALL_PATH})
  227. build-cpp: generated-proto
  228. @echo "Building Milvus cpp library ..."
  229. @(env bash $(PWD)/scripts/core_build.sh -t ${mode} -a ${use_asan} -n ${use_disk_index} -y ${use_dynamic_simd} ${AZURE_OPTION} -x ${index_engine} -o ${use_opendal})
  230. build-cpp-gpu: generated-proto
  231. @echo "Building Milvus cpp gpu library ... "
  232. @(env bash $(PWD)/scripts/core_build.sh -t ${mode} -g -n ${use_disk_index} -y ${use_dynamic_simd} ${AZURE_OPTION} -x ${index_engine} -o ${use_opendal})
  233. build-cpp-with-unittest: generated-proto
  234. @echo "Building Milvus cpp library with unittest ... "
  235. @(env bash $(PWD)/scripts/core_build.sh -t ${mode} -u -n ${use_disk_index} -y ${use_dynamic_simd} ${AZURE_OPTION} -x ${index_engine} -o ${use_opendal})
  236. build-cpp-with-coverage: generated-proto
  237. @echo "Building Milvus cpp library with coverage and unittest ..."
  238. @(env bash $(PWD)/scripts/core_build.sh -t ${mode} -a ${use_asan} -u -c -n ${use_disk_index} -y ${use_dynamic_simd} ${AZURE_OPTION} -x ${index_engine} -o ${use_opendal})
  239. check-proto-product: generated-proto
  240. @(env bash $(PWD)/scripts/check_proto_product.sh)
  241. # Run the tests.
  242. unittest: test-cpp test-go
  243. test-util:
  244. @echo "Running go unittests..."
  245. @(env bash $(PWD)/scripts/run_go_unittest.sh -t util)
  246. test-storage:
  247. @echo "Running go unittests..."
  248. @(env bash $(PWD)/scripts/run_go_unittest.sh -t storage)
  249. test-allocator:
  250. @echo "Running go unittests..."
  251. @(env bash $(PWD)/scripts/run_go_unittest.sh -t allocator)
  252. test-config:
  253. @echo "Running go unittests..."
  254. @(env bash $(PWD)/scripts/run_go_unittest.sh -t config)
  255. test-tso:
  256. @echo "Running go unittests..."
  257. @(env bash $(PWD)/scripts/run_go_unittest.sh -t tso)
  258. test-kv:
  259. @echo "Running go unittests..."
  260. @(env bash $(PWD)/scripts/run_go_unittest.sh -t kv)
  261. test-mq:
  262. @echo "Running go unittests..."
  263. @(env bash $(PWD)/scripts/run_go_unittest.sh -t mq)
  264. test-rootcoord:
  265. @echo "Running go unittests..."
  266. @(env bash $(PWD)/scripts/run_go_unittest.sh -t rootcoord)
  267. test-indexnode:
  268. @echo "Running go unittests..."
  269. @(env bash $(PWD)/scripts/run_go_unittest.sh -t indexnode)
  270. test-indexcoord:
  271. @echo "Running go unittests..."
  272. @(env bash $(PWD)/scripts/run_go_unittest.sh -t indexcoord)
  273. test-proxy:
  274. @echo "Running go unittests..."
  275. @(env bash $(PWD)/scripts/run_go_unittest.sh -t proxy)
  276. test-datacoord:
  277. @echo "Running go unittests..."
  278. @(env bash $(PWD)/scripts/run_go_unittest.sh -t datacoord)
  279. test-datanode:
  280. @echo "Running go unittests..."
  281. @(env bash $(PWD)/scripts/run_go_unittest.sh -t datanode)
  282. test-querynode:
  283. @echo "Running go unittests..."
  284. @(env bash $(PWD)/scripts/run_go_unittest.sh -t querynode)
  285. test-querycoord:
  286. @echo "Running go unittests..."
  287. @(env bash $(PWD)/scripts/run_go_unittest.sh -t querycoord)
  288. test-metastore:
  289. @echo "Running go unittests..."
  290. @(env bash $(PWD)/scripts/run_go_unittest.sh -t metastore)
  291. test-streaming:
  292. @echo "Running go unittests..."
  293. @(env bash $(PWD)/scripts/run_go_unittest.sh -t streaming)
  294. test-go: build-cpp-with-unittest
  295. @echo "Running go unittests..."
  296. @(env bash $(PWD)/scripts/run_go_unittest.sh)
  297. test-cpp: build-cpp-with-unittest
  298. @echo "Running cpp unittests..."
  299. @(env bash $(PWD)/scripts/run_cpp_unittest.sh)
  300. run-test-cpp:
  301. @echo "Running cpp unittests..."
  302. @echo $(PWD)/scripts/run_cpp_unittest.sh arg=${filter}
  303. @(env bash $(PWD)/scripts/run_cpp_unittest.sh arg=${filter})
  304. # Run code coverage.
  305. codecov: codecov-go codecov-cpp
  306. # Run codecov-go
  307. codecov-go: build-cpp-with-coverage
  308. @echo "Running go coverage..."
  309. @(env bash $(PWD)/scripts/run_go_codecov.sh)
  310. # Run codecov-go without build core again, used in github action
  311. codecov-go-without-build: getdeps
  312. @echo "Running go coverage..."
  313. @(env bash $(PWD)/scripts/run_go_codecov.sh "$(INSTALL_PATH)/gotestsum --")
  314. # Run codecov-cpp
  315. codecov-cpp: build-cpp-with-coverage
  316. @echo "Running cpp coverage..."
  317. @(env bash $(PWD)/scripts/run_cpp_codecov.sh)
  318. # Build each component and install binary to $GOPATH/bin.
  319. install: milvus
  320. @echo "Installing binary to './bin'"
  321. @(env USE_ASAN=$(USE_ASAN) GOPATH=$(GOPATH) LIBRARY_PATH=$(LIBRARY_PATH) bash $(PWD)/scripts/install_milvus.sh)
  322. @echo "Installation successful."
  323. gpu-install: milvus-gpu
  324. @echo "Installing binary to './bin'"
  325. @(env USE_ASAN=$(USE_ASAN) GOPATH=$(GOPATH) LIBRARY_PATH=$(LIBRARY_PATH) bash $(PWD)/scripts/install_milvus.sh)
  326. @echo "Installation successful."
  327. clean:
  328. @echo "Cleaning up all the generated files"
  329. @rm -rf bin/
  330. @rm -rf lib/
  331. @rm -rf $(GOPATH)/bin/milvus
  332. @rm -rf cmake_build
  333. @rm -rf internal/core/output
  334. milvus-tools: print-build-info
  335. @echo "Building tools ..."
  336. @. $(PWD)/scripts/setenv.sh && mkdir -p $(INSTALL_PATH)/tools && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build \
  337. -pgo=$(PGO_PATH)/default.pgo -ldflags="-X 'main.BuildTags=$(BUILD_TAGS)' -X 'main.BuildTime=$(BUILD_TIME)' -X 'main.GitCommit=$(GIT_COMMIT)' -X 'main.GoVersion=$(GO_VERSION)'" \
  338. -o $(INSTALL_PATH)/tools $(PWD)/cmd/tools/* 1>/dev/null
  339. rpm-setup:
  340. @echo "Setuping rpm env ...;"
  341. @build/rpm/setup-env.sh
  342. rpm: install
  343. @echo "Note: run 'make rpm-setup' to setup build env for rpm builder"
  344. @echo "Building rpm ...;"
  345. @yum -y install rpm-build rpmdevtools wget
  346. @rm -rf ~/rpmbuild/BUILD/*
  347. @rpmdev-setuptree
  348. @wget https://github.com/etcd-io/etcd/releases/download/v3.5.0/etcd-v3.5.0-linux-amd64.tar.gz && tar -xf etcd-v3.5.0-linux-amd64.tar.gz
  349. @cp etcd-v3.5.0-linux-amd64/etcd bin/etcd
  350. @wget https://dl.min.io/server/minio/release/linux-amd64/archive/minio.RELEASE.2021-02-14T04-01-33Z -O bin/minio
  351. @cp -r bin ~/rpmbuild/BUILD/
  352. @cp -r lib ~/rpmbuild/BUILD/
  353. @cp -r configs ~/rpmbuild/BUILD/
  354. @cp -r build/rpm/services ~/rpmbuild/BUILD/
  355. @QA_RPATHS="$$[ 0x001|0x0002|0x0020 ]" rpmbuild -ba ./build/rpm/milvus.spec
  356. generate-mockery-types: getdeps
  357. # RootCoord
  358. $(INSTALL_PATH)/mockery --name=RootCoordComponent --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_rootcoord.go --with-expecter --structname=RootCoord
  359. # Proxy
  360. $(INSTALL_PATH)/mockery --name=ProxyComponent --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_proxy.go --with-expecter --structname=MockProxy
  361. # QueryCoord
  362. $(INSTALL_PATH)/mockery --name=QueryCoordComponent --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_querycoord.go --with-expecter --structname=MockQueryCoord
  363. # QueryNode
  364. $(INSTALL_PATH)/mockery --name=QueryNodeComponent --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_querynode.go --with-expecter --structname=MockQueryNode
  365. # DataCoord
  366. $(INSTALL_PATH)/mockery --name=DataCoordComponent --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_datacoord.go --with-expecter --structname=MockDataCoord
  367. # DataNode
  368. $(INSTALL_PATH)/mockery --name=DataNodeComponent --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_datanode.go --with-expecter --structname=MockDataNode
  369. # IndexNode
  370. $(INSTALL_PATH)/mockery --name=IndexNodeComponent --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_indexnode.go --with-expecter --structname=MockIndexNode
  371. # Clients
  372. $(INSTALL_PATH)/mockery --name=RootCoordClient --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_rootcoord_client.go --with-expecter --structname=MockRootCoordClient
  373. $(INSTALL_PATH)/mockery --name=QueryCoordClient --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_querycoord_client.go --with-expecter --structname=MockQueryCoordClient
  374. $(INSTALL_PATH)/mockery --name=DataCoordClient --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_datacoord_client.go --with-expecter --structname=MockDataCoordClient
  375. $(INSTALL_PATH)/mockery --name=QueryNodeClient --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_querynode_client.go --with-expecter --structname=MockQueryNodeClient
  376. $(INSTALL_PATH)/mockery --name=DataNodeClient --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_datanode_client.go --with-expecter --structname=MockDataNodeClient
  377. $(INSTALL_PATH)/mockery --name=IndexNodeClient --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_indexnode_client.go --with-expecter --structname=MockIndexNodeClient
  378. $(INSTALL_PATH)/mockery --name=ProxyClient --dir=$(PWD)/internal/types --output=$(PWD)/internal/mocks --filename=mock_proxy_client.go --with-expecter --structname=MockProxyClient
  379. generate-mockery-rootcoord: getdeps
  380. $(INSTALL_PATH)/mockery --name=IMetaTable --dir=$(PWD)/internal/rootcoord --output=$(PWD)/internal/rootcoord/mocks --filename=meta_table.go --with-expecter --outpkg=mockrootcoord
  381. $(INSTALL_PATH)/mockery --name=GarbageCollector --dir=$(PWD)/internal/rootcoord --output=$(PWD)/internal/rootcoord/mocks --filename=garbage_collector.go --with-expecter --outpkg=mockrootcoord
  382. generate-mockery-proxy: getdeps
  383. $(INSTALL_PATH)/mockery --name=Cache --dir=$(PWD)/internal/proxy --output=$(PWD)/internal/proxy --filename=mock_cache.go --structname=MockCache --with-expecter --outpkg=proxy --inpackage
  384. $(INSTALL_PATH)/mockery --name=timestampAllocatorInterface --dir=$(PWD)/internal/proxy --output=$(PWD)/internal/proxy --filename=mock_tso_test.go --structname=mockTimestampAllocator --with-expecter --outpkg=proxy --inpackage
  385. $(INSTALL_PATH)/mockery --name=LBPolicy --dir=$(PWD)/internal/proxy --output=$(PWD)/internal/proxy --filename=mock_lb_policy.go --structname=MockLBPolicy --with-expecter --outpkg=proxy --inpackage
  386. $(INSTALL_PATH)/mockery --name=LBBalancer --dir=$(PWD)/internal/proxy --output=$(PWD)/internal/proxy --filename=mock_lb_balancer.go --structname=MockLBBalancer --with-expecter --outpkg=proxy --inpackage
  387. $(INSTALL_PATH)/mockery --name=shardClientMgr --dir=$(PWD)/internal/proxy --output=$(PWD)/internal/proxy --filename=mock_shardclient_manager.go --structname=MockShardClientManager --with-expecter --outpkg=proxy --inpackage
  388. $(INSTALL_PATH)/mockery --name=channelsMgr --dir=$(PWD)/internal/proxy --output=$(PWD)/internal/proxy --filename=mock_channels_manager.go --structname=MockChannelsMgr --with-expecter --outpkg=proxy --inpackage
  389. generate-mockery-querycoord: getdeps
  390. $(INSTALL_PATH)/mockery --name=QueryNodeServer --dir=$(PWD)/internal/proto/querypb/ --output=$(PWD)/internal/querycoordv2/mocks --filename=mock_querynode.go --with-expecter --structname=MockQueryNodeServer
  391. $(INSTALL_PATH)/mockery --name=Broker --dir=$(PWD)/internal/querycoordv2/meta --output=$(PWD)/internal/querycoordv2/meta --filename=mock_broker.go --with-expecter --structname=MockBroker --outpkg=meta
  392. $(INSTALL_PATH)/mockery --name=TargetManagerInterface --dir=$(PWD)/internal/querycoordv2/meta --output=$(PWD)/internal/querycoordv2/meta --filename=mock_target_manager.go --with-expecter --structname=MockTargetManager --inpackage
  393. $(INSTALL_PATH)/mockery --name=Scheduler --dir=$(PWD)/internal/querycoordv2/task --output=$(PWD)/internal/querycoordv2/task --filename=mock_scheduler.go --with-expecter --structname=MockScheduler --outpkg=task --inpackage
  394. $(INSTALL_PATH)/mockery --name=Cluster --dir=$(PWD)/internal/querycoordv2/session --output=$(PWD)/internal/querycoordv2/session --filename=mock_cluster.go --with-expecter --structname=MockCluster --outpkg=session --inpackage
  395. $(INSTALL_PATH)/mockery --name=Balance --dir=$(PWD)/internal/querycoordv2/balance --output=$(PWD)/internal/querycoordv2/balance --filename=mock_balancer.go --with-expecter --structname=MockBalancer --outpkg=balance --inpackage
  396. $(INSTALL_PATH)/mockery --name=Controller --dir=$(PWD)/internal/querycoordv2/dist --output=$(PWD)/internal/querycoordv2/dist --filename=mock_controller.go --with-expecter --structname=MockController --outpkg=dist --inpackage
  397. generate-mockery-querynode: getdeps build-cpp
  398. @source $(PWD)/scripts/setenv.sh # setup PKG_CONFIG_PATH
  399. $(INSTALL_PATH)/mockery --name=QueryHook --dir=$(PWD)/internal/querynodev2/optimizers --output=$(PWD)/internal/querynodev2/optimizers --filename=mock_query_hook.go --with-expecter --outpkg=optimizers --structname=MockQueryHook --inpackage
  400. $(INSTALL_PATH)/mockery --name=Manager --dir=$(PWD)/internal/querynodev2/cluster --output=$(PWD)/internal/querynodev2/cluster --filename=mock_manager.go --with-expecter --outpkg=cluster --structname=MockManager --inpackage
  401. $(INSTALL_PATH)/mockery --name=SegmentManager --dir=$(PWD)/internal/querynodev2/segments --output=$(PWD)/internal/querynodev2/segments --filename=mock_segment_manager.go --with-expecter --outpkg=segments --structname=MockSegmentManager --inpackage
  402. $(INSTALL_PATH)/mockery --name=CollectionManager --dir=$(PWD)/internal/querynodev2/segments --output=$(PWD)/internal/querynodev2/segments --filename=mock_collection_manager.go --with-expecter --outpkg=segments --structname=MockCollectionManager --inpackage
  403. $(INSTALL_PATH)/mockery --name=Loader --dir=$(PWD)/internal/querynodev2/segments --output=$(PWD)/internal/querynodev2/segments --filename=mock_loader.go --with-expecter --outpkg=segments --structname=MockLoader --inpackage
  404. $(INSTALL_PATH)/mockery --name=Segment --dir=$(PWD)/internal/querynodev2/segments --output=$(PWD)/internal/querynodev2/segments --filename=mock_segment.go --with-expecter --outpkg=segments --structname=MockSegment --inpackage
  405. $(INSTALL_PATH)/mockery --name=Worker --dir=$(PWD)/internal/querynodev2/cluster --output=$(PWD)/internal/querynodev2/cluster --filename=mock_worker.go --with-expecter --outpkg=worker --structname=MockWorker --inpackage
  406. $(INSTALL_PATH)/mockery --name=ShardDelegator --dir=$(PWD)/internal/querynodev2/delegator/ --output=$(PWD)/internal/querynodev2/delegator/ --filename=mock_delegator.go --with-expecter --outpkg=delegator --structname=MockShardDelegator --inpackage
  407. generate-mockery-datacoord: getdeps
  408. $(INSTALL_PATH)/mockery --name=compactionPlanContext --dir=internal/datacoord --filename=mock_compaction_plan_context.go --output=internal/datacoord --structname=MockCompactionPlanContext --with-expecter --inpackage
  409. $(INSTALL_PATH)/mockery --name=Handler --dir=internal/datacoord --filename=mock_handler.go --output=internal/datacoord --structname=NMockHandler --with-expecter --inpackage
  410. $(INSTALL_PATH)/mockery --name=Allocator --dir=internal/datacoord/allocator --filename=mock_allocator.go --output=internal/datacoord/allocator --structname=MockAllocator --with-expecter --inpackage
  411. $(INSTALL_PATH)/mockery --name=DataNodeManager --dir=internal/datacoord/session --filename=mock_datanode_manager.go --output=internal/datacoord/session --structname=MockDataNodeManager --with-expecter --inpackage
  412. $(INSTALL_PATH)/mockery --name=RWChannelStore --dir=internal/datacoord --filename=mock_channel_store.go --output=internal/datacoord --structname=MockRWChannelStore --with-expecter --inpackage
  413. $(INSTALL_PATH)/mockery --name=IndexEngineVersionManager --dir=internal/datacoord --filename=mock_index_engine_version_manager.go --output=internal/datacoord --structname=MockVersionManager --with-expecter --inpackage
  414. $(INSTALL_PATH)/mockery --name=TriggerManager --dir=internal/datacoord --filename=mock_trigger_manager.go --output=internal/datacoord --structname=MockTriggerManager --with-expecter --inpackage
  415. $(INSTALL_PATH)/mockery --name=Cluster --dir=internal/datacoord --filename=mock_cluster.go --output=internal/datacoord --structname=MockCluster --with-expecter --inpackage
  416. $(INSTALL_PATH)/mockery --name=compactionPlanContext --dir=internal/datacoord --filename=mock_compaction_plan_context.go --output=internal/datacoord --structname=MockCompactionPlanContext --with-expecter --inpackage
  417. $(INSTALL_PATH)/mockery --name=CompactionMeta --dir=internal/datacoord --filename=mock_compaction_meta.go --output=internal/datacoord --structname=MockCompactionMeta --with-expecter --inpackage
  418. $(INSTALL_PATH)/mockery --name=ChannelManager --dir=internal/datacoord --filename=mock_channelmanager.go --output=internal/datacoord --structname=MockChannelManager --with-expecter --inpackage
  419. $(INSTALL_PATH)/mockery --name=SubCluster --dir=internal/datacoord --filename=mock_subcluster.go --output=internal/datacoord --structname=MockSubCluster --with-expecter --inpackage
  420. $(INSTALL_PATH)/mockery --name=Broker --dir=internal/datacoord/broker --filename=mock_coordinator_broker.go --output=internal/datacoord/broker --structname=MockBroker --with-expecter --inpackage
  421. $(INSTALL_PATH)/mockery --name=WorkerManager --dir=internal/datacoord/session --filename=mock_worker_manager.go --output=internal/datacoord/session --structname=MockWorkerManager --with-expecter --inpackage
  422. $(INSTALL_PATH)/mockery --name=Manager --dir=internal/datacoord --filename=mock_segment_manager.go --output=internal/datacoord --structname=MockManager --with-expecter --inpackage
  423. $(INSTALL_PATH)/mockery --name=StatsJobManager --dir=internal/datacoord --filename=mock_job_manager.go --output=internal/datacoord --structname=MockStatsJobManager --with-expecter --inpackage
  424. generate-mockery-datanode: getdeps
  425. $(INSTALL_PATH)/mockery --name=Allocator --dir=$(PWD)/internal/datanode/allocator --output=$(PWD)/internal/datanode/allocator --filename=mock_allocator.go --with-expecter --structname=MockAllocator --outpkg=allocator --inpackage
  426. $(INSTALL_PATH)/mockery --name=ChannelManager --dir=$(PWD)/internal/datanode/channel --output=$(PWD)/internal/datanode/channel --filename=mock_channelmanager.go --with-expecter --structname=MockChannelManager --outpkg=channel --inpackage
  427. $(INSTALL_PATH)/mockery --name=Compactor --dir=$(PWD)/internal/datanode/compaction --output=$(PWD)/internal/datanode/compaction --filename=mock_compactor.go --with-expecter --structname=MockCompactor --outpkg=compaction --inpackage
  428. generate-mockery-flushcommon: getdeps
  429. $(INSTALL_PATH)/mockery --name=Broker --dir=$(PWD)/internal/flushcommon/broker --output=$(PWD)/internal/flushcommon/broker/ --filename=mock_broker.go --with-expecter --structname=MockBroker --outpkg=broker --inpackage
  430. $(INSTALL_PATH)/mockery --name=MetaCache --dir=$(PWD)/internal/flushcommon/metacache --output=$(PWD)/internal/flushcommon/metacache --filename=mock_meta_cache.go --with-expecter --structname=MockMetaCache --outpkg=metacache --inpackage
  431. $(INSTALL_PATH)/mockery --name=SyncManager --dir=$(PWD)/internal/flushcommon/syncmgr --output=$(PWD)/internal/flushcommon/syncmgr --filename=mock_sync_manager.go --with-expecter --structname=MockSyncManager --outpkg=syncmgr --inpackage
  432. $(INSTALL_PATH)/mockery --name=MetaWriter --dir=$(PWD)/internal/flushcommon/syncmgr --output=$(PWD)/internal/flushcommon/syncmgr --filename=mock_meta_writer.go --with-expecter --structname=MockMetaWriter --outpkg=syncmgr --inpackage
  433. $(INSTALL_PATH)/mockery --name=Serializer --dir=$(PWD)/internal/flushcommon/syncmgr --output=$(PWD)/internal/flushcommon/syncmgr --filename=mock_serializer.go --with-expecter --structname=MockSerializer --outpkg=syncmgr --inpackage
  434. $(INSTALL_PATH)/mockery --name=Task --dir=$(PWD)/internal/flushcommon/syncmgr --output=$(PWD)/internal/flushcommon/syncmgr --filename=mock_task.go --with-expecter --structname=MockTask --outpkg=syncmgr --inpackage
  435. $(INSTALL_PATH)/mockery --name=WriteBuffer --dir=$(PWD)/internal/flushcommon/writebuffer --output=$(PWD)/internal/flushcommon/writebuffer --filename=mock_write_buffer.go --with-expecter --structname=MockWriteBuffer --outpkg=writebuffer --inpackage
  436. $(INSTALL_PATH)/mockery --name=BufferManager --dir=$(PWD)/internal/flushcommon/writebuffer --output=$(PWD)/internal/flushcommon/writebuffer --filename=mock_manager.go --with-expecter --structname=MockBufferManager --outpkg=writebuffer --inpackage
  437. $(INSTALL_PATH)/mockery --name=BinlogIO --dir=$(PWD)/internal/flushcommon/io --output=$(PWD)/internal/flushcommon/io --filename=mock_binlogio.go --with-expecter --structname=MockBinlogIO --outpkg=io --inpackage
  438. $(INSTALL_PATH)/mockery --name=FlowgraphManager --dir=$(PWD)/internal/flushcommon/pipeline --output=$(PWD)/internal/flushcommon/pipeline --filename=mock_fgmanager.go --with-expecter --structname=MockFlowgraphManager --outpkg=pipeline --inpackage
  439. generate-mockery-metastore: getdeps
  440. $(INSTALL_PATH)/mockery --name=RootCoordCatalog --dir=$(PWD)/internal/metastore --output=$(PWD)/internal/metastore/mocks --filename=mock_rootcoord_catalog.go --with-expecter --structname=RootCoordCatalog --outpkg=mocks
  441. $(INSTALL_PATH)/mockery --name=DataCoordCatalog --dir=$(PWD)/internal/metastore --output=$(PWD)/internal/metastore/mocks --filename=mock_datacoord_catalog.go --with-expecter --structname=DataCoordCatalog --outpkg=mocks
  442. $(INSTALL_PATH)/mockery --name=QueryCoordCatalog --dir=$(PWD)/internal/metastore --output=$(PWD)/internal/metastore/mocks --filename=mock_querycoord_catalog.go --with-expecter --structname=QueryCoordCatalog --outpkg=mocks
  443. generate-mockery-utils: getdeps
  444. # dependency.Factory
  445. $(INSTALL_PATH)/mockery --name=Factory --dir=internal/util/dependency --output=internal/util/dependency --filename=mock_factory.go --with-expecter --structname=MockFactory --inpackage
  446. # tso.Allocator
  447. $(INSTALL_PATH)/mockery --name=Allocator --dir=internal/tso --output=internal/tso/mocks --filename=allocator.go --with-expecter --structname=Allocator --outpkg=mocktso
  448. $(INSTALL_PATH)/mockery --name=SessionInterface --dir=$(PWD)/internal/util/sessionutil --output=$(PWD)/internal/util/sessionutil --filename=mock_session.go --with-expecter --structname=MockSession --inpackage
  449. $(INSTALL_PATH)/mockery --name=GrpcClient --dir=$(PWD)/internal/util/grpcclient --output=$(PWD)/internal/mocks --filename=mock_grpc_client.go --with-expecter --structname=MockGrpcClient
  450. # proxy_client_manager.go
  451. $(INSTALL_PATH)/mockery --name=ProxyClientManagerInterface --dir=$(PWD)/internal/util/proxyutil --output=$(PWD)/internal/util/proxyutil --filename=mock_proxy_client_manager.go --with-expecter --structname=MockProxyClientManager --inpackage
  452. $(INSTALL_PATH)/mockery --name=ProxyWatcherInterface --dir=$(PWD)/internal/util/proxyutil --output=$(PWD)/internal/util/proxyutil --filename=mock_proxy_watcher.go --with-expecter --structname=MockProxyWatcher --inpackage
  453. # function
  454. $(INSTALL_PATH)/mockery --name=FunctionRunner --dir=$(PWD)/internal/util/function --output=$(PWD)/internal/util/function --filename=mock_function.go --with-expecter --structname=MockFunctionRunner --inpackage
  455. $(INSTALL_PATH)/mockery --name=GlobalIDAllocatorInterface --dir=internal/allocator --output=internal/allocator --filename=mock_global_id_allocator.go --with-expecter --structname=MockGlobalIDAllocator --inpackage
  456. generate-mockery-kv: getdeps
  457. $(INSTALL_PATH)/mockery --name=TxnKV --dir=$(PWD)/pkg/kv --output=$(PWD)/internal/kv/mocks --filename=txn_kv.go --with-expecter
  458. $(INSTALL_PATH)/mockery --name=MetaKv --dir=$(PWD)/pkg/kv --output=$(PWD)/internal/kv/mocks --filename=meta_kv.go --with-expecter
  459. $(INSTALL_PATH)/mockery --name=WatchKV --dir=$(PWD)/pkg/kv --output=$(PWD)/internal/kv/mocks --filename=watch_kv.go --with-expecter
  460. $(INSTALL_PATH)/mockery --name=SnapShotKV --dir=$(PWD)/pkg/kv --output=$(PWD)/internal/kv/mocks --filename=snapshot_kv.go --with-expecter
  461. $(INSTALL_PATH)/mockery --name=Predicate --dir=$(PWD)/pkg/kv/predicates --output=$(PWD)/internal/kv/predicates --filename=mock_predicate.go --with-expecter --inpackage
  462. generate-mockery-chunk-manager: getdeps
  463. $(INSTALL_PATH)/mockery --name=ChunkManager --dir=$(PWD)/internal/storage --output=$(PWD)/internal/mocks --filename=mock_chunk_manager.go --with-expecter
  464. generate-mockery-pkg:
  465. $(MAKE) -C pkg generate-mockery
  466. generate-mockery-internal: getdeps
  467. $(INSTALL_PATH)/mockery --config $(PWD)/internal/.mockery.yaml
  468. generate-mockery: generate-mockery-types generate-mockery-kv generate-mockery-rootcoord generate-mockery-proxy generate-mockery-querycoord generate-mockery-querynode generate-mockery-datacoord generate-mockery-pkg generate-mockery-internal
  469. generate-yaml: milvus-tools
  470. @echo "Updating milvus config yaml"
  471. @$(PWD)/bin/tools/config gen-yaml && mv milvus.yaml configs/milvus.yaml
  472. MMAP_MIGRATION_PATH = $(PWD)/cmd/tools/migration/mmap/tool
  473. mmap-migration:
  474. @echo "Building migration tool ..."
  475. @source $(PWD)/scripts/setenv.sh && \
  476. mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && \
  477. GO111MODULE=on $(GO) build -pgo=$(PGO_PATH)/default.pgo -ldflags="-r $${RPATH} -X '$(OBJPREFIX).BuildTags=$(BUILD_TAGS)' -X '$(OBJPREFIX).BuildTime=$(BUILD_TIME)' -X '$(OBJPREFIX).GitCommit=$(GIT_COMMIT)' -X '$(OBJPREFIX).GoVersion=$(GO_VERSION)'" \
  478. -tags dynamic -o $(INSTALL_PATH)/mmap-migration $(MMAP_MIGRATION_PATH)/main.go 1>/dev/null