17c477526SPhilippe Mathieu-Daudé#!/usr/bin/env python3 29dd003a9SVladimir Sementsov-Ogievskiy# group: rw quick 3a66c4b83SVladimir Sementsov-Ogievskiy# 4a66c4b83SVladimir Sementsov-Ogievskiy# Test resume mirror after auto pause on ENOSPC 5a66c4b83SVladimir Sementsov-Ogievskiy# 6a66c4b83SVladimir Sementsov-Ogievskiy# Copyright (c) 2019 Virtuozzo International GmbH. All rights reserved. 7a66c4b83SVladimir Sementsov-Ogievskiy# 8a66c4b83SVladimir Sementsov-Ogievskiy# This program is free software; you can redistribute it and/or modify 9a66c4b83SVladimir Sementsov-Ogievskiy# it under the terms of the GNU General Public License as published by 10a66c4b83SVladimir Sementsov-Ogievskiy# the Free Software Foundation; either version 2 of the License, or 11a66c4b83SVladimir Sementsov-Ogievskiy# (at your option) any later version. 12a66c4b83SVladimir Sementsov-Ogievskiy# 13a66c4b83SVladimir Sementsov-Ogievskiy# This program is distributed in the hope that it will be useful, 14a66c4b83SVladimir Sementsov-Ogievskiy# but WITHOUT ANY WARRANTY; without even the implied warranty of 15a66c4b83SVladimir Sementsov-Ogievskiy# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16a66c4b83SVladimir Sementsov-Ogievskiy# GNU General Public License for more details. 17a66c4b83SVladimir Sementsov-Ogievskiy# 18a66c4b83SVladimir Sementsov-Ogievskiy# You should have received a copy of the GNU General Public License 19a66c4b83SVladimir Sementsov-Ogievskiy# along with this program. If not, see <http://www.gnu.org/licenses/>. 20a66c4b83SVladimir Sementsov-Ogievskiy# 21a66c4b83SVladimir Sementsov-Ogievskiy 22a66c4b83SVladimir Sementsov-Ogievskiyimport iotests 23a66c4b83SVladimir Sementsov-Ogievskiyfrom iotests import qemu_img_create, qemu_io, file_path, filter_qmp_testfiles 24a66c4b83SVladimir Sementsov-Ogievskiy 257d814059SJohn Snowiotests.script_initialize(supported_fmts=['qcow2']) 26a66c4b83SVladimir Sementsov-Ogievskiy 27a66c4b83SVladimir Sementsov-Ogievskiysource, target = file_path('source', 'target') 28a66c4b83SVladimir Sementsov-Ogievskiysize = 5 * 1024 * 1024 29a66c4b83SVladimir Sementsov-Ogievskiylimit = 2 * 1024 * 1024 30a66c4b83SVladimir Sementsov-Ogievskiy 31a66c4b83SVladimir Sementsov-Ogievskiyqemu_img_create('-f', iotests.imgfmt, source, str(size)) 32a66c4b83SVladimir Sementsov-Ogievskiyqemu_img_create('-f', iotests.imgfmt, target, str(size)) 33a66c4b83SVladimir Sementsov-Ogievskiyqemu_io('-c', 'write 0 {}'.format(size), source) 34a66c4b83SVladimir Sementsov-Ogievskiy 35a66c4b83SVladimir Sementsov-Ogievskiy# raw format don't like empty files 36a66c4b83SVladimir Sementsov-Ogievskiyqemu_io('-c', 'write 0 {}'.format(size), target) 37a66c4b83SVladimir Sementsov-Ogievskiy 38a66c4b83SVladimir Sementsov-Ogievskiyvm = iotests.VM().add_drive(source) 39a66c4b83SVladimir Sementsov-Ogievskiyvm.launch() 40a66c4b83SVladimir Sementsov-Ogievskiy 41a66c4b83SVladimir Sementsov-Ogievskiyblockdev_opts = { 42a66c4b83SVladimir Sementsov-Ogievskiy 'driver': iotests.imgfmt, 43a66c4b83SVladimir Sementsov-Ogievskiy 'node-name': 'target', 44a66c4b83SVladimir Sementsov-Ogievskiy 'file': { 45a66c4b83SVladimir Sementsov-Ogievskiy 'driver': 'raw', 46a66c4b83SVladimir Sementsov-Ogievskiy 'size': limit, 47a66c4b83SVladimir Sementsov-Ogievskiy 'file': { 48a66c4b83SVladimir Sementsov-Ogievskiy 'driver': 'file', 49a66c4b83SVladimir Sementsov-Ogievskiy 'filename': target 50a66c4b83SVladimir Sementsov-Ogievskiy } 51a66c4b83SVladimir Sementsov-Ogievskiy } 52a66c4b83SVladimir Sementsov-Ogievskiy} 53a66c4b83SVladimir Sementsov-Ogievskiyvm.qmp_log('blockdev-add', filters=[filter_qmp_testfiles], **blockdev_opts) 54a66c4b83SVladimir Sementsov-Ogievskiy 55a66c4b83SVladimir Sementsov-Ogievskiyvm.qmp_log('blockdev-mirror', device='drive0', sync='full', target='target', 56a66c4b83SVladimir Sementsov-Ogievskiy on_target_error='enospc') 57a66c4b83SVladimir Sementsov-Ogievskiy 58a66c4b83SVladimir Sementsov-Ogievskiyvm.event_wait('JOB_STATUS_CHANGE', timeout=3.0, 59a66c4b83SVladimir Sementsov-Ogievskiy match={'data': {'status': 'paused'}}) 60a66c4b83SVladimir Sementsov-Ogievskiy 61a66c4b83SVladimir Sementsov-Ogievskiy# drop other cached events, to not interfere with further wait for 'running' 62a66c4b83SVladimir Sementsov-Ogievskiyvm.get_qmp_events() 63a66c4b83SVladimir Sementsov-Ogievskiy 64a66c4b83SVladimir Sementsov-Ogievskiydel blockdev_opts['file']['size'] 65*e60edf69SAlberto Garciavm.qmp_log('blockdev-reopen', filters=[filter_qmp_testfiles], 663908b7a8SAlberto Garcia options = [ blockdev_opts ]) 67a66c4b83SVladimir Sementsov-Ogievskiy 68a66c4b83SVladimir Sementsov-Ogievskiyvm.qmp_log('block-job-resume', device='drive0') 69a66c4b83SVladimir Sementsov-Ogievskiyvm.event_wait('JOB_STATUS_CHANGE', timeout=1.0, 70a66c4b83SVladimir Sementsov-Ogievskiy match={'data': {'status': 'running'}}) 71a66c4b83SVladimir Sementsov-Ogievskiy 72a66c4b83SVladimir Sementsov-Ogievskiyvm.shutdown() 73