vhdx: Simplify vhdx_set_shift_bits()
[qemu.git] / tests / qemu-iotests / 023
blob9ad06b990e2ca7c4f12ba3d4251aee47b3a4706f
1 #!/bin/bash
3 # qcow2 pattern test with various cluster sizes
5 # Copyright (C) 2009 Red Hat, Inc.
7 # This program is free software; you can redistribute it and/or modify
8 # it under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 2 of the License, or
10 # (at your option) any later version.
12 # This program is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with this program. If not, see <http://www.gnu.org/licenses/>.
21 # creator
22 owner=kwolf@redhat.com
24 seq=`basename $0`
25 echo "QA output created by $seq"
27 here=`pwd`
28 tmp=/tmp/$$
29 status=1 # failure is the default!
31 _cleanup()
33 _cleanup_test_img
35 trap "_cleanup; exit \$status" 0 1 2 3 15
37 # get standard environment, filters and checks
38 . ./common.rc
39 . ./common.filter
40 . ./common.pattern
42 # much of this could be generic for any format supporting compression.
43 _supported_fmt qcow qcow2
44 _supported_proto file
45 _supported_os Linux
47 TEST_OFFSETS="0 4294967296"
48 TEST_OPS="writev read write readv"
50 # Can't use 512 byte clusters, the tests use cluster halves
51 CLUSTER_SIZES="1024 4096 16384 65536"
53 for CLUSTER_SIZE in $CLUSTER_SIZES; do
55 echo "Creating new image; cluster size: $CLUSTER_SIZE"
56 echo
58 _make_test_img 8G
60 echo "Testing empty image"
61 echo
63 for offset in $TEST_OFFSETS; do
64 echo "At offset $offset:"
65 for op in $TEST_OPS; do
66 io_test $op $offset $CLUSTER_SIZE 3
67 done
68 _check_test_img
69 done
71 echo "Compressing image"
72 echo
74 mv "$TEST_IMG" "$TEST_IMG.orig"
75 $QEMU_IMG convert -f $IMGFMT -O $IMGFMT -c "$TEST_IMG.orig" "$TEST_IMG"
77 echo "Testing compressed image"
78 echo
80 for offset in $TEST_OFFSETS; do
81 echo "With offset $offset:"
82 for op in read readv; do
83 io_test $op $offset $CLUSTER_SIZE 3
84 done
85 _check_test_img
86 done
88 echo "Testing compressed image with odd offsets"
89 echo
90 for offset in $TEST_OFFSETS; do
91 # Some odd offset (1 sector), so tests will write to areas occupied partly
92 # by old (compressed) data and empty clusters
93 offset=$((offset + 512))
94 echo "With offset $offset:"
95 for op in $TEST_OPS; do
96 io_test $op $offset $CLUSTER_SIZE 3
97 done
98 _check_test_img
99 done
101 echo "Creating another new image"
102 echo
104 _make_test_img 8G
106 echo "More complex patterns"
107 echo
109 for offset in $TEST_OFFSETS; do
110 echo test2: With offset $offset
111 io_test2 $offset $CLUSTER_SIZE 4
112 _check_test_img
113 done
115 done
117 # success, all done
118 echo "*** done"
119 rm -f $seq.full
120 status=0