From bb756eebdac6fd24e8919e2c43f7d2c8c4091f59 Mon Sep 17 00:00:00 2001 From: RajithaY Date: Tue, 25 Apr 2017 03:31:15 -0700 Subject: Adding qemu as a submodule of KVMFORNFV This Patch includes the changes to add qemu as a submodule to kvmfornfv repo and make use of the updated latest qemu for the execution of all testcase Change-Id: I1280af507a857675c7f81d30c95255635667bdd7 Signed-off-by:RajithaY --- qemu/tests/qemu-iotests/055 | 455 -------------------------------------------- 1 file changed, 455 deletions(-) delete mode 100755 qemu/tests/qemu-iotests/055 (limited to 'qemu/tests/qemu-iotests/055') diff --git a/qemu/tests/qemu-iotests/055 b/qemu/tests/qemu-iotests/055 deleted file mode 100755 index c8e357870..000000000 --- a/qemu/tests/qemu-iotests/055 +++ /dev/null @@ -1,455 +0,0 @@ -#!/usr/bin/env python -# -# Tests for drive-backup and blockdev-backup -# -# Copyright (C) 2013, 2014 Red Hat, Inc. -# -# Based on 041. -# -# 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 time -import os -import iotests -from iotests import qemu_img, qemu_io - -test_img = os.path.join(iotests.test_dir, 'test.img') -target_img = os.path.join(iotests.test_dir, 'target.img') -blockdev_target_img = os.path.join(iotests.test_dir, 'blockdev-target.img') - -class TestSingleDrive(iotests.QMPTestCase): - image_len = 64 * 1024 * 1024 # MB - - def setUp(self): - # Write data to the image so we can compare later - qemu_img('create', '-f', iotests.imgfmt, test_img, str(TestSingleDrive.image_len)) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P0x5d 0 64k', test_img) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P0xd5 1M 32k', test_img) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P0xdc 32M 124k', test_img) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P0xdc 67043328 64k', test_img) - qemu_img('create', '-f', iotests.imgfmt, blockdev_target_img, str(TestSingleDrive.image_len)) - - self.vm = iotests.VM().add_drive(test_img).add_drive(blockdev_target_img) - if iotests.qemu_default_machine == 'pc': - self.vm.add_drive(None, 'media=cdrom', 'ide') - self.vm.launch() - - def tearDown(self): - self.vm.shutdown() - os.remove(test_img) - os.remove(blockdev_target_img) - try: - os.remove(target_img) - except OSError: - pass - - def do_test_cancel(self, cmd, target): - self.assert_no_active_block_jobs() - - result = self.vm.qmp(cmd, device='drive0', target=target, sync='full') - self.assert_qmp(result, 'return', {}) - - event = self.cancel_and_wait() - self.assert_qmp(event, 'data/type', 'backup') - - def test_cancel_drive_backup(self): - self.do_test_cancel('drive-backup', target_img) - - def test_cancel_blockdev_backup(self): - self.do_test_cancel('blockdev-backup', 'drive1') - - def do_test_pause(self, cmd, target, image): - self.assert_no_active_block_jobs() - - self.vm.pause_drive('drive0') - result = self.vm.qmp(cmd, device='drive0', - target=target, sync='full') - self.assert_qmp(result, 'return', {}) - - result = self.vm.qmp('block-job-pause', device='drive0') - self.assert_qmp(result, 'return', {}) - - self.vm.resume_drive('drive0') - time.sleep(1) - result = self.vm.qmp('query-block-jobs') - offset = self.dictpath(result, 'return[0]/offset') - - time.sleep(1) - result = self.vm.qmp('query-block-jobs') - self.assert_qmp(result, 'return[0]/offset', offset) - - result = self.vm.qmp('block-job-resume', device='drive0') - self.assert_qmp(result, 'return', {}) - - self.wait_until_completed() - - self.vm.shutdown() - self.assertTrue(iotests.compare_images(test_img, image), - 'target image does not match source after backup') - - def test_pause_drive_backup(self): - self.do_test_pause('drive-backup', target_img, target_img) - - def test_pause_blockdev_backup(self): - self.do_test_pause('blockdev-backup', 'drive1', blockdev_target_img) - - def test_medium_not_found(self): - if iotests.qemu_default_machine != 'pc': - return - - result = self.vm.qmp('drive-backup', device='drive2', # CD-ROM - target=target_img, sync='full') - self.assert_qmp(result, 'error/class', 'GenericError') - - def test_medium_not_found_blockdev_backup(self): - if iotests.qemu_default_machine != 'pc': - return - - result = self.vm.qmp('blockdev-backup', device='drive2', # CD-ROM - target='drive1', sync='full') - self.assert_qmp(result, 'error/class', 'GenericError') - - def test_image_not_found(self): - result = self.vm.qmp('drive-backup', device='drive0', - target=target_img, sync='full', mode='existing') - self.assert_qmp(result, 'error/class', 'GenericError') - - def test_invalid_format(self): - result = self.vm.qmp('drive-backup', device='drive0', - target=target_img, sync='full', - format='spaghetti-noodles') - self.assert_qmp(result, 'error/class', 'GenericError') - - def do_test_device_not_found(self, cmd, **args): - result = self.vm.qmp(cmd, **args) - if cmd == 'drive-backup': - self.assert_qmp(result, 'error/class', 'DeviceNotFound') - else: - self.assert_qmp(result, 'error/class', 'GenericError') - - def test_device_not_found(self): - self.do_test_device_not_found('drive-backup', device='nonexistent', - target=target_img, sync='full') - - self.do_test_device_not_found('blockdev-backup', device='nonexistent', - target='drive0', sync='full') - - self.do_test_device_not_found('blockdev-backup', device='drive0', - target='nonexistent', sync='full') - - self.do_test_device_not_found('blockdev-backup', device='nonexistent', - target='nonexistent', sync='full') - - def test_target_is_source(self): - result = self.vm.qmp('blockdev-backup', device='drive0', - target='drive0', sync='full') - self.assert_qmp(result, 'error/class', 'GenericError') - -class TestSetSpeed(iotests.QMPTestCase): - image_len = 80 * 1024 * 1024 # MB - - def setUp(self): - qemu_img('create', '-f', iotests.imgfmt, test_img, str(TestSetSpeed.image_len)) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P1 0 512', test_img) - qemu_img('create', '-f', iotests.imgfmt, blockdev_target_img, str(TestSingleDrive.image_len)) - - self.vm = iotests.VM().add_drive(test_img).add_drive(blockdev_target_img) - self.vm.launch() - - def tearDown(self): - self.vm.shutdown() - os.remove(test_img) - os.remove(blockdev_target_img) - try: - os.remove(target_img) - except OSError: - pass - - def do_test_set_speed(self, cmd, target): - self.assert_no_active_block_jobs() - - self.vm.pause_drive('drive0') - result = self.vm.qmp(cmd, device='drive0', target=target, sync='full') - self.assert_qmp(result, 'return', {}) - - # Default speed is 0 - result = self.vm.qmp('query-block-jobs') - self.assert_qmp(result, 'return[0]/device', 'drive0') - self.assert_qmp(result, 'return[0]/speed', 0) - - result = self.vm.qmp('block-job-set-speed', device='drive0', speed=8 * 1024 * 1024) - self.assert_qmp(result, 'return', {}) - - # Ensure the speed we set was accepted - result = self.vm.qmp('query-block-jobs') - self.assert_qmp(result, 'return[0]/device', 'drive0') - self.assert_qmp(result, 'return[0]/speed', 8 * 1024 * 1024) - - event = self.cancel_and_wait(resume=True) - self.assert_qmp(event, 'data/type', 'backup') - - # Check setting speed option works - self.vm.pause_drive('drive0') - result = self.vm.qmp(cmd, device='drive0', - target=target, sync='full', speed=4*1024*1024) - self.assert_qmp(result, 'return', {}) - - result = self.vm.qmp('query-block-jobs') - self.assert_qmp(result, 'return[0]/device', 'drive0') - self.assert_qmp(result, 'return[0]/speed', 4 * 1024 * 1024) - - event = self.cancel_and_wait(resume=True) - self.assert_qmp(event, 'data/type', 'backup') - - def test_set_speed_drive_backup(self): - self.do_test_set_speed('drive-backup', target_img) - - def test_set_speed_blockdev_backup(self): - self.do_test_set_speed('blockdev-backup', 'drive1') - - def do_test_set_speed_invalid(self, cmd, target): - self.assert_no_active_block_jobs() - - result = self.vm.qmp(cmd, device='drive0', - target=target, sync='full', speed=-1) - self.assert_qmp(result, 'error/class', 'GenericError') - - self.assert_no_active_block_jobs() - - self.vm.pause_drive('drive0') - result = self.vm.qmp(cmd, device='drive0', - target=target, sync='full') - self.assert_qmp(result, 'return', {}) - - result = self.vm.qmp('block-job-set-speed', device='drive0', speed=-1) - self.assert_qmp(result, 'error/class', 'GenericError') - - event = self.cancel_and_wait(resume=True) - self.assert_qmp(event, 'data/type', 'backup') - - def test_set_speed_invalid_drive_backup(self): - self.do_test_set_speed_invalid('drive-backup', target_img) - - def test_set_speed_invalid_blockdev_backup(self): - self.do_test_set_speed_invalid('blockdev-backup', 'drive1') - -class TestSingleTransaction(iotests.QMPTestCase): - image_len = 64 * 1024 * 1024 # MB - - def setUp(self): - qemu_img('create', '-f', iotests.imgfmt, test_img, str(TestSingleTransaction.image_len)) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P0x5d 0 64k', test_img) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P0xd5 1M 32k', test_img) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P0xdc 32M 124k', test_img) - qemu_io('-f', iotests.imgfmt, '-c', 'write -P0xdc 67043328 64k', test_img) - qemu_img('create', '-f', iotests.imgfmt, blockdev_target_img, str(TestSingleDrive.image_len)) - - self.vm = iotests.VM().add_drive(test_img).add_drive(blockdev_target_img) - if iotests.qemu_default_machine == 'pc': - self.vm.add_drive(None, 'media=cdrom', 'ide') - self.vm.launch() - - def tearDown(self): - self.vm.shutdown() - os.remove(test_img) - os.remove(blockdev_target_img) - try: - os.remove(target_img) - except OSError: - pass - - def do_test_cancel(self, cmd, target): - self.assert_no_active_block_jobs() - - result = self.vm.qmp('transaction', actions=[{ - 'type': cmd, - 'data': { 'device': 'drive0', - 'target': target, - 'sync': 'full' }, - } - ]) - - self.assert_qmp(result, 'return', {}) - - event = self.cancel_and_wait() - self.assert_qmp(event, 'data/type', 'backup') - - def test_cancel_drive_backup(self): - self.do_test_cancel('drive-backup', target_img) - - def test_cancel_blockdev_backup(self): - self.do_test_cancel('blockdev-backup', 'drive1') - - def do_test_pause(self, cmd, target, image): - self.assert_no_active_block_jobs() - - self.vm.pause_drive('drive0') - result = self.vm.qmp('transaction', actions=[{ - 'type': cmd, - 'data': { 'device': 'drive0', - 'target': target, - 'sync': 'full' }, - } - ]) - self.assert_qmp(result, 'return', {}) - - result = self.vm.qmp('block-job-pause', device='drive0') - self.assert_qmp(result, 'return', {}) - - self.vm.resume_drive('drive0') - time.sleep(1) - result = self.vm.qmp('query-block-jobs') - offset = self.dictpath(result, 'return[0]/offset') - - time.sleep(1) - result = self.vm.qmp('query-block-jobs') - self.assert_qmp(result, 'return[0]/offset', offset) - - result = self.vm.qmp('block-job-resume', device='drive0') - self.assert_qmp(result, 'return', {}) - - self.wait_until_completed() - - self.vm.shutdown() - self.assertTrue(iotests.compare_images(test_img, image), - 'target image does not match source after backup') - - def test_pause_drive_backup(self): - self.do_test_pause('drive-backup', target_img, target_img) - - def test_pause_blockdev_backup(self): - self.do_test_pause('blockdev-backup', 'drive1', blockdev_target_img) - - def do_test_medium_not_found(self, cmd, target): - if iotests.qemu_default_machine != 'pc': - return - - result = self.vm.qmp('transaction', actions=[{ - 'type': cmd, - 'data': { 'device': 'drive2', # CD-ROM - 'target': target, - 'sync': 'full' }, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - - def test_medium_not_found_drive_backup(self): - self.do_test_medium_not_found('drive-backup', target_img) - - def test_medium_not_found_blockdev_backup(self): - self.do_test_medium_not_found('blockdev-backup', 'drive1') - - def test_image_not_found(self): - result = self.vm.qmp('transaction', actions=[{ - 'type': 'drive-backup', - 'data': { 'device': 'drive0', - 'mode': 'existing', - 'target': target_img, - 'sync': 'full' }, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - - def test_device_not_found(self): - result = self.vm.qmp('transaction', actions=[{ - 'type': 'drive-backup', - 'data': { 'device': 'nonexistent', - 'mode': 'existing', - 'target': target_img, - 'sync': 'full' }, - } - ]) - self.assert_qmp(result, 'error/class', 'DeviceNotFound') - - result = self.vm.qmp('transaction', actions=[{ - 'type': 'blockdev-backup', - 'data': { 'device': 'nonexistent', - 'target': 'drive1', - 'sync': 'full' }, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - - result = self.vm.qmp('transaction', actions=[{ - 'type': 'blockdev-backup', - 'data': { 'device': 'drive0', - 'target': 'nonexistent', - 'sync': 'full' }, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - - result = self.vm.qmp('transaction', actions=[{ - 'type': 'blockdev-backup', - 'data': { 'device': 'nonexistent', - 'target': 'nonexistent', - 'sync': 'full' }, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - - def test_target_is_source(self): - result = self.vm.qmp('transaction', actions=[{ - 'type': 'blockdev-backup', - 'data': { 'device': 'drive0', - 'target': 'drive0', - 'sync': 'full' }, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - - def test_abort(self): - result = self.vm.qmp('transaction', actions=[{ - 'type': 'drive-backup', - 'data': { 'device': 'nonexistent', - 'mode': 'existing', - 'target': target_img, - 'sync': 'full' }, - }, { - 'type': 'Abort', - 'data': {}, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - self.assert_no_active_block_jobs() - - result = self.vm.qmp('transaction', actions=[{ - 'type': 'blockdev-backup', - 'data': { 'device': 'nonexistent', - 'target': 'drive1', - 'sync': 'full' }, - }, { - 'type': 'Abort', - 'data': {}, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - self.assert_no_active_block_jobs() - - result = self.vm.qmp('transaction', actions=[{ - 'type': 'blockdev-backup', - 'data': { 'device': 'drive0', - 'target': 'nonexistent', - 'sync': 'full' }, - }, { - 'type': 'Abort', - 'data': {}, - } - ]) - self.assert_qmp(result, 'error/class', 'GenericError') - self.assert_no_active_block_jobs() - -if __name__ == '__main__': - iotests.main(supported_fmts=['raw', 'qcow2']) -- cgit 1.2.3-korg