| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | #!/usr/bin/env bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | set -e | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | vms=() | 
					
						
							|  |  |  | declare -A vms_os | 
					
						
							|  |  |  | declare -A vms_raw_disks | 
					
						
							|  |  |  | declare -A vms_ctrlrs | 
					
						
							|  |  |  | declare -A vms_ctrlrs_disks | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # By default use Guest fio | 
					
						
							|  |  |  | fio_bin="" | 
					
						
							| 
									
										
										
										
											2018-01-31 15:10:26 +00:00
										 |  |  | test_cases="" | 
					
						
							| 
									
										
										
										
											2018-05-08 19:16:05 +00:00
										 |  |  | MGMT_TARGET_IP="" | 
					
						
							|  |  |  | MGMT_INITIATOR_IP="" | 
					
						
							|  |  |  | RDMA_TARGET_IP="" | 
					
						
							|  |  |  | RDMA_INITIATOR_IP="" | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | function usage() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	[[ ! -z $2 ]] && ( echo "$2"; echo ""; ) | 
					
						
							|  |  |  | 	echo "Shortcut script for doing automated test of live migration." | 
					
						
							|  |  |  | 	echo "Usage: $(basename $1) [OPTIONS]" | 
					
						
							|  |  |  | 	echo | 
					
						
							|  |  |  | 	echo "    --work-dir=WORK_DIR   Where to find build file. Must exist. [default: $TEST_DIR]" | 
					
						
							|  |  |  | 	echo "    --os ARGS             VM configuration. This parameter might be used more than once:" | 
					
						
							|  |  |  | 	echo "    --fio-bin=FIO         Use specific fio binary (will be uploaded to VM)" | 
					
						
							| 
									
										
										
										
											2018-01-31 15:10:26 +00:00
										 |  |  | 	echo "    --test-cases=TESTS    Coma-separated list of tests to run. Implemented test cases are: 1" | 
					
						
							|  |  |  | 	echo "                          See test/vhost/test_plan.md for more info." | 
					
						
							| 
									
										
										
										
											2018-05-08 19:16:05 +00:00
										 |  |  | 	echo "    --mgmt-tgt-ip=IP      IP address of target." | 
					
						
							|  |  |  | 	echo "    --mgmt-init-ip=IP     IP address of initiator." | 
					
						
							|  |  |  | 	echo "    --rdma-tgt-ip=IP      IP address of targets rdma capable NIC." | 
					
						
							|  |  |  | 	echo "    --rdma-init-ip=IP     IP address of initiators rdma capable NIC." | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | 	echo "-x                        set -x for script debug" | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | for param in "$@"; do | 
					
						
							|  |  |  | 	case "$param" in | 
					
						
							|  |  |  | 		--help|-h) | 
					
						
							|  |  |  | 			usage $0 | 
					
						
							|  |  |  | 			exit 0 | 
					
						
							|  |  |  | 			;; | 
					
						
							|  |  |  | 		--work-dir=*) TEST_DIR="${param#*=}" ;; | 
					
						
							|  |  |  | 		--os=*) os_image="${param#*=}" ;; | 
					
						
							|  |  |  | 		--fio-bin=*) fio_bin="${param}" ;; | 
					
						
							| 
									
										
										
										
											2018-01-31 15:10:26 +00:00
										 |  |  | 		--test-cases=*) test_cases="${param#*=}" ;; | 
					
						
							| 
									
										
										
										
											2018-05-08 19:16:05 +00:00
										 |  |  | 		--mgmt-tgt-ip=*) MGMT_TARGET_IP="${param#*=}" ;; | 
					
						
							|  |  |  | 		--mgmt-init-ip=*) MGMT_INITIATOR_IP="${param#*=}" ;; | 
					
						
							|  |  |  | 		--rdma-tgt-ip=*) RDMA_TARGET_IP="${param#*=}" ;; | 
					
						
							|  |  |  | 		--rdma-init-ip=*) RDMA_INITIATOR_IP="${param#*=}" ;; | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | 		-x) set -x ;; | 
					
						
							|  |  |  | 		-v) SPDK_VHOST_VERBOSE=true	;; | 
					
						
							|  |  |  | 		*) | 
					
						
							|  |  |  | 			usage $0 "Invalid argument '$param'" | 
					
						
							|  |  |  | 			exit 1;; | 
					
						
							|  |  |  | 	esac | 
					
						
							|  |  |  | done | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | . $(readlink -e "$(dirname $0)/../common/common.sh") || exit 1 | 
					
						
							| 
									
										
										
										
											2018-05-21 01:35:58 +00:00
										 |  |  | MIGRATION_DIR=$(readlink -f $(dirname $0)) | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-31 15:10:26 +00:00
										 |  |  | [[ ! -z "$test_cases" ]] || fail "Need '--test-cases=' parameter" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | trap 'error_exit "${FUNCNAME}" "${LINENO}"' INT ERR EXIT | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function vm_monitor_send() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	local vm_num=$1 | 
					
						
							|  |  |  | 	local cmd_result_file="$2" | 
					
						
							|  |  |  | 	local vm_dir="$VM_BASE_DIR/$1" | 
					
						
							|  |  |  | 	local vm_monitor_port=$(cat $vm_dir/monitor_port) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	[[ ! -z "$vm_monitor_port" ]] || fail "No monitor port!" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	shift 2 | 
					
						
							|  |  |  | 	nc 127.0.0.1 $vm_monitor_port "$@" > $cmd_result_file | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Migrate VM $1 | 
					
						
							|  |  |  | function vm_migrate() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	local from_vm_dir="$VM_BASE_DIR/$1" | 
					
						
							|  |  |  | 	local target_vm_dir="$(readlink -e $from_vm_dir/vm_migrate_to)" | 
					
						
							|  |  |  | 	local target_vm="$(basename $target_vm_dir)" | 
					
						
							|  |  |  | 	local target_vm_migration_port="$(cat $target_vm_dir/migration_port)" | 
					
						
							| 
									
										
										
										
											2018-02-21 14:09:16 +00:00
										 |  |  | 	if [[ -n "$2" ]]; then | 
					
						
							|  |  |  | 		local target_ip=$2 | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		local target_ip="127.0.0.1" | 
					
						
							|  |  |  | 	fi | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	# Sanity check if target VM (QEMU) is configured to accept source VM (QEMU) migration | 
					
						
							|  |  |  | 	if [[ "$(readlink -e ${target_vm_dir}/vm_incoming)" != "$(readlink -e ${from_vm_dir})" ]]; then | 
					
						
							|  |  |  | 		fail "source VM $1 or destination VM is not properly configured for live migration" | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-01 21:14:58 +00:00
										 |  |  | 	timing_enter vm_migrate | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | 	notice "Migrating VM $1 to VM "$(basename $target_vm_dir) | 
					
						
							|  |  |  | 	echo -e \
 | 
					
						
							|  |  |  | 		"migrate_set_speed 1g\n" \
 | 
					
						
							| 
									
										
										
										
											2018-02-21 14:09:16 +00:00
										 |  |  | 		"migrate tcp:$target_ip:$target_vm_migration_port\n" \
 | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | 		"info migrate\n" \
 | 
					
						
							|  |  |  | 		"quit" | vm_monitor_send $1 "$from_vm_dir/migration_result" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	# Post migration checks: | 
					
						
							|  |  |  | 	if ! grep "Migration status: completed"  $from_vm_dir/migration_result -q; then | 
					
						
							|  |  |  | 		cat $from_vm_dir/migration_result | 
					
						
							|  |  |  | 		fail "Migration failed:\n" | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-21 14:09:16 +00:00
										 |  |  | 	# Don't perform the following check if target VM is on remote server | 
					
						
							|  |  |  | 	# as we won't have access to it. | 
					
						
							|  |  |  | 	# If you need this check then perform it on your own. | 
					
						
							|  |  |  | 	if [[ "$target_ip" == "127.0.0.1" ]]; then | 
					
						
							|  |  |  | 		if ! vm_os_booted $target_vm; then | 
					
						
							|  |  |  | 			fail "VM$target_vm is not running" | 
					
						
							|  |  |  | 			cat $target_vm $target_vm_dir/cont_result | 
					
						
							|  |  |  | 		fi | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | 	fi | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	notice "Migration complete" | 
					
						
							| 
									
										
										
										
											2018-02-01 21:14:58 +00:00
										 |  |  | 	timing_exit vm_migrate | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function is_fio_running() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	local shell_restore_x="$( [[ "$-" =~ x ]] && echo 'set -x' )" | 
					
						
							|  |  |  | 	set +x | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if vm_ssh $1 'kill -0 $(cat /root/fio.pid)'; then | 
					
						
							|  |  |  | 		local ret=0 | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		local ret=1 | 
					
						
							|  |  |  | 	fi | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	$shell_restore_x | 
					
						
							|  |  |  | 	return $ret | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-31 15:10:26 +00:00
										 |  |  | for test_case in ${test_cases//,/ }; do | 
					
						
							|  |  |  | 	assert_number "$test_case" | 
					
						
							|  |  |  | 	notice "===============================" | 
					
						
							|  |  |  | 	notice "Running Migration test case ${test_case}" | 
					
						
							|  |  |  | 	notice "===============================" | 
					
						
							| 
									
										
										
										
											2018-02-01 21:14:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	timing_enter migration-tc${test_case} | 
					
						
							| 
									
										
										
										
											2018-05-21 01:35:58 +00:00
										 |  |  | 	source $MIGRATION_DIR/migration-tc${test_case}.sh | 
					
						
							| 
									
										
										
										
											2018-02-01 21:14:58 +00:00
										 |  |  | 	timing_exit migration-tc${test_case} | 
					
						
							| 
									
										
										
										
											2018-01-31 15:10:26 +00:00
										 |  |  | done | 
					
						
							| 
									
										
										
										
											2018-01-03 13:24:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | notice "Migration Test SUCCESS" | 
					
						
							|  |  |  | notice "===============" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | trap - SIGINT ERR EXIT |