5435e8a804
Backport patches related with iotest from upstream * Patches added: block-backend-Retain-permissions-after-m.patch iotest-065-explicit-compression-type.patch iotest-214-explicit-compression-type.patch iotest-302-use-img_info_log-helper.patch iotest-303-explicit-compression-type.patch iotest-39-use-_qcow2_dump_header.patch iotests-60-more-accurate-set-dirty-bit-i.patch iotests-bash-tests-filter-compression-ty.patch iotests-common.rc-introduce-_qcow2_dump_.patch iotests-declare-lack-of-support-for-comp.patch iotests-drop-qemu_img_verbose-helper.patch iotests-massive-use-_qcow2_dump_header.patch iotests-MRCE-Write-data-to-source.patch iotests.py-filter-out-successful-output-.patch iotests.py-img_info_log-rename-imgopts-a.patch iotests.py-implement-unsupported_imgopts.patch iotests.py-qemu_img-create-support-IMGOP.patch iotests.py-rewrite-default-luks-support-.patch iotests-specify-some-unsupported_imgopts.patch qcow2-simple-case-support-for-downgradin.patch tests-qemu-iotests-Fix-051-for-binaries-.patch OBS-URL: https://build.opensuse.org/request/show/955876 OBS-URL: https://build.opensuse.org/package/show/Virtualization/qemu?expand=0&rev=690
92 lines
3.3 KiB
Diff
92 lines
3.3 KiB
Diff
From: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
|
|
Date: Thu, 23 Dec 2021 17:01:29 +0100
|
|
Subject: iotests.py: qemu_img*("create"): support
|
|
IMGOPTS='compression_type=zstd'
|
|
|
|
Git-commit: 22e29bcea12ccf0e127b91917d959c69bebbd952
|
|
|
|
Adding support of IMGOPTS (like in bash tests) allows user to pass a
|
|
lot of different options. Still, some may require additional logic.
|
|
|
|
Now we want compression_type option, so add some smart logic around it:
|
|
ignore compression_type=zstd in IMGOPTS, if test want qcow2 in
|
|
compatibility mode. As well, ignore compression_type for non-qcow2
|
|
formats.
|
|
|
|
Note that we may instead add support only to qemu_img_create(), but
|
|
that works bad:
|
|
|
|
1. We'll have to update a lot of tests to use qemu_img_create instead
|
|
of qemu_img('create'). (still, we may want do it anyway, but no
|
|
reason to create a dependancy between task of supporting IMGOPTS and
|
|
updating a lot of tests)
|
|
|
|
2. Some tests use qemu_img_pipe('create', ..) - even more work on
|
|
updating
|
|
|
|
3. Even if we update all tests to go through qemu_img_create, we'll
|
|
need a way to avoid creating new tests using qemu_img*('create') -
|
|
add assertions.. That doesn't seem good.
|
|
|
|
So, let's add support of IMGOPTS to most generic
|
|
qemu_img_pipe_and_status().
|
|
|
|
Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
|
|
Reviewed-by: Hanna Reitz <hreitz@redhat.com>
|
|
Message-Id: <20211223160144.1097696-5-vsementsov@virtuozzo.com>
|
|
Signed-off-by: Hanna Reitz <hreitz@redhat.com>
|
|
Signed-off-by: Li Zhang <lizhang@suse.de>
|
|
---
|
|
tests/qemu-iotests/iotests.py | 27 ++++++++++++++++++++++++++-
|
|
1 file changed, 26 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/tests/qemu-iotests/iotests.py b/tests/qemu-iotests/iotests.py
|
|
index 35d92715ccf4defe721a38982788..f0370b520651aa4ccc1cdb0cf28e 100644
|
|
--- a/tests/qemu-iotests/iotests.py
|
|
+++ b/tests/qemu-iotests/iotests.py
|
|
@@ -16,6 +16,7 @@
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
+import argparse
|
|
import atexit
|
|
import bz2
|
|
from collections import OrderedDict
|
|
@@ -153,11 +154,35 @@ def qemu_tool_pipe_and_status(tool: str, args: Sequence[str],
|
|
{-subp.returncode}: {cmd}\n')
|
|
return (output, subp.returncode)
|
|
|
|
+def qemu_img_create_prepare_args(args: List[str]) -> List[str]:
|
|
+ if not args or args[0] != 'create':
|
|
+ return list(args)
|
|
+ args = args[1:]
|
|
+
|
|
+ p = argparse.ArgumentParser(allow_abbrev=False)
|
|
+ p.add_argument('-f')
|
|
+ parsed, remaining = p.parse_known_args(args)
|
|
+
|
|
+ result = ['create']
|
|
+ if parsed.f is not None:
|
|
+ result += ['-f', parsed.f]
|
|
+
|
|
+ # IMGOPTS most probably contain options specific for the selected format,
|
|
+ # like extended_l2 or compression_type for qcow2. Test may want to create
|
|
+ # additional images in other formats that doesn't support these options.
|
|
+ # So, use IMGOPTS only for images created in imgfmt format.
|
|
+ if parsed.f == imgfmt and 'IMGOPTS' in os.environ:
|
|
+ result += ['-o', os.environ['IMGOPTS']]
|
|
+
|
|
+ result += remaining
|
|
+
|
|
+ return result
|
|
+
|
|
def qemu_img_pipe_and_status(*args: str) -> Tuple[str, int]:
|
|
"""
|
|
Run qemu-img and return both its output and its exit code
|
|
"""
|
|
- full_args = qemu_img_args + list(args)
|
|
+ full_args = qemu_img_args + qemu_img_create_prepare_args(list(args))
|
|
return qemu_tool_pipe_and_status('qemu-img', full_args)
|
|
|
|
def qemu_img(*args: str) -> int:
|