[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH 4/4] iotests: Add test for failing mirror comple
From: |
Vladimir Sementsov-Ogievskiy |
Subject: |
Re: [Qemu-devel] [PATCH 4/4] iotests: Add test for failing mirror complete |
Date: |
Wed, 18 Sep 2019 16:30:13 +0000 |
12.09.2019 16:56, Max Reitz wrote:
> Signed-off-by: Max Reitz <address@hidden>
> ---
> tests/qemu-iotests/041 | 44 ++++++++++++++++++++++++++++++++++++++
> tests/qemu-iotests/041.out | 4 ++--
> 2 files changed, 46 insertions(+), 2 deletions(-)
>
> diff --git a/tests/qemu-iotests/041 b/tests/qemu-iotests/041
> index 8568426311..84bc6d6581 100755
> --- a/tests/qemu-iotests/041
> +++ b/tests/qemu-iotests/041
> @@ -1121,6 +1121,50 @@ class TestOrphanedSource(iotests.QMPTestCase):
> target='dest-ro')
> self.assert_qmp(result, 'error/class', 'GenericError')
>
> + def test_failing_permission_in_complete(self):
> + self.assert_no_active_block_jobs()
> +
> + # Unshare consistent-read on the target
> + # (The mirror job does not care)
> + result = self.vm.qmp('blockdev-add',
> + driver='blkdebug',
> + node_name='dest-perm',
> + image='dest',
> + unshare_child_perms=['consistent-read'])
> + self.assert_qmp(result, 'return', {})
> +
> + result = self.vm.qmp('blockdev-mirror', job_id='job', device='src',
> + sync='full', target='dest',
> + filter_node_name='mirror-filter')
> + self.assert_qmp(result, 'return', {})
> +
> + # Require consistent-read on the source
> + # (We can only add this node once the job has started, or it
> + # will complain that it does not want to run on non-root nodes)
> + result = self.vm.qmp('blockdev-add',
> + driver='blkdebug',
> + node_name='src-perm',
> + image='src',
> + take_child_perms=['consistent-read'])
> + self.assert_qmp(result, 'return', {})
> +
> + # While completing, mirror will attempt to replace src by
> + # dest, which must fail because src-perm requires
> + # consistent-read but dest-perm does not share it; thus
> + # aborting the job when it is supposed to complete
> + self.complete_and_wait('job',
> + completion_error='Operation not permitted')
> +
> + # Assert that all of our nodes are still there (except for the
> + # mirror filter, which should be gone despite the failure)
> + nodes = self.vm.qmp('query-named-block-nodes')['return']
> + nodes = list(map(lambda image: image['node-name'], nodes))
using list comprehension is a bit more pythonic:
nodes = [node['node-name'] for node in nodes]
> +
> + for expect in ['src', 'src-perm', 'dest', 'dest-perm']:
> + self.assertTrue(expect in nodes, '%s disappeared' % expect)
> + self.assertFalse('mirror-filter' in nodes,
> + 'Mirror filter node did not disappear')
> +
> if __name__ == '__main__':
> iotests.main(supported_fmts=['qcow2', 'qed'],
> supported_protocols=['file'])
> diff --git a/tests/qemu-iotests/041.out b/tests/qemu-iotests/041.out
> index 2c448b4239..f496be9197 100644
> --- a/tests/qemu-iotests/041.out
> +++ b/tests/qemu-iotests/041.out
> @@ -1,5 +1,5 @@
> -..........................................................................................
> +...........................................................................................
> ----------------------------------------------------------------------
> -Ran 90 tests
> +Ran 91 tests
>
> OK
>
With or without my suggestion:
Reviewed-by: Vladimir Sementsov-Ogievskiy <address@hidden>
I checked, that it pass, and that fails (generates segfault) if drop patch 01:
Tested-by: Vladimir Sementsov-Ogievskiy <address@hidden>
--
Best regards,
Vladimir
- Re: [Qemu-devel] [PATCH 1/4] mirror: Do not dereference invalid pointers, (continued)
Re: [Qemu-devel] [PATCH 0/4] mirror: Do not dereference invalid pointers, Vladimir Sementsov-Ogievskiy, 2019/09/18