| 
									
										
										
										
											2020-01-30 17:32:23 +01:00
										 |  |  | #!/usr/bin/env python3 | 
					
						
							| 
									
										
										
										
											2021-01-16 16:44:19 +03:00
										 |  |  | # group: rw | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | # | 
					
						
							| 
									
										
										
										
											2021-01-26 11:48:33 +01:00
										 |  |  | # Test case for media change monitor commands | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | # | 
					
						
							|  |  |  | # 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_blockdev_change_medium(self): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', | 
					
						
							|  |  |  |                     id=self.device_name, filename=new_img, | 
					
						
							|  |  |  |                     format=iotests.imgfmt) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('eject', id=self.device_name, force=True) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('eject', id=self.device_name, force=True) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', id=self.device_name, | 
					
						
							|  |  |  |                     filename=new_img, format=iotests.imgfmt) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-open-tray', | 
					
						
							|  |  |  |                     id=self.device_name, force=True) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-close-tray', id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('eject', id=self.device_name, force=True) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-close-tray', id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												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): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-open-tray', id=self.device_name, | 
					
						
							|  |  |  |                                           force=True) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', id=self.device_name, | 
					
						
							|  |  |  |                                               filename=new_img, | 
					
						
							|  |  |  |                                               format=iotests.imgfmt) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-add', | 
					
						
							|  |  |  |                     node_name='new', | 
					
						
							|  |  |  |                     driver=iotests.imgfmt, | 
					
						
							|  |  |  |                     read_only=read_only_node, | 
					
						
							|  |  |  |                     file={'filename': new_img, | 
					
						
							|  |  |  |                            'driver': 'file'}) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         self.vm.cmd('blockdev-open-tray', | 
					
						
							|  |  |  |                     id=self.device_name, force=True) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-remove-medium', | 
					
						
							|  |  |  |                     id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-insert-medium', | 
					
						
							|  |  |  |                     id=self.device_name, node_name='new') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-close-tray', id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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): | 
					
						
							|  |  |  |         # Should be a no-op | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-close-tray', id=self.device_name) | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-add', | 
					
						
							|  |  |  |                     node_name='new', | 
					
						
							|  |  |  |                     driver=iotests.imgfmt, | 
					
						
							|  |  |  |                     file={'filename': new_img, | 
					
						
							|  |  |  |                           'driver': 'file'}) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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': | 
					
						
							| 
									
										
										
										
											2023-10-13 17:33:02 +02:00
										 |  |  |             self.vm.add_object('iothread,id=iothread0') | 
					
						
							|  |  |  |             self.vm.add_device('virtio-scsi-pci,iothread=iothread0') | 
					
						
							| 
									
										
										
										
											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): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-add', | 
					
						
							|  |  |  |                     node_name='new', | 
					
						
							|  |  |  |                     driver=iotests.imgfmt, | 
					
						
							|  |  |  |                     file={'filename': new_img, | 
					
						
							|  |  |  |                           'driver': 'file'}) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-open-tray', id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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': | 
					
						
							| 
									
										
										
										
											2023-10-13 17:33:02 +02:00
										 |  |  |             self.vm.add_object('iothread,id=iothread0') | 
					
						
							|  |  |  |             self.vm.add_device('virtio-scsi-pci,iothread=iothread0') | 
					
						
							| 
									
										
										
										
											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): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-open-tray', id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         self.wait_for_open() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # Should be a no-op | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-remove-medium', id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 09:29:52 -03: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 09:29:52 -03: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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', id=self.device_name, | 
					
						
							|  |  |  |                                               filename=new_img, | 
					
						
							|  |  |  |                                               format=iotests.imgfmt, | 
					
						
							|  |  |  |                                               read_only_mode='retain') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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 09:29:52 -03: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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', id=self.device_name, | 
					
						
							|  |  |  |                                               filename=new_img, | 
					
						
							|  |  |  |                                               format=iotests.imgfmt, | 
					
						
							|  |  |  |                                               read_only_mode='retain') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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 09:29:52 -03: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 09:29:52 -03: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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', | 
					
						
							|  |  |  |                     id=self.device_name, | 
					
						
							|  |  |  |                     filename=new_img, | 
					
						
							|  |  |  |                     format=iotests.imgfmt, | 
					
						
							|  |  |  |                     read_only_mode='read-write') | 
					
						
							| 
									
										
										
										
											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', new_img) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def test_rw_ro(self): | 
					
						
							| 
									
										
										
										
											2018-06-08 09:29:52 -03: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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', | 
					
						
							|  |  |  |                     id=self.device_name, | 
					
						
							|  |  |  |                     filename=new_img, | 
					
						
							|  |  |  |                     format=iotests.imgfmt, | 
					
						
							|  |  |  |                     read_only_mode='read-only') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', | 
					
						
							|  |  |  |                     id=self.device_name, | 
					
						
							|  |  |  |                     filename=new_img, | 
					
						
							|  |  |  |                     format=iotests.imgfmt, | 
					
						
							|  |  |  |                     read_only_mode='read-only') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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 09:29:52 -03: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 09:29:52 -03: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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-change-medium', id=self.device_name, | 
					
						
							|  |  |  |                                               filename=new_img, | 
					
						
							|  |  |  |                                               format=iotests.imgfmt, | 
					
						
							|  |  |  |                                               read_only_mode='retain') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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 09:29:52 -03: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 09:29:52 -03: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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-add', | 
					
						
							|  |  |  |                     node_name='new', | 
					
						
							|  |  |  |                     driver=iotests.imgfmt, | 
					
						
							|  |  |  |                     read_only=True, | 
					
						
							|  |  |  |                     file={'filename': new_img, | 
					
						
							|  |  |  |                            'driver': 'file'}) | 
					
						
							| 
									
										
										
										
											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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-remove-medium', id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         result = self.vm.qmp('query-block') | 
					
						
							|  |  |  |         self.assert_qmp_absent(result, 'return[0]/inserted') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-insert-medium', id=self.device_name, | 
					
						
							|  |  |  |                                               node_name='new') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-remove-medium', id=self.device_name) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         result = self.vm.qmp('query-block') | 
					
						
							|  |  |  |         self.assert_qmp_absent(result, 'return[0]/inserted') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-add', | 
					
						
							|  |  |  |                     node_name='node0', | 
					
						
							|  |  |  |                     driver=iotests.imgfmt, | 
					
						
							|  |  |  |                     file={'filename': old_img, | 
					
						
							|  |  |  |                           'driver': 'file'}) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-insert-medium', id=self.device_name, | 
					
						
							|  |  |  |                                               node_name='node0') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-17 12:48:18 +02:00
										 |  |  |     # We need backing file support | 
					
						
							|  |  |  |     @iotests.skip_for_formats(('vpc', 'parallels', 'qcow', 'vdi', 'vmdk', 'raw', | 
					
						
							|  |  |  |                                'vhdx')) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  |     def test_snapshot_and_commit(self): | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('blockdev-snapshot-sync', device='drive0', | 
					
						
							|  |  |  |                                               snapshot_file=new_img, | 
					
						
							|  |  |  |                                               format=iotests.imgfmt) | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('block-commit', device='drive0') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         self.vm.event_wait(name='BLOCK_JOB_READY') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         result = self.vm.qmp('query-block-jobs') | 
					
						
							|  |  |  |         self.assert_qmp(result, 'return[0]/device', 'drive0') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 18:41:25 +03:00
										 |  |  |         self.vm.cmd('block-job-complete', device='drive0') | 
					
						
							| 
									
										
										
										
											2015-10-26 21:39:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         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']) |