Signed-off-by: Maxim Levitsky <mlevitsk@redhat.com>
---
tests/qemu-iotests/263 | 91 ++++++++++++++++++++++++++++++++++++++
tests/qemu-iotests/263.out | 40 +++++++++++++++++
tests/qemu-iotests/group | 2 +
3 files changed, 133 insertions(+)
create mode 100755 tests/qemu-iotests/263
create mode 100644 tests/qemu-iotests/263.out
diff --git a/tests/qemu-iotests/263 b/tests/qemu-iotests/263
new file mode 100755
index 0000000000..d2c030fae9
--- /dev/null
+++ b/tests/qemu-iotests/263
@@ -0,0 +1,91 @@
+#!/usr/bin/env bash
+#
+# Test encrypted write that crosses cluster boundary of two unallocated clusters
+# Based on 188
+#
+# Copyright (C) 2019 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/>.
+#
+
+# creator
+owner=mlevitsk@redhat.com
+
+seq=`basename $0`
+echo "QA output created by $seq"
+
+status=1 # failure is the default!
+
+_cleanup()
+{
+ _cleanup_test_img
+}
+trap "_cleanup; exit \$status" 0 1 2 3 15
+
+# get standard environment, filters and checks
+. ./common.rc
+. ./common.filter
+
+_supported_fmt qcow2
+_supported_proto generic
+_supported_os Linux
+
+
+size=1M
+
+SECRET="secret,id=sec0,data=astrochicken"
+QEMU_IO_OPTIONS=$QEMU_IO_OPTIONS_NO_FMT
+
+
+_run_test()
+{
+ echo "== reading the whole image =="
+ $QEMU_IO --object $SECRET -c "read -P 0 0 $size" --image-opts "$1" | _filter_qemu_io | _filter_testdir
+
+ echo
+ echo "== write two 512 byte sectors on a cluster boundary =="
+ $QEMU_IO --object $SECRET -c "write -P 0xAA 0xFE00 0x400" --image-opts "$1" | _filter_qemu_io | _filter_testdir
+
+ echo
+ echo "== verify that the rest of the image is not changed =="
+ $QEMU_IO --object $SECRET -c "read -P 0x00 0x00000 0xFE00" --image-opts "$1" | _filter_qemu_io | _filter_testdir
+ $QEMU_IO --object $SECRET -c "read -P 0xAA 0x0FE00 0x400" --image-opts "$1" | _filter_qemu_io | _filter_testdir
+ $QEMU_IO --object $SECRET -c "read -P 0x00 0x10200 0xEFE00" --image-opts "$1" | _filter_qemu_io | _filter_testdir
+
+}
+
+
+echo
+echo "testing LUKS qcow2 encryption"
+echo
+
+_make_test_img --object $SECRET -o "encrypt.format=luks,encrypt.key-secret=sec0,encrypt.iter-time=10,cluster_size=64K" $size
+_run_test "driver=$IMGFMT,encrypt.key-secret=sec0,file.filename=$TEST_IMG"
+_cleanup_test_img
+
+echo
+echo "testing legacy AES qcow2 encryption"
+echo
+
+
+_make_test_img --object $SECRET -o "encrypt.format=aes,encrypt.key-secret=sec0,cluster_size=64K" $size
+_run_test "driver=$IMGFMT,encrypt.key-secret=sec0,file.filename=$TEST_IMG"
+_cleanup_test_img
+
+
+
+# success, all done
+echo "*** done"
+rm -f $seq.full
+status=0
diff --git a/tests/qemu-iotests/263.out b/tests/qemu-iotests/263.out
new file mode 100644
index 0000000000..0c982c55cb
--- /dev/null
+++ b/tests/qemu-iotests/263.out
@@ -0,0 +1,40 @@
+QA output created by 263
+
+testing LUKS qcow2 encryption
+
+Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=1048576 encrypt.format=luks encrypt.key-secret=sec0 encrypt.iter-time=10
+== reading the whole image ==
+read 1048576/1048576 bytes at offset 0
+1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+
+== write two 512 byte sectors on a cluster boundary ==
+wrote 1024/1024 bytes at offset 65024
+1 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+
+== verify that the rest of the image is not changed ==
+read 65024/65024 bytes at offset 0
+63.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+read 1024/1024 bytes at offset 65024
+1 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+read 982528/982528 bytes at offset 66048
+959.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+
+testing legacy AES qcow2 encryption
+
+Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=1048576 encrypt.format=aes encrypt.key-secret=sec0
+== reading the whole image ==
+read 1048576/1048576 bytes at offset 0
+1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+
+== write two 512 byte sectors on a cluster boundary ==
+wrote 1024/1024 bytes at offset 65024
+1 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+
+== verify that the rest of the image is not changed ==
+read 65024/65024 bytes at offset 0
+63.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+read 1024/1024 bytes at offset 65024
+1 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+read 982528/982528 bytes at offset 66048
+959.500 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+*** done
diff --git a/tests/qemu-iotests/group b/tests/qemu-iotests/group
index 6082c74806..8d58729ee1 100644
--- a/tests/qemu-iotests/group
+++ b/tests/qemu-iotests/group
@@ -274,5 +274,7 @@
257 rw
258 rw quick
262 rw quick migration
+263 rw quick
265 rw auto quick
266 rw quick
+>>>>>>> patched
--
2.17.2
13.09.2019 18:28, Maxim Levitsky wrote: > Signed-off-by: Maxim Levitsky <mlevitsk@redhat.com> > --- > tests/qemu-iotests/263 | 91 ++++++++++++++++++++++++++++++++++++++ > tests/qemu-iotests/263.out | 40 +++++++++++++++++ > tests/qemu-iotests/group | 2 + > 3 files changed, 133 insertions(+) > create mode 100755 tests/qemu-iotests/263 > create mode 100644 tests/qemu-iotests/263.out > > diff --git a/tests/qemu-iotests/263 b/tests/qemu-iotests/263 > new file mode 100755 > index 0000000000..d2c030fae9 > --- /dev/null > +++ b/tests/qemu-iotests/263 [..] > --- a/tests/qemu-iotests/group > +++ b/tests/qemu-iotests/group > @@ -274,5 +274,7 @@ > 257 rw > 258 rw quick > 262 rw quick migration > +263 rw quick > 265 rw auto quick > 266 rw quick > +>>>>>>> patched > last line is a mistake. also, test failed for me: 263 fail [19:21:35] [19:21:35] output mismatch (see 263.out.bad) --- /work/src/qemu/maxim-luks/tests/qemu-iotests/263.out 2019-09-13 19:11:45.464727427 +0300 +++ /work/src/qemu/maxim-luks/tests/qemu-iotests/263.out.bad 2019-09-13 19:21:35.535381253 +0300 @@ -2,6 +2,7 @@ testing LUKS qcow2 encryption +qemu-img: TEST_DIR/t.IMGFMT: No crypto library supporting PBKDF in this build: Function not implemented Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=1048576 encrypt.format=luks encrypt.key-secret=sec0 encrypt.iter-time=10 == reading the whole image == read 1048576/1048576 bytes at offset 0 Failures: 263 Failed 1 of 1 tests and if reconfigure with --enable-gnutls --enable-gcrypt --enable-vhost-crypto --enable-crypto-afalg (don't know which one is actually needed) it works.. so, we at least should skip the test if it's unsupported -- Best regards, Vladimir
On Fri, 2019-09-13 at 16:27 +0000, Vladimir Sementsov-Ogievskiy wrote: > 13.09.2019 18:28, Maxim Levitsky wrote: > > Signed-off-by: Maxim Levitsky <mlevitsk@redhat.com> > > --- > > tests/qemu-iotests/263 | 91 ++++++++++++++++++++++++++++++++++++++ > > tests/qemu-iotests/263.out | 40 +++++++++++++++++ > > tests/qemu-iotests/group | 2 + > > 3 files changed, 133 insertions(+) > > create mode 100755 tests/qemu-iotests/263 > > create mode 100644 tests/qemu-iotests/263.out > > > > diff --git a/tests/qemu-iotests/263 b/tests/qemu-iotests/263 > > new file mode 100755 > > index 0000000000..d2c030fae9 > > --- /dev/null > > +++ b/tests/qemu-iotests/263 > > [..] > > > --- a/tests/qemu-iotests/group > > +++ b/tests/qemu-iotests/group > > @@ -274,5 +274,7 @@ > > 257 rw > > 258 rw quick > > 262 rw quick migration > > +263 rw quick > > 265 rw auto quick > > 266 rw quick > > +>>>>>>> patched > > > > last line is a mistake. Last minute merge mistake :-( > > also, test failed for me: > > 263 fail [19:21:35] [19:21:35] output mismatch (see 263.out.bad) > --- /work/src/qemu/maxim-luks/tests/qemu-iotests/263.out 2019-09-13 19:11:45.464727427 +0300 > +++ /work/src/qemu/maxim-luks/tests/qemu-iotests/263.out.bad 2019-09-13 19:21:35.535381253 +0300 > @@ -2,6 +2,7 @@ > > testing LUKS qcow2 encryption > > +qemu-img: TEST_DIR/t.IMGFMT: No crypto library supporting PBKDF in this build: Function not implemented > Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=1048576 encrypt.format=luks encrypt.key-secret=sec0 encrypt.iter-time=10 > == reading the whole image == > read 1048576/1048576 bytes at offset 0 > Failures: 263 > Failed 1 of 1 tests > > > and if reconfigure with > --enable-gnutls --enable-gcrypt --enable-vhost-crypto --enable-crypto-afalg > (don't know which one is actually needed) > it works.. > > so, we at least should skip the test if it's unsupported Don't know. I based this test on 188 and it also doesn't have anything special about this. Its not in auto group though. I guess we need to ask Daniel about this. Best regards, Maxim Levitsky
13.09.2019 19:39, Maxim Levitsky wrote: > On Fri, 2019-09-13 at 16:27 +0000, Vladimir Sementsov-Ogievskiy wrote: >> 13.09.2019 18:28, Maxim Levitsky wrote: >>> Signed-off-by: Maxim Levitsky <mlevitsk@redhat.com> >>> --- >>> tests/qemu-iotests/263 | 91 ++++++++++++++++++++++++++++++++++++++ >>> tests/qemu-iotests/263.out | 40 +++++++++++++++++ >>> tests/qemu-iotests/group | 2 + >>> 3 files changed, 133 insertions(+) >>> create mode 100755 tests/qemu-iotests/263 >>> create mode 100644 tests/qemu-iotests/263.out >>> >>> diff --git a/tests/qemu-iotests/263 b/tests/qemu-iotests/263 >>> new file mode 100755 >>> index 0000000000..d2c030fae9 >>> --- /dev/null >>> +++ b/tests/qemu-iotests/263 >> >> [..] >> >>> --- a/tests/qemu-iotests/group >>> +++ b/tests/qemu-iotests/group >>> @@ -274,5 +274,7 @@ >>> 257 rw >>> 258 rw quick >>> 262 rw quick migration >>> +263 rw quick >>> 265 rw auto quick >>> 266 rw quick >>> +>>>>>>> patched >>> >> >> last line is a mistake. > Last minute merge mistake :-( > >> >> also, test failed for me: >> >> 263 fail [19:21:35] [19:21:35] output mismatch (see 263.out.bad) >> --- /work/src/qemu/maxim-luks/tests/qemu-iotests/263.out 2019-09-13 19:11:45.464727427 +0300 >> +++ /work/src/qemu/maxim-luks/tests/qemu-iotests/263.out.bad 2019-09-13 19:21:35.535381253 +0300 >> @@ -2,6 +2,7 @@ >> >> testing LUKS qcow2 encryption >> >> +qemu-img: TEST_DIR/t.IMGFMT: No crypto library supporting PBKDF in this build: Function not implemented >> Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=1048576 encrypt.format=luks encrypt.key-secret=sec0 encrypt.iter-time=10 >> == reading the whole image == >> read 1048576/1048576 bytes at offset 0 >> Failures: 263 >> Failed 1 of 1 tests >> >> >> and if reconfigure with >> --enable-gnutls --enable-gcrypt --enable-vhost-crypto --enable-crypto-afalg >> (don't know which one is actually needed) >> it works.. >> >> so, we at least should skip the test if it's unsupported > Don't know. I based this test on 188 and it also doesn't have anything special about this. > Its not in auto group though. > I guess we need to ask Daniel about this. > > Hmm, the problem was not in "configure" arguments, seems needed thing is enabled by default, but actually all works for me after installing gnutls-devel and without it 188 don't work without it (or some its dependencies) too. So it's "not a regression" and I'dont care: Tested-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> [don't forget to drop ">>>>>>> patched"] and I also checked that test fails if position it before patch 01, so it's true bug-catcher. -- Best regards, Vladimir
On Fri, 2019-09-13 at 16:57 +0000, Vladimir Sementsov-Ogievskiy wrote: > 13.09.2019 19:39, Maxim Levitsky wrote: > > On Fri, 2019-09-13 at 16:27 +0000, Vladimir Sementsov-Ogievskiy wrote: > > > 13.09.2019 18:28, Maxim Levitsky wrote: > > > > Signed-off-by: Maxim Levitsky <mlevitsk@redhat.com> > > > > --- > > > > tests/qemu-iotests/263 | 91 ++++++++++++++++++++++++++++++++++++++ > > > > tests/qemu-iotests/263.out | 40 +++++++++++++++++ > > > > tests/qemu-iotests/group | 2 + > > > > 3 files changed, 133 insertions(+) > > > > create mode 100755 tests/qemu-iotests/263 > > > > create mode 100644 tests/qemu-iotests/263.out > > > > > > > > diff --git a/tests/qemu-iotests/263 b/tests/qemu-iotests/263 > > > > new file mode 100755 > > > > index 0000000000..d2c030fae9 > > > > --- /dev/null > > > > +++ b/tests/qemu-iotests/263 > > > > > > [..] > > > > > > > --- a/tests/qemu-iotests/group > > > > +++ b/tests/qemu-iotests/group > > > > @@ -274,5 +274,7 @@ > > > > 257 rw > > > > 258 rw quick > > > > 262 rw quick migration > > > > +263 rw quick > > > > 265 rw auto quick > > > > 266 rw quick > > > > +>>>>>>> patched > > > > > > > > > > last line is a mistake. > > > > Last minute merge mistake :-( > > > > > > > > also, test failed for me: > > > > > > 263 fail [19:21:35] [19:21:35] output mismatch (see 263.out.bad) > > > --- /work/src/qemu/maxim-luks/tests/qemu-iotests/263.out 2019-09-13 19:11:45.464727427 +0300 > > > +++ /work/src/qemu/maxim-luks/tests/qemu-iotests/263.out.bad 2019-09-13 19:21:35.535381253 +0300 > > > @@ -2,6 +2,7 @@ > > > > > > testing LUKS qcow2 encryption > > > > > > +qemu-img: TEST_DIR/t.IMGFMT: No crypto library supporting PBKDF in this build: Function not implemented > > > Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=1048576 encrypt.format=luks encrypt.key-secret=sec0 encrypt.iter-time=10 > > > == reading the whole image == > > > read 1048576/1048576 bytes at offset 0 > > > Failures: 263 > > > Failed 1 of 1 tests > > > > > > > > > and if reconfigure with > > > --enable-gnutls --enable-gcrypt --enable-vhost-crypto --enable-crypto-afalg > > > (don't know which one is actually needed) > > > it works.. > > > > > > so, we at least should skip the test if it's unsupported > > > > Don't know. I based this test on 188 and it also doesn't have anything special about this. > > Its not in auto group though. > > I guess we need to ask Daniel about this. > > > > > > Hmm, the problem was not in "configure" arguments, seems needed thing is enabled by default, but actually > all works for me after installing gnutls-devel > > and without it 188 don't work without it (or some its dependencies) too. So it's "not a regression" > and I'dont care: > > Tested-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> > [don't forget to drop ">>>>>>> patched"] > > and I also checked that test fails if position it before patch 01, so it's true bug-catcher. Thanks!! Best regards, Maxim Levitsky
© 2016 - 2025 Red Hat, Inc.