blob: 1f48339692d244af9d9e803161c224140757bb1a [file] [log] [blame]
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +01001#!/bin/bash
2#
3# Test qcow2 lazy refcounts
4#
5# Copyright (C) 2012 Red Hat, Inc.
6# Copyright IBM, Corp. 2010
7#
8# Based on test 038.
9#
10# This program is free software; you can redistribute it and/or modify
11# it under the terms of the GNU General Public License as published by
12# the Free Software Foundation; either version 2 of the License, or
13# (at your option) any later version.
14#
15# This program is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18# GNU General Public License for more details.
19#
20# You should have received a copy of the GNU General Public License
21# along with this program. If not, see <http://www.gnu.org/licenses/>.
22#
23
24# creator
25owner=stefanha@linux.vnet.ibm.com
26
27seq=`basename $0`
28echo "QA output created by $seq"
29
30here=`pwd`
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010031status=1 # failure is the default!
32
33_cleanup()
34{
35 _cleanup_test_img
36}
37trap "_cleanup; exit \$status" 0 1 2 3 15
38
39# get standard environment, filters and checks
40. ./common.rc
41. ./common.filter
42
43_supported_fmt qcow2
Peter Lieven1f7bf7d2014-02-03 10:26:14 +010044_supported_proto file
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010045_supported_os Linux
Fam Zhengf210a832013-12-04 09:07:00 +080046_default_cache_mode "writethrough"
47_supported_cache_modes "writethrough"
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010048
49size=128M
50
51echo
52echo "== Checking that image is clean on shutdown =="
53
54IMGOPTS="compat=1.1,lazy_refcounts=on"
55_make_test_img $size
56
Jeff Codyf897e392013-10-31 11:57:40 -040057$QEMU_IO -c "write -P 0x5a 0 512" "$TEST_IMG" | _filter_qemu_io
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010058
59# The dirty bit must not be set
Max Reitzea81ca92014-05-24 23:24:58 +020060$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010061_check_test_img
62
63echo
64echo "== Creating a dirty image file =="
65
66IMGOPTS="compat=1.1,lazy_refcounts=on"
67_make_test_img $size
68
Max Reitz934659c2015-09-02 20:52:27 +020069$QEMU_IO -c "write -P 0x5a 0 512" \
70 -c "sigraise $(kill -l KILL)" "$TEST_IMG" 2>&1 \
Max Reitz3f394472014-12-08 10:48:12 +010071 | _filter_qemu_io
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010072
73# The dirty bit must be set
Max Reitzea81ca92014-05-24 23:24:58 +020074$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010075_check_test_img
76
77echo
78echo "== Read-only access must still work =="
79
Jeff Codyfef9c192013-09-25 08:12:22 -040080$QEMU_IO -r -c "read -P 0x5a 0 512" "$TEST_IMG" | _filter_qemu_io
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010081
82# The dirty bit must be set
Max Reitzea81ca92014-05-24 23:24:58 +020083$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010084
85echo
86echo "== Repairing the image file must succeed =="
87
Federico Simoncellic6bb9ad2013-01-28 06:59:46 -050088_check_test_img -r all
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010089
90# The dirty bit must not be set
Max Reitzea81ca92014-05-24 23:24:58 +020091$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010092
93echo
94echo "== Data should still be accessible after repair =="
95
Jeff Codyfef9c192013-09-25 08:12:22 -040096$QEMU_IO -c "read -P 0x5a 0 512" "$TEST_IMG" | _filter_qemu_io
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +010097
98echo
99echo "== Opening a dirty image read/write should repair it =="
100
101IMGOPTS="compat=1.1,lazy_refcounts=on"
102_make_test_img $size
103
Max Reitz934659c2015-09-02 20:52:27 +0200104$QEMU_IO -c "write -P 0x5a 0 512" \
105 -c "sigraise $(kill -l KILL)" "$TEST_IMG" 2>&1 \
Max Reitz3f394472014-12-08 10:48:12 +0100106 | _filter_qemu_io
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +0100107
108# The dirty bit must be set
Max Reitzea81ca92014-05-24 23:24:58 +0200109$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +0100110
Jeff Codyfef9c192013-09-25 08:12:22 -0400111$QEMU_IO -c "write 0 512" "$TEST_IMG" | _filter_qemu_io
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +0100112
113# The dirty bit must not be set
Max Reitzea81ca92014-05-24 23:24:58 +0200114$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +0100115
116echo
117echo "== Creating an image file with lazy_refcounts=off =="
118
119IMGOPTS="compat=1.1,lazy_refcounts=off"
120_make_test_img $size
121
Max Reitz934659c2015-09-02 20:52:27 +0200122$QEMU_IO -c "write -P 0x5a 0 512" \
123 -c "sigraise $(kill -l KILL)" "$TEST_IMG" 2>&1 \
Max Reitz3f394472014-12-08 10:48:12 +0100124 | _filter_qemu_io
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +0100125
126# The dirty bit must not be set since lazy_refcounts=off
Max Reitzea81ca92014-05-24 23:24:58 +0200127$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +0100128_check_test_img
129
Kevin Wolf4c2e5f82014-04-03 13:47:50 +0200130echo
131echo "== Committing to a backing file with lazy_refcounts=on =="
132
133IMGOPTS="compat=1.1,lazy_refcounts=on"
134TEST_IMG="$TEST_IMG".base _make_test_img $size
135
136IMGOPTS="compat=1.1,lazy_refcounts=on,backing_file=$TEST_IMG.base"
137_make_test_img $size
138
139$QEMU_IO -c "write 0 512" "$TEST_IMG" | _filter_qemu_io
140$QEMU_IMG commit "$TEST_IMG"
141
142# The dirty bit must not be set
Max Reitzea81ca92014-05-24 23:24:58 +0200143$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
144$PYTHON qcow2.py "$TEST_IMG".base dump-header | grep incompatible_features
Kevin Wolf4c2e5f82014-04-03 13:47:50 +0200145
146_check_test_img
147TEST_IMG="$TEST_IMG".base _check_test_img
148
Kevin Wolfe6150532015-09-04 18:26:09 +0200149echo
150echo "== Changing lazy_refcounts setting at runtime =="
151
152IMGOPTS="compat=1.1,lazy_refcounts=off"
153_make_test_img $size
154
155$QEMU_IO -c "reopen -o lazy-refcounts=on" \
156 -c "write -P 0x5a 0 512" \
157 -c "sigraise $(kill -l KILL)" "$TEST_IMG" 2>&1 \
158 | _filter_qemu_io
159
160# The dirty bit must be set
161$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
162_check_test_img
163
164IMGOPTS="compat=1.1,lazy_refcounts=on"
165_make_test_img $size
166
167$QEMU_IO -c "reopen -o lazy-refcounts=off" \
168 -c "write -P 0x5a 0 512" \
169 -c "sigraise $(kill -l KILL)" "$TEST_IMG" 2>&1 \
170 | _filter_qemu_io
171
172# The dirty bit must not be set
173$PYTHON qcow2.py "$TEST_IMG" dump-header | grep incompatible_features
174_check_test_img
175
Kevin Wolf4c2e5f82014-04-03 13:47:50 +0200176
Stefan Hajnoczidc68afe2012-07-27 09:05:24 +0100177# success, all done
178echo "*** done"
179rm -f $seq.full
180status=0
181