milvus/tests/scripts/e2e-k8s.sh

386 lines
12 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
# shellcheck source=build/lib.sh
source "${ROOT}/build/lib.sh"
setup_and_export_git_sha
# shellcheck source=build/kind_provisioner.sh
source "${ROOT}/build/kind_provisioner.sh"
# shellcheck source=ci-util.sh
source "${ROOT}/tests/scripts/ci-util.sh"
TOPOLOGY=SINGLE_CLUSTER
NODE_IMAGE="kindest/node:v1.20.2"
KIND_CONFIG=""
INSTALL_EXTRA_ARG=""
TEST_EXTRA_ARG=""
CLUSTER_TOPOLOGY_CONFIG_FILE="${ROOT}/build/config/topology/multicluster.json"
while (( "$#" )); do
case "$1" in
# Node images can be found at https://github.com/kubernetes-sigs/kind/releases
# For example, kindest/node:v1.14.0
--node-image)
NODE_IMAGE=$2
shift 2
;;
# Config for enabling different Kubernetes features in KinD (see build/config/topology/trustworthy-jwt.yaml).
--kind-config)
KIND_CONFIG=$2
shift 2
;;
--build-command)
BUILD_COMMAND=$2
shift 2
;;
--install-extra-arg)
INSTALL_EXTRA_ARG=$2
shift 2
;;
--test-extra-arg)
TEST_EXTRA_ARG=$2
shift 2
;;
--test-timeout)
TEST_TIMEOUT=$2
shift 2
;;
--skip-setup)
SKIP_SETUP=true
shift
;;
--skip-install)
SKIP_INSTALL=true
shift
;;
--skip-cleanup)
SKIP_CLEANUP=true
shift
;;
--skip-build)
SKIP_BUILD=true
shift
;;
--skip-build-image)
SKIP_BUILD_IMAGE=true
shift
;;
--skip-test)
SKIP_TEST=true
shift
;;
--skip-export-logs)
SKIP_EXPORT_LOGS=true
shift
;;
--disable-kind)
DISABLE_KIND=true
shift
;;
--manual)
MANUAL=true
shift
;;
--gpu)
GPU_BUILD=true
shift
;;
--topology)
case $2 in
SINGLE_CLUSTER | MULTICLUSTER_SINGLE_NETWORK | MULTICLUSTER )
TOPOLOGY=$2
echo "Running with topology ${TOPOLOGY}"
;;
*)
echo "Error: Unsupported topology ${TOPOLOGY}" >&2
exit 1
;;
esac
shift 2
;;
--topology-config)
CLUSTER_TOPOLOGY_CONFIG_FILE="${ROOT}/${2}"
shift 2
;;
-h|--help)
{ set +x; } 2>/dev/null
HELP="
Usage:
$0 [flags] [Arguments]
--node-image Kubernetes in Docker (KinD) Node image
The image is a Docker image for running nested containers, systemd, and Kubernetes components.
Node images can be found at https://github.com/kubernetes-sigs/kind/releases.
Default: \"kindest/node:v1.20.2\"
--kind-config Config for enabling different Kubernetes features in KinD
--build-command Specified build milvus command
--install-extra-arg Install Milvus Helm Chart extra configuration. (see https://github.com/zilliztech/milvus-helm-charts/blob/main/charts/milvus-ha/values.yaml)
To override values in a chart, use either the '--values' flag and pass in a file or use the '--set' flag and pass configuration from the command line, to force a string value use '--set-string'.
Refer: https://helm.sh/docs/helm/helm_install/#helm-install
--test-extra-arg Run e2e test extra configuration
For example, \"--tags=L0\"
--test-timeout To specify timeout period of e2e test. Timeout time is specified in seconds.
--topology KinD cluster topology of deployments
Provides three classes: \"SINGLE_CLUSTER\", \"MULTICLUSTER_SINGLE_NETWORK\", \"MULTICLUSTER\"
Default: \"SINGLE_CLUSTER\"
--topology-config KinD cluster topology configuration file
--skip-setup Skip setup KinD cluster
--skip-install Skip install Milvus Helm Chart
--skip-cleanup Skip cleanup KinD cluster
--skip-build Skip build Milvus binary
--skip-build-image Skip build Milvus image
--skip-test Skip e2e test
--skip-export-logs Skip kind export logs
--manual Manual Mode
--disable-kind Remove KinD cluster
-h or --help Print help information
Use \"$0 --help\" for more information about a given command.
"
echo -e "${HELP}" ; exit 0
;;
-*)
echo "Error: Unsupported flag $1" >&2
exit 1
;;
*) # preserve positional arguments
PARAMS+=("$1")
shift
;;
esac
done
if [[ -n "${GPU_BUILD:-}" ]]; then
export BUILD_COMMAND="${BUILD_COMMAND:-make gpu-install}"
export BUILD_SCRIPT="builder_gpu.sh"
export BUILD_IMAGE_SCRIPT="build_image_gpu.sh"
export TAG="${TAG:-gpu-latest}"
export MODE="gpu"
else
export BUILD_COMMAND="${BUILD_COMMAND:-make install use_disk_index=ON}"
export BUILD_SCRIPT="builder.sh"
export BUILD_IMAGE_SCRIPT="build_image.sh"
export TAG="${TAG:-latest}"
export MODE="cpu"
fi
export MANUAL="${MANUAL:-}"
# Default IP family of the cluster is IPv4
export IP_FAMILY="${IP_FAMILY:-ipv4}"
# KinD will not have a LoadBalancer, so we need to disable it
export TEST_ENV=kind
# LoadBalancer in Kind is supported using metallb if not ipv6.
if [ "${IP_FAMILY}" != "ipv6" ]; then
export TEST_ENV=kind-metallb
fi
# See https://kind.sigs.k8s.io/docs/user/quick-start/#loading-an-image-into-your-cluster
export PULL_POLICY=IfNotPresent
# We run a local-registry in a docker container that KinD nodes pull from
# These values must match what are in config/trustworthy-jwt.yaml
export KIND_REGISTRY_NAME="kind-registry"
export KIND_REGISTRY_PORT="5000"
export KIND_REGISTRY="localhost:${KIND_REGISTRY_PORT}"
export ARTIFACTS="${ARTIFACTS:-$(mktemp -d)}"
export SINGLE_CLUSTER_NAME="${SINGLE_CLUSTER_NAME:-kind}"
export HUB="${HUB:-milvusdb}"
export CI="true"
export IS_NETWORK_MODE_HOST=true
if [[ ! -d "${ARTIFACTS}" ]];then
mkdir -p "${ARTIFACTS}"
fi
if [[ ! -x "$(command -v kubectl)" ]]; then
KUBECTL_DIR="${KUBECTL_DIR:-"${HOME}/tool_cache/kubectl"}"
KUBECTL_VERSION="v1.20.2"
export PATH="${KUBECTL_DIR}:${PATH}"
if [[ ! -x "$(command -v kubectl)" ]]; then
install_kubectl "${KUBECTL_DIR}" "${KUBECTL_VERSION}"
fi
fi
if [[ -z "${DISABLE_KIND:-}" ]];then
if [[ ! -x "$(command -v kind)" ]]; then
KIND_DIR="${KIND_DIR:-"${HOME}/tool_cache/kind"}"
KIND_VERSION="v0.11.1"
export PATH="${KIND_DIR}:${PATH}"
if [[ ! -x "$(command -v kind)" ]]; then
install_kind "${KIND_DIR}" "${KIND_VERSION}"
fi
fi
fi
if [[ -z "${SKIP_SETUP:-}" ]]; then
export DEFAULT_CLUSTER_YAML="${ROOT}/build/config/topology/trustworthy-jwt.yaml"
export METRICS_SERVER_CONFIG_DIR="${ROOT}/build/config/metrics"
if ! docker info > /dev/null 2>&1; then
echo "KinD need docker to set up cluster - please start docker and try again!"
exit 1
fi
if [[ "${TOPOLOGY}" == "SINGLE_CLUSTER" ]]; then
trace "setup kind cluster" setup_kind_cluster "${SINGLE_CLUSTER_NAME}" "${NODE_IMAGE}" "${KIND_CONFIG}"
else
trace "load cluster topology" load_cluster_topology "${CLUSTER_TOPOLOGY_CONFIG_FILE}"
trace "setup kind clusters" setup_kind_clusters "${NODE_IMAGE}" "${IP_FAMILY}"
TOPOLOGY_JSON=$(cat "${CLUSTER_TOPOLOGY_CONFIG_FILE}")
for i in $(seq 0 $((${#CLUSTER_NAMES[@]} - 1))); do
CLUSTER="${CLUSTER_NAMES[i]}"
KCONFIG="${KUBECONFIGS[i]}"
TOPOLOGY_JSON=$(set_topology_value "${TOPOLOGY_JSON}" "${CLUSTER}" "meta.kubeconfig" "${KCONFIG}")
done
RUNTIME_TOPOLOGY_CONFIG_FILE="${ARTIFACTS}/topology-config.json"
echo "${TOPOLOGY_JSON}" > "${RUNTIME_TOPOLOGY_CONFIG_FILE}"
export INTEGRATION_TEST_TOPOLOGY_FILE
INTEGRATION_TEST_TOPOLOGY_FILE="${RUNTIME_TOPOLOGY_CONFIG_FILE}"
export INTEGRATION_TEST_KUBECONFIG
INTEGRATION_TEST_KUBECONFIG=NONE
fi
fi
if [[ -z "${SKIP_BUILD:-}" ]]; then
#If disable_kind exist, do not need kind registry
if [[ -n "${DISABLE_KIND:-}" ]]; then
echo "do not set up kind registry when disable_kind exist"
else
trace "setup kind registry" setup_kind_registry
fi
pushd "${ROOT}"
trace "build milvus" "${ROOT}/build/${BUILD_SCRIPT}" /bin/bash -c "${BUILD_COMMAND}"
popd
fi
if [[ -n "${DISABLE_KIND:-}" ]]; then
export MILVUS_IMAGE_TAG="${TAG}"
export MILVUS_IMAGE_REPO="${HUB}/milvus"
fi
if [[ -z "${SKIP_BUILD_IMAGE:-}" ]]; then
# If disable_kind exist,login ci docker registry instead
if [[ -n "${DISABLE_KIND:-}" ]]; then
trace "docker login in ci registry" docker_login_ci_registry
else
# If we're not intending to pull from an actual remote registry, use the local kind registry
running="$(docker inspect -f '{{.State.Running}}' "${KIND_REGISTRY_NAME}" 2>/dev/null || true)"
if [[ "${running}" == 'true' ]]; then
HUB="${KIND_REGISTRY}"
export HUB
fi
export MILVUS_IMAGE_REPO="${HUB}/milvus"
export MILVUS_IMAGE_TAG="${TAG}"
fi
pushd "${ROOT}"
# Build Milvus Docker Image
trace "build milvus image" "${ROOT}/build/${BUILD_IMAGE_SCRIPT}"
trace "push milvus image" docker push "${MILVUS_IMAGE_REPO}:${MILVUS_IMAGE_TAG}"
popd
fi
if [[ -z "${SKIP_INSTALL:-}" ]]; then
if [[ ! -x "$(command -v helm)" ]]; then
HELM_DIR="${HELM_DIR:-"${HOME}/tool_cache/helm"}"
HELM_VERSION="v3.5.4"
export PATH="${HELM_DIR}:${PATH}"
if [[ ! -x "$(command -v helm)" ]]; then
install_helm "${HELM_DIR}" "${HELM_VERSION}"
fi
fi
export MILVUS_HELM_RELEASE_NAME=$(./get_release_name.sh)
echo "[debug] helm install ${MILVUS_HELM_RELEASE_NAME}"
trace "install milvus helm chart" "${ROOT}/tests/scripts/install_milvus.sh" "${INSTALL_EXTRA_ARG}"
fi
if [[ -z "${SKIP_TEST:-}" ]]; then
if [[ -n "${TEST_TIMEOUT:-}" ]]; then
if [[ -n "${DISABLE_KIND:-}" ]]; then
trace "e2e test" "timeout" "${TEST_TIMEOUT}" "${ROOT}/tests/scripts/e2e.sh" "${TEST_EXTRA_ARG}"
else
trace "e2e test" "timeout" "-v" "${TEST_TIMEOUT}" "${ROOT}/tests/scripts/e2e.sh" "${TEST_EXTRA_ARG}"
fi
else
trace "e2e test" "${ROOT}/tests/scripts/e2e.sh" "${TEST_EXTRA_ARG}"
fi
fi
# Check if the user is running the clusters in manual mode.
if [[ -n "${MANUAL:-}" ]]; then
echo "Running cluster(s) in manual mode. Press any key to shutdown and exit..."
read -rsn1
exit 0
fi