mirror of
https://gitee.com/milvus-io/milvus.git
synced 2024-11-30 10:59:32 +08:00
86274f70bd
improve concurrency and reduce import test execution time --------- Signed-off-by: zhuwenxing <wenxing.zhu@zilliz.com>
146 lines
6.1 KiB
Bash
Executable File
146 lines
6.1 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# 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.
|
|
|
|
SOURCE="${BASH_SOURCE[0]}"
|
|
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
|
SOURCE="$(readlink "$SOURCE")"
|
|
[[ $SOURCE != /* ]] && SOURCE="$DIR/$SOURCE" # if $SOURCE was a relative symlink, we need to resolve it relative to the path where the symlink file was located
|
|
done
|
|
ROOT="$( cd -P "$( dirname "$SOURCE" )/../.." && pwd )"
|
|
|
|
# Exit immediately for non zero status
|
|
set -e
|
|
# Check unset variables
|
|
set -u
|
|
# Print commands
|
|
set -x
|
|
|
|
|
|
|
|
MILVUS_HELM_RELEASE_NAME="${MILVUS_HELM_RELEASE_NAME:-milvus-testing}"
|
|
MILVUS_CLUSTER_ENABLED="${MILVUS_CLUSTER_ENABLED:-false}"
|
|
MILVUS_HELM_NAMESPACE="${MILVUS_HELM_NAMESPACE:-default}"
|
|
PARALLEL_NUM="${PARALLEL_NUM:-6}"
|
|
# Use service name instead of IP to test
|
|
MILVUS_SERVICE_NAME=$(echo "${MILVUS_HELM_RELEASE_NAME}-milvus.${MILVUS_HELM_NAMESPACE}" | tr -d '\n')
|
|
# MILVUS_SERVICE_HOST=$(kubectl get svc ${MILVUS_SERVICE_NAME}-milvus -n ${MILVUS_HELM_NAMESPACE} -o jsonpath='{.spec.clusterIP}')
|
|
MILVUS_SERVICE_PORT="19530"
|
|
# Minio service name
|
|
MINIO_SERVICE_NAME=$(echo "${MILVUS_HELM_RELEASE_NAME}-minio.${MILVUS_HELM_NAMESPACE}" | tr -d '\n')
|
|
|
|
|
|
# Shellcheck source=ci-util.sh
|
|
source "${ROOT}/tests/scripts/ci-util-4am.sh"
|
|
|
|
|
|
cd ${ROOT}/tests/python_client
|
|
|
|
# Print python3 version, python version 3.6.8 is more stable for test
|
|
python3 -V
|
|
|
|
# Pytest will try to get ${CI_LOG_PATH} from environment variables first,then use default path
|
|
export CI_LOG_PATH=/tmp/ci_logs/test
|
|
|
|
if [ ! -d "${CI_LOG_PATH}" ]; then
|
|
# Create dir for ci log path when it does not exist
|
|
mkdir -p ${CI_LOG_PATH}
|
|
fi
|
|
|
|
echo "prepare e2e test"
|
|
install_pytest_requirements
|
|
|
|
|
|
|
|
|
|
cd ${ROOT}/tests/python_client
|
|
# Run bulk insert test
|
|
# if MILVUS_HELM_RELEASE_NAME contains "msop", then it is one pod mode, skip the bulk insert test
|
|
if [[ "${MILVUS_HELM_RELEASE_NAME}" != *"msop"* ]]; then
|
|
if [[ -n "${TEST_TIMEOUT:-}" ]]; then
|
|
|
|
timeout "${TEST_TIMEOUT}" pytest testcases/test_bulk_insert.py --timeout=300 -n 6 --host ${MILVUS_SERVICE_NAME} --port ${MILVUS_SERVICE_PORT} --minio_host ${MINIO_SERVICE_NAME} \
|
|
--html=${CI_LOG_PATH}/report_bulk_insert.html --self-contained-html
|
|
else
|
|
pytest testcases/test_bulk_insert.py --timeout=300 -n 6 --host ${MILVUS_SERVICE_NAME} --port ${MILVUS_SERVICE_PORT} --minio_host ${MINIO_SERVICE_NAME} \
|
|
--html=${CI_LOG_PATH}/report_bulk_insert.html --self-contained-html
|
|
fi
|
|
fi
|
|
|
|
|
|
# Run restful test v1
|
|
|
|
cd ${ROOT}/tests/restful_client
|
|
|
|
if [[ -n "${TEST_TIMEOUT:-}" ]]; then
|
|
|
|
timeout "${TEST_TIMEOUT}" pytest testcases --endpoint http://${MILVUS_SERVICE_NAME}:${MILVUS_SERVICE_PORT} -v -x -m L0 -n 6 --timeout 180\
|
|
--html=${CI_LOG_PATH}/report_restful.html --self-contained-html
|
|
else
|
|
pytest testcases --endpoint http://${MILVUS_SERVICE_NAME}:${MILVUS_SERVICE_PORT} -v -x -m L0 -n 6 --timeout 180\
|
|
--html=${CI_LOG_PATH}/report_restful.html --self-contained-html
|
|
fi
|
|
|
|
# Run restful test v2
|
|
cd ${ROOT}/tests/restful_client_v2
|
|
|
|
if [[ -n "${TEST_TIMEOUT:-}" ]]; then
|
|
|
|
timeout "${TEST_TIMEOUT}" pytest testcases --endpoint http://${MILVUS_SERVICE_NAME}:${MILVUS_SERVICE_PORT} --minio_host ${MINIO_SERVICE_NAME} -v -x -m L0 -n 6 --timeout 180\
|
|
--html=${CI_LOG_PATH}/report_restful.html --self-contained-html
|
|
else
|
|
pytest testcases --endpoint http://${MILVUS_SERVICE_NAME}:${MILVUS_SERVICE_PORT} --minio_host ${MINIO_SERVICE_NAME} -v -x -m L0 -n 6 --timeout 180\
|
|
--html=${CI_LOG_PATH}/report_restful.html --self-contained-html
|
|
fi
|
|
|
|
|
|
if [[ "${MILVUS_HELM_RELEASE_NAME}" != *"msop"* ]]; then
|
|
if [[ -n "${TEST_TIMEOUT:-}" ]]; then
|
|
|
|
timeout "${TEST_TIMEOUT}" pytest testcases --endpoint http://${MILVUS_SERVICE_NAME}:${MILVUS_SERVICE_PORT} --minio_host ${MINIO_SERVICE_NAME} -v -x -m BulkInsert -n 6 --timeout 180\
|
|
--html=${CI_LOG_PATH}/report_restful.html --self-contained-html
|
|
else
|
|
pytest testcases --endpoint http://${MILVUS_SERVICE_NAME}:${MILVUS_SERVICE_PORT} --minio_host ${MINIO_SERVICE_NAME} -v -x -m BulkInsert -n 6 --timeout 180\
|
|
--html=${CI_LOG_PATH}/report_restful.html --self-contained-html
|
|
fi
|
|
fi
|
|
|
|
|
|
cd ${ROOT}/tests/python_client
|
|
|
|
|
|
# Pytest is not able to have both --timeout & --workers, so do not add --timeout or --workers in the shell script
|
|
if [[ -n "${TEST_TIMEOUT:-}" ]]; then
|
|
|
|
timeout "${TEST_TIMEOUT}" pytest --host ${MILVUS_SERVICE_NAME} --port ${MILVUS_SERVICE_PORT} \
|
|
--html=${CI_LOG_PATH}/report.html --self-contained-html ${@:-}
|
|
else
|
|
pytest --host ${MILVUS_SERVICE_NAME} --port ${MILVUS_SERVICE_PORT} \
|
|
--html=${CI_LOG_PATH}/report.html --self-contained-html ${@:-}
|
|
fi
|
|
|
|
# # Run concurrent test with 5 processes
|
|
# if [[ -n "${TEST_TIMEOUT:-}" ]]; then
|
|
|
|
# timeout "${TEST_TIMEOUT}" pytest testcases/test_concurrent.py --host ${MILVUS_SERVICE_NAME} --port ${MILVUS_SERVICE_PORT} --count 5 -n 5 \
|
|
# --html=${CI_LOG_PATH}/report_concurrent.html --self-contained-html
|
|
# else
|
|
# pytest testcases/test_concurrent.py --host ${MILVUS_SERVICE_NAME} --port ${MILVUS_SERVICE_PORT} --count 5 -n 5 \
|
|
# --html=${CI_LOG_PATH}/report_concurrent.html --self-contained-html
|
|
# fi
|