From: Hanna Reitz <hreitz@redhat.com>
To: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>,
qemu-block@nongnu.org
Cc: fam@euphon.net, kwolf@redhat.com, jsnow@redhat.com,
qemu-devel@nongnu.org, armbru@redhat.com,
nikita.lapshin@virtuozzo.com, stefanha@redhat.com,
eblake@redhat.com
Subject: Re: [PATCH v5 16/16] iotests/image-fleecing: test push backup with fleecing
Date: Thu, 3 Mar 2022 11:58:52 +0100 [thread overview]
Message-ID: <1cb8456c-60c9-3a25-50c2-10b00a77ae5f@redhat.com> (raw)
In-Reply-To: <20220228113927.1852146-17-vsementsov@virtuozzo.com>
On 28.02.22 12:39, Vladimir Sementsov-Ogievskiy wrote:
> Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
> ---
> tests/qemu-iotests/tests/image-fleecing | 120 ++++++++++++++------
> tests/qemu-iotests/tests/image-fleecing.out | 63 ++++++++++
> 2 files changed, 151 insertions(+), 32 deletions(-)
>
> diff --git a/tests/qemu-iotests/tests/image-fleecing b/tests/qemu-iotests/tests/image-fleecing
> index 33995612be..89c79af698 100755
> --- a/tests/qemu-iotests/tests/image-fleecing
> +++ b/tests/qemu-iotests/tests/image-fleecing
[...]
> @@ -170,6 +196,20 @@ def do_test(use_cbw, use_snapshot_access_filter, base_img_path,
> log(cmd)
> log(vm.hmp_qemu_io(qom_path, cmd, qdev=True))
>
> + if push_backup:
> + # Check that previous operations were done during backup, not after
> + result = vm.qmp('query-block-jobs')
> + if len(result['return']) != 1:
> + log('Backup finished too fast, COW is not tested')
I don’t understand why this log is here, its message sounds like “case
not run”, but first this logged message will make the whole test fail...
> +
> + result = vm.qmp('block-job-set-speed', device='push-backup', speed=0)
> + assert result == {'return': {}}
...and then this will fail, too.
Either this is a hard failure, then the log shouldn’t include “COW is
not tested” (because it is tested, and the case has failed); or it’s a
casenotrun, and then nothing should be logged (the message should be
appended to .casenotrun), and the block-job-set-speed call and waiting
for BLOCK_JOB_COMPLETED should only be done when the job is still in the
job list.
> +
> + log(vm.event_wait(name='BLOCK_JOB_COMPLETED',
> + match={'data': {'device': 'push-backup'}}),
> + filters=[iotests.filter_qmp_event])
> + log(vm.qmp('blockdev-del', node_name='target'))
> +
> log('')
> log('--- Verifying Data ---')
> log('')
> @@ -177,15 +217,19 @@ def do_test(use_cbw, use_snapshot_access_filter, base_img_path,
> for p in patterns + zeroes:
> cmd = 'read -P%s %s %s' % p
> log(cmd)
> - out, ret = qemu_io_pipe_and_status('-r', '-f', 'raw', '-c', cmd, nbd_uri)
> - if ret != 0:
> - print(out)
> + if push_backup:
> + assert qemu_io_silent('-r', '-c', cmd, target_img_path) == 0
> + else:
> + out, ret = qemu_io_pipe_and_status('-r', '-f', 'raw', '-c', cmd, nbd_uri)
> + if ret != 0:
> + print(out)
The existing principle of “print qemu-io’s output on error” seemed
perfectly fine to me. Why not continue using it?
(e.g. like
args = ['-r', '-c', cmd]
if push_backup:
args += [target_img_path]
else:
args += ['-f', 'raw', nbd_uri]
out, ret = qemu_io_pipe_and_status(*args)
)
> log('')
> log('--- Cleanup ---')
> log('')
>
> - log(vm.qmp('nbd-server-stop'))
> + if not push_backup:
> + log(vm.qmp('nbd-server-stop'))
>
> if use_cbw:
> if use_snapshot_access_filter:
> +read -P0xcd 0x3ff0000 64k
> +
> +Done
next prev parent reply other threads:[~2022-03-03 11:01 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-02-28 11:39 [PATCH v5 00/16] Make image fleecing more usable Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 01/16] block/block-copy: move copy_bitmap initialization to block_copy_state_new() Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 02/16] block/dirty-bitmap: bdrv_merge_dirty_bitmap(): add return value Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 03/16] block/block-copy: block_copy_state_new(): add bitmap parameter Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 04/16] block/copy-before-write: add bitmap open parameter Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 05/16] block/block-copy: add block_copy_reset() Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 06/16] block: intoduce reqlist Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 07/16] block/reqlist: reqlist_find_conflict(): use ranges_overlap() Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 08/16] block/dirty-bitmap: introduce bdrv_dirty_bitmap_status() Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 09/16] block/reqlist: add reqlist_wait_all() Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 10/16] block/io: introduce block driver snapshot-access API Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 11/16] block: introduce snapshot-access block driver Vladimir Sementsov-Ogievskiy
2022-03-03 11:05 ` Hanna Reitz
2022-03-03 11:11 ` Hanna Reitz
2022-03-03 17:26 ` Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 12/16] block: copy-before-write: realize snapshot-access API Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 13/16] iotests/image-fleecing: add test-case for fleecing format node Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 14/16] iotests.py: add qemu_io_pipe_and_status() Vladimir Sementsov-Ogievskiy
2022-02-28 11:39 ` [PATCH v5 15/16] iotests/image-fleecing: add test case with bitmap Vladimir Sementsov-Ogievskiy
2022-03-03 11:44 ` Hanna Reitz
2022-03-03 12:57 ` Hanna Reitz
2022-02-28 11:39 ` [PATCH v5 16/16] iotests/image-fleecing: test push backup with fleecing Vladimir Sementsov-Ogievskiy
2022-03-03 10:58 ` Hanna Reitz [this message]
2022-03-03 17:35 ` Vladimir Sementsov-Ogievskiy
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1cb8456c-60c9-3a25-50c2-10b00a77ae5f@redhat.com \
--to=hreitz@redhat.com \
--cc=armbru@redhat.com \
--cc=eblake@redhat.com \
--cc=fam@euphon.net \
--cc=jsnow@redhat.com \
--cc=kwolf@redhat.com \
--cc=nikita.lapshin@virtuozzo.com \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@redhat.com \
--cc=vsementsov@virtuozzo.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).