1#!/bin/bash 2# 3# Test postcopy live migration with shared storage 4# 5# Copyright (C) 2017 Red Hat, Inc. 6# 7# This program is free software; you can redistribute it and/or modify 8# it under the terms of the GNU General Public License as published by 9# the Free Software Foundation; either version 2 of the License, or 10# (at your option) any later version. 11# 12# This program is distributed in the hope that it will be useful, 13# but WITHOUT ANY WARRANTY; without even the implied warranty of 14# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15# GNU General Public License for more details. 16# 17# You should have received a copy of the GNU General Public License 18# along with this program. If not, see <http://www.gnu.org/licenses/>. 19# 20 21# creator 22owner=kwolf@redhat.com 23 24seq=`basename $0` 25echo "QA output created by $seq" 26 27here=`pwd` 28status=1 # failure is the default! 29 30MIG_SOCKET="${TEST_DIR}/migrate" 31 32_cleanup() 33{ 34 rm -f "${MIG_SOCKET}" 35 _cleanup_test_img 36 _cleanup_qemu 37} 38trap "_cleanup; exit \$status" 0 1 2 3 15 39 40# get standard environment, filters and checks 41. ./common.rc 42. ./common.filter 43. ./common.qemu 44 45_supported_fmt generic 46# Formats that do not support live migration 47_unsupported_fmt qcow vdi vhdx vmdk vpc vvfat parallels 48_supported_proto generic 49_supported_os Linux 50 51size=64M 52_make_test_img $size 53 54echo 55echo === Starting VMs === 56echo 57 58qemu_comm_method="monitor" 59 60if [ "$IMGOPTSSYNTAX" = "true" ]; then 61 _launch_qemu \ 62 -drive "${TEST_IMG}",cache=${CACHEMODE},id=disk 63else 64 _launch_qemu \ 65 -drive file="${TEST_IMG}",cache=${CACHEMODE},driver=$IMGFMT,id=disk 66fi 67src=$QEMU_HANDLE 68 69if [ "$IMGOPTSSYNTAX" = "true" ]; then 70 _launch_qemu \ 71 -drive "${TEST_IMG}",cache=${CACHEMODE},id=disk \ 72 -incoming "unix:${MIG_SOCKET}" 73else 74 _launch_qemu \ 75 -drive file="${TEST_IMG}",cache=${CACHEMODE},driver=$IMGFMT,id=disk \ 76 -incoming "unix:${MIG_SOCKET}" 77fi 78dest=$QEMU_HANDLE 79 80echo 81echo === Write something on the source === 82echo 83 84silent= 85_send_qemu_cmd $src 'qemu-io disk "write -P 0x55 0 64k"' "(qemu)" 86_send_qemu_cmd $src "" "ops/sec" 87_send_qemu_cmd $src 'qemu-io disk "read -P 0x55 0 64k"' "(qemu)" 88_send_qemu_cmd $src "" "ops/sec" 89 90echo 91echo === Do postcopy migration to destination === 92echo 93 94# Slow down migration so much that it definitely won't finish before we can 95# switch to postcopy 96# Enable postcopy-ram capability both on source and destination 97silent=yes 98_send_qemu_cmd $dest 'migrate_set_capability postcopy-ram on' "(qemu)" 99_send_qemu_cmd $src 'migrate_set_speed 4k' "(qemu)" 100_send_qemu_cmd $src 'migrate_set_capability postcopy-ram on' "(qemu)" 101_send_qemu_cmd $src "migrate -d unix:${MIG_SOCKET}" "(qemu)" 102_send_qemu_cmd $src 'migrate_start_postcopy' "(qemu)" 103 104QEMU_COMM_TIMEOUT=1 qemu_cmd_repeat=10 silent=yes \ 105 _send_qemu_cmd $src "info migrate" "completed\|failed" 106silent=yes _send_qemu_cmd $src "" "(qemu)" 107 108echo 109echo === Do some I/O on the destination === 110echo 111 112# It is important that we use the BlockBackend of the guest device here instead 113# of the node name, which would create a new BlockBackend and not test whether 114# the guest has the necessary permissions to access the image now 115silent= 116_send_qemu_cmd $dest 'qemu-io disk "read -P 0x55 0 64k"' "(qemu)" 117_send_qemu_cmd $dest "" "ops/sec" 118_send_qemu_cmd $dest 'qemu-io disk "write -P 0x66 1M 64k"' "(qemu)" 119_send_qemu_cmd $dest "" "ops/sec" 120 121echo 122echo === Shut down and check image === 123echo 124 125_send_qemu_cmd $src 'quit' "" 126_send_qemu_cmd $dest 'quit' "" 127wait=1 _cleanup_qemu 128 129_check_test_img 130 131# success, all done 132echo "*** done" 133rm -f $seq.full 134status=0 135