mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2025-01-03 03:15:20 +00:00
scripts: Add entry for live-migration integration tests
Signed-off-by: Bo Chen <chen.bo@intel.com>
This commit is contained in:
parent
92a506fb06
commit
a1a0bc8592
@ -178,16 +178,17 @@ cmd_help() {
|
|||||||
echo ""
|
echo ""
|
||||||
echo " tests [--unit|--cargo|--all] [--libc musl|gnu] [-- [<cargo test args>]]"
|
echo " tests [--unit|--cargo|--all] [--libc musl|gnu] [-- [<cargo test args>]]"
|
||||||
echo " Run the Cloud Hypervisor tests."
|
echo " Run the Cloud Hypervisor tests."
|
||||||
echo " --unit Run the unit tests."
|
echo " --unit Run the unit tests."
|
||||||
echo " --cargo Run the cargo tests."
|
echo " --cargo Run the cargo tests."
|
||||||
echo " --integration Run the integration tests."
|
echo " --integration Run the integration tests."
|
||||||
echo " --integration-sgx Run the SGX integration tests."
|
echo " --integration-sgx Run the SGX integration tests."
|
||||||
echo " --integration-vfio Run the VFIO integration tests."
|
echo " --integration-vfio Run the VFIO integration tests."
|
||||||
echo " --integration-windows Run the Windows guest integration tests."
|
echo " --integration-windows Run the Windows guest integration tests."
|
||||||
echo " --libc Select the C library Cloud Hypervisor will be built against. Default is gnu"
|
echo " --integration-live-migration Run the live-migration integration tests."
|
||||||
echo " --volumes Hash separated volumes to be exported. Example --volumes /mnt:/mnt#/myvol:/myvol"
|
echo " --libc Select the C library Cloud Hypervisor will be built against. Default is gnu"
|
||||||
echo " --hypervisor Underlying hypervisor. Options kvm, mshv"
|
echo " --volumes Hash separated volumes to be exported. Example --volumes /mnt:/mnt#/myvol:/myvol"
|
||||||
echo " --all Run all tests."
|
echo " --hypervisor Underlying hypervisor. Options kvm, mshv"
|
||||||
|
echo " --all Run all tests."
|
||||||
echo ""
|
echo ""
|
||||||
echo " build-container [--type]"
|
echo " build-container [--type]"
|
||||||
echo " Build the Cloud Hypervisor container."
|
echo " Build the Cloud Hypervisor container."
|
||||||
@ -298,19 +299,21 @@ cmd_tests() {
|
|||||||
integration_sgx=false
|
integration_sgx=false
|
||||||
integration_vfio=false
|
integration_vfio=false
|
||||||
integration_windows=false
|
integration_windows=false
|
||||||
|
integration_live_migration=false
|
||||||
libc="gnu"
|
libc="gnu"
|
||||||
arg_vols=""
|
arg_vols=""
|
||||||
hypervisor="kvm"
|
hypervisor="kvm"
|
||||||
exported_device="/dev/kvm"
|
exported_device="/dev/kvm"
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
"-h"|"--help") { cmd_help; exit 1; } ;;
|
"-h"|"--help") { cmd_help; exit 1; } ;;
|
||||||
"--unit") { unit=true; } ;;
|
"--unit") { unit=true; } ;;
|
||||||
"--cargo") { cargo=true; } ;;
|
"--cargo") { cargo=true; } ;;
|
||||||
"--integration") { integration=true; } ;;
|
"--integration") { integration=true; } ;;
|
||||||
"--integration-sgx") { integration_sgx=true; } ;;
|
"--integration-sgx") { integration_sgx=true; } ;;
|
||||||
"--integration-vfio") { integration_vfio=true; } ;;
|
"--integration-vfio") { integration_vfio=true; } ;;
|
||||||
"--integration-windows") { integration_windows=true; } ;;
|
"--integration-windows") { integration_windows=true; } ;;
|
||||||
|
"--integration-live-migration") { integration_live_migration=true; } ;;
|
||||||
"--libc")
|
"--libc")
|
||||||
shift
|
shift
|
||||||
[[ "$1" =~ ^(musl|gnu)$ ]] || \
|
[[ "$1" =~ ^(musl|gnu)$ ]] || \
|
||||||
@ -454,6 +457,25 @@ cmd_tests() {
|
|||||||
"$CTR_IMAGE" \
|
"$CTR_IMAGE" \
|
||||||
./scripts/run_integration_tests_windows.sh "$@" || fix_dir_perms $? || exit $?
|
./scripts/run_integration_tests_windows.sh "$@" || fix_dir_perms $? || exit $?
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ "$integration_live_migration" = true ] ; then
|
||||||
|
say "Running 'live migration' integration tests for $target..."
|
||||||
|
$DOCKER_RUNTIME run \
|
||||||
|
--workdir "$CTR_CLH_ROOT_DIR" \
|
||||||
|
--rm \
|
||||||
|
--privileged \
|
||||||
|
--security-opt seccomp=unconfined \
|
||||||
|
--ipc=host \
|
||||||
|
--net="$CTR_CLH_NET" \
|
||||||
|
--mount type=tmpfs,destination=/tmp \
|
||||||
|
--volume /dev:/dev \
|
||||||
|
--volume "$CLH_ROOT_DIR:$CTR_CLH_ROOT_DIR" $exported_volumes \
|
||||||
|
--volume "$CLH_INTEGRATION_WORKLOADS:$CTR_CLH_INTEGRATION_WORKLOADS" \
|
||||||
|
--env USER="root" \
|
||||||
|
--env CH_LIBC="${libc}" \
|
||||||
|
"$CTR_IMAGE" \
|
||||||
|
./scripts/run_integration_tests_live_migration.sh "$@" || fix_dir_perms $? || exit $?
|
||||||
|
fi
|
||||||
fix_dir_perms $?
|
fix_dir_perms $?
|
||||||
}
|
}
|
||||||
|
|
||||||
|
87
scripts/run_integration_tests_live_migration.sh
Executable file
87
scripts/run_integration_tests_live_migration.sh
Executable file
@ -0,0 +1,87 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -x
|
||||||
|
|
||||||
|
source $HOME/.cargo/env
|
||||||
|
source $(dirname "$0")/test-util.sh
|
||||||
|
|
||||||
|
export BUILD_TARGET=${BUILD_TARGET-x86_64-unknown-linux-gnu}
|
||||||
|
|
||||||
|
WORKLOADS_DIR="$HOME/workloads"
|
||||||
|
mkdir -p "$WORKLOADS_DIR"
|
||||||
|
|
||||||
|
process_common_args "$@"
|
||||||
|
|
||||||
|
# For now these values are deafult for kvm
|
||||||
|
features_build=""
|
||||||
|
features_test="--features integration_tests"
|
||||||
|
|
||||||
|
cp scripts/sha1sums-x86_64 $WORKLOADS_DIR
|
||||||
|
|
||||||
|
FOCAL_OS_IMAGE_NAME="focal-server-cloudimg-amd64-custom-20210609-0.qcow2"
|
||||||
|
FOCAL_OS_IMAGE_URL="https://cloud-hypervisor.azureedge.net/$FOCAL_OS_IMAGE_NAME"
|
||||||
|
FOCAL_OS_IMAGE="$WORKLOADS_DIR/$FOCAL_OS_IMAGE_NAME"
|
||||||
|
if [ ! -f "$FOCAL_OS_IMAGE" ]; then
|
||||||
|
pushd $WORKLOADS_DIR
|
||||||
|
time wget --quiet $FOCAL_OS_IMAGE_URL || exit 1
|
||||||
|
popd
|
||||||
|
fi
|
||||||
|
|
||||||
|
FOCAL_OS_RAW_IMAGE_NAME="focal-server-cloudimg-amd64-custom-20210609-0.raw"
|
||||||
|
FOCAL_OS_RAW_IMAGE="$WORKLOADS_DIR/$FOCAL_OS_RAW_IMAGE_NAME"
|
||||||
|
if [ ! -f "$FOCAL_OS_RAW_IMAGE" ]; then
|
||||||
|
pushd $WORKLOADS_DIR
|
||||||
|
time qemu-img convert -p -f qcow2 -O raw $FOCAL_OS_IMAGE_NAME $FOCAL_OS_RAW_IMAGE_NAME || exit 1
|
||||||
|
popd
|
||||||
|
fi
|
||||||
|
|
||||||
|
pushd $WORKLOADS_DIR
|
||||||
|
grep focal sha1sums-x86_64 | sha1sum --check
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "sha1sum validation of images failed, remove invalid images to fix the issue."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
popd
|
||||||
|
|
||||||
|
# Build custom kernel based on virtio-pmem and virtio-fs upstream patches
|
||||||
|
VMLINUX_IMAGE="$WORKLOADS_DIR/vmlinux"
|
||||||
|
|
||||||
|
LINUX_CUSTOM_DIR="$WORKLOADS_DIR/linux-custom"
|
||||||
|
|
||||||
|
if [ ! -f "$VMLINUX_IMAGE" ]; then
|
||||||
|
SRCDIR=$PWD
|
||||||
|
pushd $WORKLOADS_DIR
|
||||||
|
time git clone --depth 1 "https://github.com/cloud-hypervisor/linux.git" -b "ch-5.14" $LINUX_CUSTOM_DIR
|
||||||
|
cp $SRCDIR/resources/linux-config-x86_64 $LINUX_CUSTOM_DIR/.config
|
||||||
|
popd
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -f "$VMLINUX_IMAGE" ]; then
|
||||||
|
pushd $LINUX_CUSTOM_DIR
|
||||||
|
time make bzImage -j `nproc`
|
||||||
|
cp vmlinux $VMLINUX_IMAGE || exit 1
|
||||||
|
popd
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d "$LINUX_CUSTOM_DIR" ]; then
|
||||||
|
rm -rf $LINUX_CUSTOM_DIR
|
||||||
|
fi
|
||||||
|
|
||||||
|
BUILD_TARGET="$(uname -m)-unknown-linux-${CH_LIBC}"
|
||||||
|
CFLAGS=""
|
||||||
|
TARGET_CC=""
|
||||||
|
if [[ "${BUILD_TARGET}" == "x86_64-unknown-linux-musl" ]]; then
|
||||||
|
TARGET_CC="musl-gcc"
|
||||||
|
CFLAGS="-I /usr/include/x86_64-linux-musl/ -idirafter /usr/include/"
|
||||||
|
fi
|
||||||
|
|
||||||
|
cargo build --all --release $features_build --target $BUILD_TARGET
|
||||||
|
strip target/$BUILD_TARGET/release/cloud-hypervisor
|
||||||
|
strip target/$BUILD_TARGET/release/vhost_user_net
|
||||||
|
strip target/$BUILD_TARGET/release/ch-remote
|
||||||
|
|
||||||
|
export RUST_BACKTRACE=1
|
||||||
|
|
||||||
|
time cargo test $features_test "tests::live_migration::$test_filter" -- --test-threads=1
|
||||||
|
RES=$?
|
||||||
|
|
||||||
|
exit $RES
|
Loading…
Reference in New Issue
Block a user