#!/usr/bin/env python3 # # Simple mirror test # # Copyright (c) 2018 Virtuozzo International GmbH. All rights reserved. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # import sys import os import iotests from iotests import qemu_img_create, qemu_io, file_path, log sys.path.append(os.path.join(os.path.dirname(__file__), '..', '..', 'python')) from qemu.machine import QEMUMachine # Note: # This test was added to check that mirror dead-lock was fixed (see previous # commit before this test addition). # And it didn't reproduce if at least one of the following: # 1. use small image size # 2. use raw format (not qcow2) # 3. drop kvm and use iotests.VM() (maybe, because of qtest) (however, it still # reproduces, if just drop kvm, but gdb failed to produce full backtraces # for me) # 4. add iothread size = 1 * 1024 * 1024 * 1024 iotests.verify_image_format(supported_fmts=['qcow2']) disk = file_path('disk') # prepare source image qemu_img_create('-f', iotests.imgfmt, '-o', 'preallocation=metadata', disk, str(size)) vm = QEMUMachine(iotests.qemu_prog) vm.add_args('-accel', 'kvm', '-accel', 'tcg') if iotests.qemu_default_machine == 's390-ccw-virtio': vm.add_args('-no-shutdown') vm.add_args('-drive', 'id=src,file=' + disk) vm.launch() log(vm.qmp('object-add', qom_type='throttle-group', id='tg0', props={ 'x-bps-total': size })) log(vm.qmp('blockdev-add', **{ 'node-name': 'target', 'driver': 'throttle', 'throttle-group': 'tg0', 'file': { 'driver': 'null-co', 'size': size } })) log(vm.qmp('blockdev-mirror', device='src', target='target', sync='full')) try: vm.event_wait('BLOCK_JOB_READY', timeout=10.0) except: vm.shutdown() raise vm.shutdown()