xref: /qemu/tests/qemu-iotests/182 (revision 09a274d8)
1#!/bin/bash
2#
3# Test image locking for POSIX locks
4#
5# Copyright 2017 Red Hat, Inc.
6#
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.
11#
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.
16#
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/>.
19#
20
21# creator
22owner=famz@redhat.com
23
24seq="$(basename $0)"
25echo "QA output created by $seq"
26
27tmp=/tmp/$$
28status=1	# failure is the default!
29
30_cleanup()
31{
32    _cleanup_test_img
33    rm -f "$TEST_IMG.overlay"
34}
35trap "_cleanup; exit \$status" 0 1 2 3 15
36
37# get standard environment, filters and checks
38. ./common.rc
39. ./common.filter
40. ./common.qemu
41
42_supported_fmt qcow2
43_supported_proto file
44_supported_os Linux
45
46size=32M
47
48case "$QEMU_DEFAULT_MACHINE" in
49  s390-ccw-virtio)
50      virtioblk=virtio-blk-ccw
51      ;;
52  *)
53      virtioblk=virtio-blk-pci
54      ;;
55esac
56
57_make_test_img $size
58
59echo "Starting QEMU"
60_launch_qemu -drive file=$TEST_IMG,if=none,id=drive0,file.locking=on \
61    -device $virtioblk,drive=drive0
62
63echo
64echo "Starting a second QEMU using the same image should fail"
65echo 'quit' | $QEMU -nographic -monitor stdio \
66    -drive file=$TEST_IMG,if=none,id=drive0,file.locking=on \
67    -device $virtioblk,drive=drive0 2>&1 | _filter_testdir 2>&1 |
68    _filter_qemu |
69    sed -e '/falling back to POSIX file/d' \
70        -e '/locks can be lost unexpectedly/d'
71
72_cleanup_qemu
73
74echo
75echo '=== Testing reopen ==='
76echo
77
78# This tests that reopening does not unshare any permissions it should
79# not unshare
80# (There was a bug where reopening shared exactly the opposite of the
81# permissions it was supposed to share)
82
83_launch_qemu
84
85_send_qemu_cmd $QEMU_HANDLE \
86    "{'execute': 'qmp_capabilities'}" \
87    'return'
88
89# Open the image without any format layer (we are not going to access
90# it, so that is fine)
91# This should keep all permissions shared.
92success_or_failure=y _send_qemu_cmd $QEMU_HANDLE \
93    "{'execute': 'blockdev-add',
94      'arguments': {
95          'node-name': 'node0',
96          'driver': 'file',
97          'filename': '$TEST_IMG',
98          'locking': 'on'
99          } }" \
100    'return' \
101    'error'
102
103# This snapshot will perform a reopen to drop R/W to RO.
104# It should still keep all permissions shared.
105success_or_failure=y _send_qemu_cmd $QEMU_HANDLE \
106    "{'execute': 'blockdev-snapshot-sync',
107      'arguments': {
108          'node-name': 'node0',
109          'snapshot-file': '$TEST_IMG.overlay',
110          'snapshot-node-name': 'node1'
111      } }" \
112    'return' \
113    'error'
114
115# Now open the same file again
116# This does not require any permissions (and does not unshare any), so
117# this will not conflict with node0.
118success_or_failure=y _send_qemu_cmd $QEMU_HANDLE \
119    "{'execute': 'blockdev-add',
120      'arguments': {
121          'node-name': 'node1',
122          'driver': 'file',
123          'filename': '$TEST_IMG',
124          'locking': 'on'
125          } }" \
126    'return' \
127    'error'
128
129# Now we attach the image to a virtio-blk device.  This device does
130# require some permissions (at least WRITE and READ_CONSISTENT), so if
131# reopening node0 unshared any (which it should not have), this will
132# fail (but it should not).
133success_or_failure=y _send_qemu_cmd $QEMU_HANDLE \
134    "{'execute': 'device_add',
135      'arguments': {
136          'driver': 'virtio-blk',
137          'drive': 'node1'
138      } }" \
139    'return' \
140    'error'
141
142_cleanup_qemu
143
144# success, all done
145echo "*** done"
146rm -f $seq.full
147status=0
148