2020-10-30 08:25:06 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2021-10-09 10:01:27 +00:00
|
|
|
# Licensed to the LF AI & Data foundation under one
|
|
|
|
# or more contributor license agreements. See the NOTICE file
|
|
|
|
# distributed with this work for additional information
|
|
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
|
|
# to you 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.
|
|
|
|
|
2021-11-17 02:37:16 +00:00
|
|
|
# Exit immediately for non zero status
|
2020-10-30 08:25:06 +00:00
|
|
|
set -e
|
|
|
|
|
2022-06-28 11:58:25 +00:00
|
|
|
BASEDIR=$(dirname "$0")
|
|
|
|
source $BASEDIR/setenv.sh
|
2022-06-24 13:12:15 +00:00
|
|
|
|
2022-04-28 13:03:47 +00:00
|
|
|
if [[ $(uname -s) == "Darwin" ]]; then
|
|
|
|
export MallocNanoZone=0
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ "$(uname -m)" == "arm64" ]]; then
|
2022-04-20 15:03:41 +00:00
|
|
|
APPLE_SILICON_FLAG="-tags dynamic"
|
2022-02-09 06:27:46 +00:00
|
|
|
fi
|
|
|
|
|
2021-10-11 10:58:29 +00:00
|
|
|
# ignore MinIO,S3 unittes
|
2021-01-12 10:03:24 +00:00
|
|
|
MILVUS_DIR="${ROOT_DIR}/internal/"
|
2021-10-05 04:32:26 +00:00
|
|
|
echo "Running go unittest under $MILVUS_DIR"
|
2021-01-12 10:03:24 +00:00
|
|
|
|
2022-09-08 09:36:35 +00:00
|
|
|
TEST_ALL=1
|
|
|
|
TEST_TAG="ALL"
|
|
|
|
|
|
|
|
while getopts "t:h" arg; do
|
|
|
|
case $arg in
|
|
|
|
t)
|
|
|
|
TEST_ALL=0
|
|
|
|
TEST_TAG=$OPTARG
|
|
|
|
;;
|
|
|
|
h) # help
|
|
|
|
echo "
|
|
|
|
parameter:
|
|
|
|
-t: test tag(default: all)
|
|
|
|
-h: help
|
|
|
|
|
|
|
|
usage:
|
|
|
|
./go_run_unittest.sh -t \${TEST_TAG}
|
|
|
|
"
|
|
|
|
exit 0
|
|
|
|
;;
|
|
|
|
?)
|
|
|
|
echo "ERROR! unknown argument"
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
function test_proxy()
|
|
|
|
{
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/proxy/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/distributed/proxy/..." -failfast
|
|
|
|
}
|
|
|
|
|
2022-09-15 10:48:32 +00:00
|
|
|
function test_querycoordv2()
|
|
|
|
{
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/querycoordv2/..." -failfast
|
|
|
|
}
|
|
|
|
|
2022-09-08 09:36:35 +00:00
|
|
|
function test_querynode()
|
|
|
|
{
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/querynode/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/distributed/querynode/..." -failfast
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function test_kv()
|
|
|
|
{
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/kv/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_mq()
|
|
|
|
{
|
2022-08-12 05:30:38 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} $(go list "${MILVUS_DIR}/mq/..." | grep -v kafka) -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_storage()
|
|
|
|
{
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/storage" -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_allocator()
|
|
|
|
{
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/allocator/..." -failfast
|
|
|
|
}
|
|
|
|
|
|
|
|
function test_tso()
|
|
|
|
{
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/tso/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_config()
|
|
|
|
{
|
2022-08-01 02:04:33 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/config/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_util()
|
|
|
|
{
|
2022-10-08 07:38:58 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/util/autoindex/..." -failfast
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/util/funcutil/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/util/paramtable/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/util/retry/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/util/sessionutil/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/util/trace/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/util/typeutil/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/util/importutil/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_datanode
|
|
|
|
{
|
|
|
|
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/datanode/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/distributed/datanode/..." -failfast
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function test_indexnode()
|
|
|
|
{
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/indexnode/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_rootcoord()
|
|
|
|
{
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/distributed/rootcoord/..." -failfast
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/rootcoord" -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_datacoord()
|
|
|
|
{
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/distributed/datacoord/..." -failfast
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/datacoord/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_querycoord()
|
|
|
|
{
|
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/distributed/querycoord/..." -failfast
|
2022-09-08 12:38:35 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/querycoord/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_indexcoord()
|
|
|
|
{
|
2022-06-28 11:58:25 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/indexcoord/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_metastore()
|
|
|
|
{
|
2022-08-23 02:26:53 +00:00
|
|
|
go test -race -cover ${APPLE_SILICON_FLAG} "${MILVUS_DIR}/metastore/..." -failfast
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function test_all()
|
|
|
|
{
|
|
|
|
test_proxy
|
|
|
|
test_querynode
|
|
|
|
test_datanode
|
|
|
|
test_indexnode
|
|
|
|
test_rootcoord
|
|
|
|
test_querycoord
|
|
|
|
test_datacoord
|
|
|
|
test_indexcoord
|
|
|
|
test_kv
|
|
|
|
test_mq
|
|
|
|
test_storage
|
|
|
|
test_allocator
|
|
|
|
test_tso
|
|
|
|
test_config
|
|
|
|
test_util
|
|
|
|
test_metastore
|
2022-09-15 10:48:32 +00:00
|
|
|
test_querycoordv2
|
2022-09-08 09:36:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case "${TEST_TAG}" in
|
|
|
|
proxy)
|
|
|
|
test_proxy
|
|
|
|
;;
|
|
|
|
querynode)
|
|
|
|
test_querynode
|
|
|
|
;;
|
|
|
|
datanode)
|
|
|
|
test_datanode
|
|
|
|
;;
|
|
|
|
indexnode)
|
|
|
|
test_indexnode
|
|
|
|
;;
|
|
|
|
rootcoord)
|
|
|
|
test_rootcoord
|
|
|
|
;;
|
|
|
|
querycoord)
|
|
|
|
test_querycoord
|
|
|
|
;;
|
|
|
|
datacoord)
|
|
|
|
test_datacoord
|
|
|
|
;;
|
|
|
|
indexcoord)
|
|
|
|
test_indexcoord
|
|
|
|
;;
|
|
|
|
kv)
|
|
|
|
test_kv
|
|
|
|
;;
|
|
|
|
mq)
|
|
|
|
test_mq
|
|
|
|
;;
|
|
|
|
storage)
|
|
|
|
test_storage
|
|
|
|
;;
|
|
|
|
allocator)
|
|
|
|
test_allocator
|
|
|
|
;;
|
|
|
|
tso)
|
|
|
|
test_tso
|
|
|
|
;;
|
|
|
|
config)
|
|
|
|
test_config
|
|
|
|
;;
|
|
|
|
util)
|
|
|
|
test_util
|
|
|
|
;;
|
|
|
|
metastore)
|
|
|
|
test_metastore
|
|
|
|
;;
|
|
|
|
*) echo "Test All";
|
|
|
|
test_all
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2021-10-06 11:28:47 +00:00
|
|
|
|
2021-10-09 10:01:27 +00:00
|
|
|
echo " Go unittest finished"
|