Message ID | 20190913152818.17843-4-mlevitsk@redhat.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | Fix qcow2+luks corruption introduced by commit 8ac0f15f335 | expand |
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
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.
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
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
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