2020-10-30 08:25:06 +00:00
|
|
|
# Copyright (C) 2019-2020 Zilliz. All rights reserved.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
|
|
|
|
# with the License. You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software distributed under the License
|
|
|
|
# is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
|
|
|
|
# or implied. See the License for the specific language governing permissions and limitations under the License.
|
|
|
|
|
|
|
|
GO ?= go
|
|
|
|
PWD := $(shell pwd)
|
|
|
|
GOPATH := $(shell $(GO) env GOPATH)
|
|
|
|
|
|
|
|
INSTALL_PATH := $(PWD)/bin
|
|
|
|
LIBRARY_PATH := $(PWD)/lib
|
|
|
|
|
2020-11-09 10:47:37 +00:00
|
|
|
all: build-cpp build-go
|
2020-10-30 08:25:06 +00:00
|
|
|
|
|
|
|
get-build-deps:
|
|
|
|
@(env bash $(PWD)/scripts/install_deps.sh)
|
|
|
|
|
2020-12-09 12:07:27 +00:00
|
|
|
getdeps:
|
|
|
|
@mkdir -p ${GOPATH}/bin
|
|
|
|
@which golangci-lint 1>/dev/null || (echo "Installing golangci-lint" && curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(GOPATH)/bin v1.27.0)
|
2021-01-13 05:36:27 +00:00
|
|
|
@which ruleguard 1>/dev/null || (echo "Installing ruleguard" && go get github.com/quasilyte/go-ruleguard/cmd/ruleguard@v0.2.1)
|
2020-12-09 12:07:27 +00:00
|
|
|
|
2020-12-31 09:25:45 +00:00
|
|
|
tools/bin/revive: tools/check/go.mod
|
|
|
|
cd tools/check; \
|
|
|
|
$(GO) build -o ../bin/revive github.com/mgechev/revive
|
|
|
|
|
2020-11-23 11:57:05 +00:00
|
|
|
cppcheck:
|
|
|
|
@(env bash ${PWD}/scripts/core_build.sh -l)
|
2020-11-18 02:07:05 +00:00
|
|
|
|
|
|
|
generated-proto-go:export protoc:=${PWD}/cmake_build/thirdparty/protobuf/protobuf-build/protoc
|
|
|
|
generated-proto-go: build-cpp
|
2020-12-09 12:07:27 +00:00
|
|
|
@mkdir -p ${GOPATH}/bin
|
|
|
|
@which protoc-gen-go 1>/dev/null || (echo "Installing protoc-gen-go" && go get github.com/golang/protobuf/protoc-gen-go@v1.3.2)
|
2020-11-18 02:07:05 +00:00
|
|
|
@(env bash $(PWD)/scripts/proto_gen_go.sh)
|
|
|
|
|
|
|
|
check-proto-product: generated-proto-go
|
|
|
|
@(env bash $(PWD)/scripts/check_proto_product.sh)
|
|
|
|
|
2020-10-30 08:25:06 +00:00
|
|
|
fmt:
|
2020-12-29 09:19:44 +00:00
|
|
|
ifdef GO_DIFF_FILES
|
|
|
|
@echo "Running $@ check"
|
|
|
|
@GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh $(GO_DIFF_FILES)
|
|
|
|
else
|
2020-10-30 08:25:06 +00:00
|
|
|
@echo "Running $@ check"
|
2020-11-18 02:07:05 +00:00
|
|
|
@GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh cmd/
|
|
|
|
@GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh internal/
|
2020-12-03 11:00:11 +00:00
|
|
|
@GO111MODULE=on env bash $(PWD)/scripts/gofmt.sh tests/go/
|
2020-12-29 09:19:44 +00:00
|
|
|
endif
|
2020-10-30 08:25:06 +00:00
|
|
|
|
2020-12-31 09:25:45 +00:00
|
|
|
lint:tools/bin/revive
|
|
|
|
@echo "Running $@ check"
|
|
|
|
@tools/bin/revive -formatter friendly -config tools/check/revive.toml ./...
|
|
|
|
|
2020-10-30 08:25:06 +00:00
|
|
|
#TODO: Check code specifications by golangci-lint
|
2021-01-14 07:12:08 +00:00
|
|
|
static-check:
|
2020-10-30 08:25:06 +00:00
|
|
|
@echo "Running $@ check"
|
|
|
|
@GO111MODULE=on ${GOPATH}/bin/golangci-lint cache clean
|
2020-12-08 06:41:04 +00:00
|
|
|
@GO111MODULE=on ${GOPATH}/bin/golangci-lint run --timeout=30m --config ./.golangci.yml ./internal/...
|
|
|
|
@GO111MODULE=on ${GOPATH}/bin/golangci-lint run --timeout=30m --config ./.golangci.yml ./cmd/...
|
|
|
|
@GO111MODULE=on ${GOPATH}/bin/golangci-lint run --timeout=30m --config ./.golangci.yml ./tests/go/...
|
2020-10-30 08:25:06 +00:00
|
|
|
|
2020-11-03 03:25:47 +00:00
|
|
|
ruleguard:
|
2020-12-29 09:19:44 +00:00
|
|
|
ifdef GO_DIFF_FILES
|
|
|
|
@echo "Running $@ check"
|
|
|
|
@${GOPATH}/bin/ruleguard -rules ruleguard.rules.go $(GO_DIFF_FILES)
|
|
|
|
else
|
2020-11-03 03:25:47 +00:00
|
|
|
@echo "Running $@ check"
|
2020-11-13 02:00:32 +00:00
|
|
|
@${GOPATH}/bin/ruleguard -rules ruleguard.rules.go ./internal/...
|
|
|
|
@${GOPATH}/bin/ruleguard -rules ruleguard.rules.go ./cmd/...
|
2020-12-03 11:00:11 +00:00
|
|
|
@${GOPATH}/bin/ruleguard -rules ruleguard.rules.go ./tests/go/...
|
2020-12-29 09:19:44 +00:00
|
|
|
endif
|
2020-11-03 03:25:47 +00:00
|
|
|
|
2021-01-13 05:36:27 +00:00
|
|
|
verifiers: getdeps cppcheck fmt static-check ruleguard
|
2020-10-30 08:25:06 +00:00
|
|
|
|
2021-01-18 11:32:08 +00:00
|
|
|
# Builds various components locally.
|
2021-02-20 02:15:37 +00:00
|
|
|
|
|
|
|
master: build-cpp
|
|
|
|
@echo "Building each component's binary to './bin'"
|
|
|
|
@echo "Building masterservice ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/masterservice $(PWD)/cmd/masterservice/main.go 1>/dev/null
|
|
|
|
|
2021-01-18 11:32:08 +00:00
|
|
|
proxynode: build-cpp
|
|
|
|
@echo "Building each component's binary to './bin'"
|
2021-01-26 11:24:09 +00:00
|
|
|
@echo "Building proxy node ..."
|
2021-01-22 01:36:18 +00:00
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="0" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/proxynode $(PWD)/cmd/proxy/node/proxy_node.go 1>/dev/null
|
2021-01-18 11:32:08 +00:00
|
|
|
|
|
|
|
# Builds various components locally.
|
|
|
|
querynode: build-cpp
|
|
|
|
@echo "Building each component's binary to './bin'"
|
|
|
|
@echo "Building query node ..."
|
2021-01-27 01:50:52 +00:00
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/querynode $(PWD)/cmd/querynode/querynode.go 1>/dev/null
|
2021-01-18 11:32:08 +00:00
|
|
|
|
2021-01-26 06:46:54 +00:00
|
|
|
# Builds various components locally.
|
|
|
|
datanode: build-cpp
|
|
|
|
@echo "Building each component's binary to './bin'"
|
|
|
|
@echo "Building data node ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/datanode $(PWD)/cmd/datanode/main.go 1>/dev/null
|
|
|
|
|
2021-01-18 11:32:08 +00:00
|
|
|
# Builds various components locally.
|
|
|
|
indexnode: build-cpp
|
|
|
|
@echo "Building each component's binary to './bin'"
|
2021-01-26 11:24:09 +00:00
|
|
|
@echo "Building distributed indexnode ..."
|
2021-01-29 09:08:31 +00:00
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/indexnode $(PWD)/cmd/indexnode/main.go 1>/dev/null
|
2021-01-26 11:24:09 +00:00
|
|
|
|
|
|
|
indexservice: build-cpp
|
|
|
|
@echo "Building each component's binary to './bin'"
|
|
|
|
@echo "Building distributed indexservice ..."
|
2021-01-29 09:08:31 +00:00
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/indexservice $(PWD)/cmd/indexservice/main.go 1>/dev/null
|
2021-01-18 11:32:08 +00:00
|
|
|
|
2021-03-10 02:02:55 +00:00
|
|
|
singlenode: build-cpp
|
|
|
|
@echo "Building singlenode ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/singlenode $(PWD)/cmd/singlenode/main.go 1>/dev/null
|
|
|
|
|
2021-03-11 10:42:25 +00:00
|
|
|
queryservice: build-cpp
|
|
|
|
@echo "Building each component's binary to './bin'"
|
|
|
|
@echo "Building distributed queryservice ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/queryservice $(PWD)/cmd/queryservice/queryservice.go 1>/dev/null
|
2021-01-18 11:32:08 +00:00
|
|
|
|
2021-03-16 09:55:42 +00:00
|
|
|
dataservice: build-cpp
|
|
|
|
@echo "Building dataservice ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/dataservice $(PWD)/cmd/dataservice/main.go 1>/dev/null
|
|
|
|
|
2020-10-30 08:25:06 +00:00
|
|
|
# Builds various components locally.
|
2021-01-14 07:12:08 +00:00
|
|
|
build-go: build-cpp
|
2020-11-30 11:08:32 +00:00
|
|
|
@echo "Building each component's binary to './bin'"
|
2021-01-25 07:58:04 +00:00
|
|
|
@echo "Building masterservice ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/masterservice $(PWD)/cmd/masterservice/main.go 1>/dev/null
|
2021-01-22 04:57:23 +00:00
|
|
|
@echo "Building proxy service ..."
|
2021-01-26 05:41:41 +00:00
|
|
|
# TODO: fix me, why proxy service need cgo enabled
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/proxyservice $(PWD)/cmd/proxy/service/proxy_service.go 1>/dev/null
|
2021-01-22 01:36:18 +00:00
|
|
|
@echo "Building proxy node ..."
|
2021-01-26 05:41:41 +00:00
|
|
|
# TODO: fix me, why proxy node need cgo enabled
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/proxynode $(PWD)/cmd/proxy/node/proxy_node.go 1>/dev/null
|
2021-01-27 01:50:52 +00:00
|
|
|
@echo "Building query service ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/queryservice $(PWD)/cmd/queryservice/queryservice.go 1>/dev/null
|
2021-02-02 01:52:42 +00:00
|
|
|
@echo "Building query node ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/querynode $(PWD)/cmd/querynode/querynode.go 1>/dev/null
|
2020-12-30 06:09:00 +00:00
|
|
|
@echo "Building binlog ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/binlog $(PWD)/cmd/binlog/main.go 1>/dev/null
|
2021-01-14 01:52:03 +00:00
|
|
|
@echo "Building singlenode ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/singlenode $(PWD)/cmd/singlenode/main.go 1>/dev/null
|
2021-01-20 10:26:20 +00:00
|
|
|
@echo "Building distributed indexservice ..."
|
2021-01-29 09:08:31 +00:00
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/indexservice $(PWD)/cmd/indexservice/main.go 1>/dev/null
|
2021-01-20 10:26:20 +00:00
|
|
|
@echo "Building distributed indexnode ..."
|
2021-01-29 09:08:31 +00:00
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/indexnode $(PWD)/cmd/indexnode/main.go 1>/dev/null
|
2021-01-26 09:40:26 +00:00
|
|
|
@echo "Building data node ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/datanode $(PWD)/cmd/datanode/main.go 1>/dev/null
|
2021-01-26 08:36:26 +00:00
|
|
|
@echo "Building dataservice ..."
|
|
|
|
@mkdir -p $(INSTALL_PATH) && go env -w CGO_ENABLED="1" && GO111MODULE=on $(GO) build -o $(INSTALL_PATH)/dataservice $(PWD)/cmd/dataservice/main.go 1>/dev/null
|
2020-10-30 08:25:06 +00:00
|
|
|
|
2021-01-25 07:58:04 +00:00
|
|
|
|
2020-10-30 08:25:06 +00:00
|
|
|
build-cpp:
|
2020-12-08 11:53:22 +00:00
|
|
|
@(env bash $(PWD)/scripts/core_build.sh -f "$(CUSTOM_THIRDPARTY_PATH)")
|
|
|
|
@(env bash $(PWD)/scripts/cwrapper_build.sh -t Release -f "$(CUSTOM_THIRDPARTY_PATH)")
|
2021-01-14 07:12:08 +00:00
|
|
|
@go env -w CGO_CFLAGS="-I$(PWD)/internal/kv/rocksdb/cwrapper/output/include"
|
|
|
|
@go env -w CGO_LDFLAGS="-L$(PWD)/internal/kv/rocksdb/cwrapper/output/lib -l:librocksdb.a -lstdc++ -lm -lz"
|
|
|
|
@(env bash $(PWD)/scripts/cwrapper_rocksdb_build.sh -t Release -f "$(CUSTOM_THIRDPARTY_PATH)")
|
|
|
|
@go get github.com/tecbot/gorocksdb
|
2020-10-30 08:25:06 +00:00
|
|
|
|
|
|
|
build-cpp-with-unittest:
|
2020-12-08 11:53:22 +00:00
|
|
|
@(env bash $(PWD)/scripts/core_build.sh -u -f "$(CUSTOM_THIRDPARTY_PATH)")
|
|
|
|
@(env bash $(PWD)/scripts/cwrapper_build.sh -t Release -f "$(CUSTOM_THIRDPARTY_PATH)")
|
2020-10-30 08:25:06 +00:00
|
|
|
|
|
|
|
# Runs the tests.
|
2020-10-31 08:30:20 +00:00
|
|
|
unittest: test-cpp test-go
|
2020-10-30 08:25:06 +00:00
|
|
|
|
2021-01-22 01:36:18 +00:00
|
|
|
#TODO: proxynode master query node writer's unittest
|
2021-01-14 07:12:08 +00:00
|
|
|
test-go:build-cpp
|
2020-10-30 08:25:06 +00:00
|
|
|
@echo "Running go unittests..."
|
2021-01-26 05:41:41 +00:00
|
|
|
@echo "disable go unittest for now, enable it later"
|
2021-01-29 01:27:26 +00:00
|
|
|
@(env bash $(PWD)/scripts/run_go_unittest.sh)
|
2020-10-30 08:25:06 +00:00
|
|
|
|
|
|
|
test-cpp: build-cpp-with-unittest
|
2020-11-03 03:25:47 +00:00
|
|
|
@echo "Running cpp unittests..."
|
2020-10-30 08:25:06 +00:00
|
|
|
@(env bash $(PWD)/scripts/run_cpp_unittest.sh)
|
|
|
|
|
|
|
|
#TODO: build each component to docker
|
|
|
|
docker: verifiers
|
|
|
|
|
|
|
|
# Builds each component and installs it to $GOPATH/bin.
|
|
|
|
install: all
|
|
|
|
@echo "Installing binary to './bin'"
|
2021-02-20 02:15:37 +00:00
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/masterservice $(GOPATH)/bin/masterservice
|
2021-01-27 01:50:52 +00:00
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/queryservice $(GOPATH)/bin/queryservice
|
2020-11-26 08:01:31 +00:00
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/querynode $(GOPATH)/bin/querynode
|
2021-01-22 01:36:18 +00:00
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/proxynode $(GOPATH)/bin/proxynode
|
2021-01-22 04:57:23 +00:00
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/proxyservice $(GOPATH)/bin/proxyservice
|
2021-01-14 01:52:03 +00:00
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/singlenode $(GOPATH)/bin/singlenode
|
2021-01-26 06:31:31 +00:00
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/indexservice $(GOPATH)/bin/indexservice
|
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/indexnode $(GOPATH)/bin/indexnode
|
2021-02-20 02:15:37 +00:00
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/dataservice $(GOPATH)/bin/dataservice
|
|
|
|
@mkdir -p $(GOPATH)/bin && cp -f $(PWD)/bin/datanode $(GOPATH)/bin/datanode
|
2020-10-30 08:25:06 +00:00
|
|
|
@mkdir -p $(LIBRARY_PATH) && cp -f $(PWD)/internal/core/output/lib/* $(LIBRARY_PATH)
|
|
|
|
@echo "Installation successful."
|
|
|
|
|
|
|
|
clean:
|
|
|
|
@echo "Cleaning up all the generated files"
|
|
|
|
@find . -name '*.test' | xargs rm -fv
|
|
|
|
@find . -name '*~' | xargs rm -fv
|
2021-01-11 10:35:54 +00:00
|
|
|
@rm -rf bin/
|
|
|
|
@rm -rf lib/
|
2021-02-20 02:15:37 +00:00
|
|
|
@rm -rf $(GOPATH)/bin/masterservice
|
2021-01-22 01:36:18 +00:00
|
|
|
@rm -rf $(GOPATH)/bin/proxynode
|
2021-01-22 04:57:23 +00:00
|
|
|
@rm -rf $(GOPATH)/bin/proxyservice
|
2021-01-27 01:50:52 +00:00
|
|
|
@rm -rf $(GOPATH)/bin/queryservice
|
2021-01-11 10:35:54 +00:00
|
|
|
@rm -rf $(GOPATH)/bin/querynode
|
2021-01-14 01:52:03 +00:00
|
|
|
@rm -rf $(GOPATH)/bin/singlenode
|
2021-01-26 06:31:31 +00:00
|
|
|
@rm -rf $(GOPATH)/bin/indexservice
|
|
|
|
@rm -rf $(GOPATH)/bin/indexnode
|
2021-02-20 02:15:37 +00:00
|
|
|
@rm -rf $(GOPATH)/bin/dataservice
|
|
|
|
@rm -rf $(GOPATH)/bin/datanode
|