2015-10-26 21:39:19 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
#
|
|
|
|
# Test case for the QMP 'change' command and all other associated
|
|
|
|
# commands
|
|
|
|
#
|
|
|
|
# Copyright (C) 2015 Red Hat, Inc.
|
|
|
|
#
|
|
|
|
# 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 <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
|
|
|
|
import os
|
|
|
|
import stat
|
|
|
|
import time
|
|
|
|
import iotests
|
|
|
|
from iotests import qemu_img
|
|
|
|
|
|
|
|
old_img = os.path.join(iotests.test_dir, 'test0.img')
|
|
|
|
new_img = os.path.join(iotests.test_dir, 'test1.img')
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
def interface_to_device_name(interface):
|
|
|
|
if interface == 'ide':
|
|
|
|
return 'ide-cd'
|
|
|
|
elif interface == 'floppy':
|
|
|
|
return 'floppy'
|
2019-07-30 12:23:45 +02:00
|
|
|
elif interface == 'scsi':
|
|
|
|
return 'scsi-cd'
|
2017-11-10 23:42:59 +01:00
|
|
|
else:
|
|
|
|
return None
|
|
|
|
|
2015-10-26 21:39:19 +01:00
|
|
|
class ChangeBaseClass(iotests.QMPTestCase):
|
|
|
|
has_opened = False
|
|
|
|
has_closed = False
|
|
|
|
|
2019-07-30 16:49:26 +02:00
|
|
|
device_name = 'qdev0'
|
|
|
|
use_drive = False
|
|
|
|
|
2015-10-26 21:39:19 +01:00
|
|
|
def process_events(self):
|
|
|
|
for event in self.vm.get_qmp_events(wait=False):
|
|
|
|
if (event['event'] == 'DEVICE_TRAY_MOVED' and
|
2019-07-30 16:49:26 +02:00
|
|
|
(event['data']['device'] == 'drive0' or
|
|
|
|
event['data']['id'] == self.device_name)):
|
2015-10-26 21:39:19 +01:00
|
|
|
if event['data']['tray-open'] == False:
|
|
|
|
self.has_closed = True
|
|
|
|
else:
|
|
|
|
self.has_opened = True
|
|
|
|
|
|
|
|
def wait_for_open(self):
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if not self.has_real_tray:
|
|
|
|
return
|
|
|
|
|
2018-11-20 18:09:49 +01:00
|
|
|
with iotests.Timeout(3, 'Timeout while waiting for the tray to open'):
|
|
|
|
while not self.has_opened:
|
|
|
|
self.process_events()
|
2015-10-26 21:39:19 +01:00
|
|
|
|
|
|
|
def wait_for_close(self):
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if not self.has_real_tray:
|
|
|
|
return
|
|
|
|
|
2018-11-20 18:09:49 +01:00
|
|
|
with iotests.Timeout(3, 'Timeout while waiting for the tray to close'):
|
|
|
|
while not self.has_closed:
|
|
|
|
self.process_events()
|
2015-10-26 21:39:19 +01:00
|
|
|
|
|
|
|
class GeneralChangeTestsBaseClass(ChangeBaseClass):
|
2016-09-20 13:38:49 +02:00
|
|
|
|
2015-10-26 21:39:19 +01:00
|
|
|
def test_change(self):
|
2019-07-30 16:49:26 +02:00
|
|
|
# 'change' requires a drive name, so skip the test for blockdev
|
|
|
|
if not self.use_drive:
|
|
|
|
return
|
|
|
|
|
2015-10-26 21:39:19 +01:00
|
|
|
result = self.vm.qmp('change', device='drive0', target=new_img,
|
|
|
|
arg=iotests.imgfmt)
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
self.wait_for_close()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', False)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
|
|
|
def test_blockdev_change_medium(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-change-medium',
|
|
|
|
id=self.device_name, filename=new_img,
|
|
|
|
format=iotests.imgfmt)
|
2016-09-20 13:38:49 +02:00
|
|
|
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
self.wait_for_close()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', False)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
|
|
|
def test_eject(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('eject', id=self.device_name, force=True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
|
|
|
|
def test_tray_eject_change(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('eject', id=self.device_name, force=True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-change-medium', id=self.device_name,
|
|
|
|
filename=new_img, format=iotests.imgfmt)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_close()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', False)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
|
|
|
def test_tray_open_close(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-open-tray',
|
|
|
|
id=self.device_name, force=True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', True)
|
2015-10-26 21:39:19 +01:00
|
|
|
if self.was_empty == True:
|
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
else:
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-close-tray', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
if self.has_real_tray or not self.was_empty:
|
|
|
|
self.wait_for_close()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', False)
|
|
|
|
if self.was_empty == True:
|
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
else:
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
def test_tray_eject_close(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('eject', id=self.device_name, force=True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-close-tray', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
self.wait_for_close()
|
2015-10-26 21:39:19 +01:00
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', False)
|
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
|
|
|
|
def test_tray_open_change(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-open-tray', id=self.device_name,
|
|
|
|
force=True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', True)
|
2015-10-26 21:39:19 +01:00
|
|
|
if self.was_empty == True:
|
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
else:
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-change-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt)
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_close()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', False)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
2019-07-30 16:50:52 +02:00
|
|
|
def test_cycle(self, read_only_node=False):
|
2015-10-26 21:39:19 +01:00
|
|
|
result = self.vm.qmp('blockdev-add',
|
2016-10-07 17:05:04 +02:00
|
|
|
node_name='new',
|
|
|
|
driver=iotests.imgfmt,
|
2019-07-30 16:50:52 +02:00
|
|
|
read_only=read_only_node,
|
2016-10-07 17:05:04 +02:00
|
|
|
file={'filename': new_img,
|
|
|
|
'driver': 'file'})
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-open-tray',
|
|
|
|
id=self.device_name, force=True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', True)
|
2015-10-26 21:39:19 +01:00
|
|
|
if self.was_empty == True:
|
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
else:
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-remove-medium',
|
2017-11-10 23:42:59 +01:00
|
|
|
id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-insert-medium',
|
2017-11-10 23:42:59 +01:00
|
|
|
id=self.device_name, node_name='new')
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', True)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-close-tray', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_close()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if self.has_real_tray:
|
|
|
|
self.assert_qmp(result, 'return[0]/tray_open', False)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
2019-07-30 16:50:52 +02:00
|
|
|
def test_cycle_read_only_media(self):
|
|
|
|
self.test_cycle(True)
|
|
|
|
|
2015-10-26 21:39:19 +01:00
|
|
|
def test_close_on_closed(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-close-tray', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
# Should be a no-op
|
|
|
|
self.assert_qmp(result, 'return', {})
|
2018-11-20 18:12:21 +01:00
|
|
|
self.assertEqual(self.vm.get_qmp_events(wait=False), [])
|
2015-10-26 21:39:19 +01:00
|
|
|
|
|
|
|
def test_remove_on_closed(self):
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if not self.has_real_tray:
|
2015-10-26 21:39:19 +01:00
|
|
|
return
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-remove-medium', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'error/class', 'GenericError')
|
|
|
|
|
|
|
|
def test_insert_on_closed(self):
|
Revert "hw/block/fdc: Implement tray status"
This reverts the changes that commit
2e1280e8ff95b3145bc6262accc9d447718e5318 applied to hw/block/fdc.c;
also, an additional case of drv->media_inserted use has crept in since,
which is replaced by a call to blk_is_inserted().
That commit changed tests/fdc-test.c, too, because after it, one less
TRAY_MOVED event would be emitted when executing 'change' on an empty
drive. However, now, no TRAY_MOVED events will be emitted at all, and
the tray_open status returned by query-block will always be false,
necessitating (different) changes to tests/fdc-test.c and iotest 118,
which is why this patch is not a pure revert of said commit.
Signed-off-by: Max Reitz <mreitz@redhat.com>
Message-id: 1454096953-31773-4-git-send-email-mreitz@redhat.com
Reviewed-by: Eric Blake <eblake@redhat.com>
2016-01-29 20:49:12 +01:00
|
|
|
if not self.has_real_tray:
|
2015-10-26 21:39:19 +01:00
|
|
|
return
|
|
|
|
|
|
|
|
result = self.vm.qmp('blockdev-add',
|
2016-10-07 17:05:04 +02:00
|
|
|
node_name='new',
|
|
|
|
driver=iotests.imgfmt,
|
|
|
|
file={'filename': new_img,
|
|
|
|
'driver': 'file'})
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-insert-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
node_name='new')
|
|
|
|
self.assert_qmp(result, 'error/class', 'GenericError')
|
|
|
|
|
|
|
|
class TestInitiallyFilled(GeneralChangeTestsBaseClass):
|
|
|
|
was_empty = False
|
|
|
|
|
2019-07-30 16:25:55 +02:00
|
|
|
def setUp(self):
|
2015-10-26 21:39:19 +01:00
|
|
|
qemu_img('create', '-f', iotests.imgfmt, old_img, '1440k')
|
|
|
|
qemu_img('create', '-f', iotests.imgfmt, new_img, '1440k')
|
2016-09-20 13:38:49 +02:00
|
|
|
self.vm = iotests.VM()
|
2019-07-30 16:49:26 +02:00
|
|
|
if self.use_drive:
|
|
|
|
self.vm.add_drive(old_img, 'media=%s' % self.media, 'none')
|
|
|
|
else:
|
|
|
|
self.vm.add_blockdev([ 'node-name=drive0',
|
|
|
|
'driver=%s' % iotests.imgfmt,
|
|
|
|
'file.driver=file',
|
|
|
|
'file.filename=%s' % old_img ])
|
2019-07-30 16:25:55 +02:00
|
|
|
if self.interface == 'scsi':
|
2019-07-30 12:23:45 +02:00
|
|
|
self.vm.add_device('virtio-scsi-pci')
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_device('%s,drive=drive0,id=%s' %
|
2019-07-30 16:25:55 +02:00
|
|
|
(interface_to_device_name(self.interface),
|
2017-11-10 23:42:59 +01:00
|
|
|
self.device_name))
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
self.vm.shutdown()
|
|
|
|
os.remove(old_img)
|
|
|
|
os.remove(new_img)
|
|
|
|
|
|
|
|
def test_insert_on_filled(self):
|
|
|
|
result = self.vm.qmp('blockdev-add',
|
2016-10-07 17:05:04 +02:00
|
|
|
node_name='new',
|
|
|
|
driver=iotests.imgfmt,
|
|
|
|
file={'filename': new_img,
|
|
|
|
'driver': 'file'})
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-open-tray', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-insert-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
node_name='new')
|
|
|
|
self.assert_qmp(result, 'error/class', 'GenericError')
|
|
|
|
|
|
|
|
class TestInitiallyEmpty(GeneralChangeTestsBaseClass):
|
|
|
|
was_empty = True
|
|
|
|
|
2019-07-30 16:25:55 +02:00
|
|
|
def setUp(self):
|
2015-10-26 21:39:19 +01:00
|
|
|
qemu_img('create', '-f', iotests.imgfmt, new_img, '1440k')
|
2019-07-30 16:49:26 +02:00
|
|
|
self.vm = iotests.VM()
|
|
|
|
if self.use_drive:
|
|
|
|
self.vm.add_drive(None, 'media=%s' % self.media, 'none')
|
2019-07-30 16:25:55 +02:00
|
|
|
if self.interface == 'scsi':
|
2019-07-30 12:23:45 +02:00
|
|
|
self.vm.add_device('virtio-scsi-pci')
|
2019-07-30 16:49:26 +02:00
|
|
|
self.vm.add_device('%s,%sid=%s' %
|
2019-07-30 16:25:55 +02:00
|
|
|
(interface_to_device_name(self.interface),
|
2019-07-30 16:49:26 +02:00
|
|
|
'drive=drive0,' if self.use_drive else '',
|
2017-11-10 23:42:59 +01:00
|
|
|
self.device_name))
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
self.vm.shutdown()
|
|
|
|
os.remove(new_img)
|
|
|
|
|
|
|
|
def test_remove_on_empty(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-open-tray', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.wait_for_open()
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-remove-medium', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
# Should be a no-op
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
2019-07-30 16:25:55 +02:00
|
|
|
# Do this in a function to avoid leaking variables like case into the global
|
|
|
|
# name space (otherwise tests would be run for the abstract base classes)
|
|
|
|
def create_basic_test_classes():
|
|
|
|
for (media, interface, has_real_tray) in [ ('cdrom', 'ide', True),
|
|
|
|
('cdrom', 'scsi', True),
|
|
|
|
('disk', 'floppy', False) ]:
|
2015-10-26 21:39:19 +01:00
|
|
|
|
2019-07-30 16:25:55 +02:00
|
|
|
for case in [ TestInitiallyFilled, TestInitiallyEmpty ]:
|
2019-07-30 16:49:26 +02:00
|
|
|
for use_drive in [ True, False ]:
|
|
|
|
attr = { 'media': media,
|
|
|
|
'interface': interface,
|
|
|
|
'has_real_tray': has_real_tray,
|
|
|
|
'use_drive': use_drive }
|
|
|
|
|
|
|
|
name = '%s_%s_%s_%s' % (case.__name__, media, interface,
|
|
|
|
'drive' if use_drive else 'blockdev')
|
|
|
|
globals()[name] = type(name, (case, ), attr)
|
2019-07-30 12:23:45 +02:00
|
|
|
|
2019-07-30 16:25:55 +02:00
|
|
|
create_basic_test_classes()
|
2015-10-26 21:39:19 +01:00
|
|
|
|
|
|
|
class TestChangeReadOnly(ChangeBaseClass):
|
2017-11-10 23:42:59 +01:00
|
|
|
device_name = 'qdev0'
|
|
|
|
|
2015-10-26 21:39:19 +01:00
|
|
|
def setUp(self):
|
|
|
|
qemu_img('create', '-f', iotests.imgfmt, old_img, '1440k')
|
|
|
|
qemu_img('create', '-f', iotests.imgfmt, new_img, '1440k')
|
|
|
|
self.vm = iotests.VM()
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
self.vm.shutdown()
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(old_img, 0o666)
|
|
|
|
os.chmod(new_img, 0o666)
|
2015-10-26 21:39:19 +01:00
|
|
|
os.remove(old_img)
|
|
|
|
os.remove(new_img)
|
|
|
|
|
|
|
|
def test_ro_ro_retain(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(old_img, 0o444)
|
|
|
|
os.chmod(new_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk,read-only=on', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-change-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='retain')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
|
|
|
def test_ro_rw_retain(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(old_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk,read-only=on', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-change-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='retain')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
2019-10-18 13:46:42 +02:00
|
|
|
@iotests.skip_if_user_is_root
|
2015-10-26 21:39:19 +01:00
|
|
|
def test_rw_ro_retain(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(new_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-change-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='retain')
|
|
|
|
self.assert_qmp(result, 'error/class', 'GenericError')
|
|
|
|
|
2018-11-20 18:12:21 +01:00
|
|
|
self.assertEqual(self.vm.get_qmp_events(wait=False), [])
|
2015-10-26 21:39:19 +01:00
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
def test_ro_rw(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(old_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk,read-only=on', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
result = self.vm.qmp('blockdev-change-medium',
|
2017-11-10 23:42:59 +01:00
|
|
|
id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='read-write')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
|
|
|
def test_rw_ro(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(new_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
result = self.vm.qmp('blockdev-change-medium',
|
2017-11-10 23:42:59 +01:00
|
|
|
id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='read-only')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
|
|
|
def test_make_rw_ro(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
result = self.vm.qmp('blockdev-change-medium',
|
2017-11-10 23:42:59 +01:00
|
|
|
id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='read-only')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
2019-10-18 13:46:42 +02:00
|
|
|
@iotests.skip_if_user_is_root
|
2015-10-26 21:39:19 +01:00
|
|
|
def test_make_ro_rw(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(new_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
result = self.vm.qmp('blockdev-change-medium',
|
2017-11-10 23:42:59 +01:00
|
|
|
id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='read-write')
|
|
|
|
self.assert_qmp(result, 'error/class', 'GenericError')
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
def test_make_rw_ro_by_retain(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(old_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk,read-only=on', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-change-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='retain')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
2019-10-18 13:46:42 +02:00
|
|
|
@iotests.skip_if_user_is_root
|
2015-10-26 21:39:19 +01:00
|
|
|
def test_make_ro_rw_by_retain(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(new_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:42:59 +01:00
|
|
|
result = self.vm.qmp('blockdev-change-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
filename=new_img,
|
|
|
|
format=iotests.imgfmt,
|
|
|
|
read_only_mode='retain')
|
|
|
|
self.assert_qmp(result, 'error/class', 'GenericError')
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
def test_rw_ro_cycle(self):
|
2018-06-08 14:29:52 +02:00
|
|
|
os.chmod(new_img, 0o444)
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_drive(old_img, 'media=disk', 'none')
|
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
result = self.vm.qmp('blockdev-add',
|
2016-10-07 17:05:04 +02:00
|
|
|
node_name='new',
|
|
|
|
driver=iotests.imgfmt,
|
|
|
|
read_only=True,
|
|
|
|
file={'filename': new_img,
|
|
|
|
'driver': 'file'})
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', False)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-remove-medium', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-insert-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
node_name='new')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/ro', True)
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
|
|
|
|
GeneralChangeTestsBaseClass = None
|
|
|
|
TestInitiallyFilled = None
|
|
|
|
TestInitiallyEmpty = None
|
|
|
|
|
|
|
|
|
|
|
|
class TestBlockJobsAfterCycle(ChangeBaseClass):
|
2017-11-10 23:42:59 +01:00
|
|
|
device_name = 'qdev0'
|
|
|
|
|
2015-10-26 21:39:19 +01:00
|
|
|
def setUp(self):
|
2017-11-10 23:42:59 +01:00
|
|
|
qemu_img('create', '-f', iotests.imgfmt, old_img, '1440K')
|
2015-10-26 21:39:19 +01:00
|
|
|
|
|
|
|
self.vm = iotests.VM()
|
2016-09-21 14:56:06 +02:00
|
|
|
self.vm.add_drive_raw("id=drive0,driver=null-co,if=none")
|
2017-11-10 23:42:59 +01:00
|
|
|
self.vm.add_device('floppy,drive=drive0,id=%s' % self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.vm.launch()
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/format', 'null-co')
|
|
|
|
|
|
|
|
# For device-less BBs, calling blockdev-open-tray or blockdev-close-tray
|
|
|
|
# is not necessary
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-remove-medium', id=self.device_name)
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp_absent(result, 'return[0]/inserted')
|
|
|
|
|
|
|
|
result = self.vm.qmp('blockdev-add',
|
2016-10-07 17:05:04 +02:00
|
|
|
node_name='node0',
|
|
|
|
driver=iotests.imgfmt,
|
|
|
|
file={'filename': old_img,
|
|
|
|
'driver': 'file'})
|
2015-10-26 21:39:19 +01:00
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
2017-11-10 23:43:02 +01:00
|
|
|
result = self.vm.qmp('blockdev-insert-medium', id=self.device_name,
|
2015-10-26 21:39:19 +01:00
|
|
|
node_name='node0')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', old_img)
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
self.vm.shutdown()
|
|
|
|
os.remove(old_img)
|
|
|
|
try:
|
|
|
|
os.remove(new_img)
|
|
|
|
except OSError:
|
|
|
|
pass
|
|
|
|
|
|
|
|
def test_snapshot_and_commit(self):
|
|
|
|
# We need backing file support
|
|
|
|
if iotests.imgfmt != 'qcow2' and iotests.imgfmt != 'qed':
|
|
|
|
return
|
|
|
|
|
|
|
|
result = self.vm.qmp('blockdev-snapshot-sync', device='drive0',
|
|
|
|
snapshot_file=new_img,
|
|
|
|
format=iotests.imgfmt)
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block')
|
|
|
|
self.assert_qmp(result, 'return[0]/inserted/image/filename', new_img)
|
|
|
|
self.assert_qmp(result,
|
|
|
|
'return[0]/inserted/image/backing-image/filename',
|
|
|
|
old_img)
|
|
|
|
|
|
|
|
result = self.vm.qmp('block-commit', device='drive0')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.vm.event_wait(name='BLOCK_JOB_READY')
|
|
|
|
|
|
|
|
result = self.vm.qmp('query-block-jobs')
|
|
|
|
self.assert_qmp(result, 'return[0]/device', 'drive0')
|
|
|
|
|
|
|
|
result = self.vm.qmp('block-job-complete', device='drive0')
|
|
|
|
self.assert_qmp(result, 'return', {})
|
|
|
|
|
|
|
|
self.vm.event_wait(name='BLOCK_JOB_COMPLETED')
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
if iotests.qemu_default_machine != 'pc':
|
|
|
|
# We need floppy and IDE CD-ROM
|
|
|
|
iotests.notrun('not suitable for this machine type: %s' %
|
|
|
|
iotests.qemu_default_machine)
|
2016-01-25 15:42:56 +01:00
|
|
|
# Need to support image creation
|
|
|
|
iotests.main(supported_fmts=['vpc', 'parallels', 'qcow', 'vdi', 'qcow2',
|
2019-09-02 21:33:18 +02:00
|
|
|
'vmdk', 'raw', 'vhdx', 'qed'],
|
|
|
|
supported_protocols=['file'])
|