111a82d14SPhilippe Mathieu-Daudé#!/usr/bin/env bash 2*9dd003a9SVladimir Sementsov-Ogievskiy# group: rw quick 3de9efdb3SFam Zheng# 4de9efdb3SFam Zheng# Test image locking for POSIX locks 5de9efdb3SFam Zheng# 6de9efdb3SFam Zheng# Copyright 2017 Red Hat, Inc. 7de9efdb3SFam Zheng# 8de9efdb3SFam Zheng# This program is free software; you can redistribute it and/or modify 9de9efdb3SFam Zheng# it under the terms of the GNU General Public License as published by 10de9efdb3SFam Zheng# the Free Software Foundation; either version 2 of the License, or 11de9efdb3SFam Zheng# (at your option) any later version. 12de9efdb3SFam Zheng# 13de9efdb3SFam Zheng# This program is distributed in the hope that it will be useful, 14de9efdb3SFam Zheng# but WITHOUT ANY WARRANTY; without even the implied warranty of 15de9efdb3SFam Zheng# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16de9efdb3SFam Zheng# GNU General Public License for more details. 17de9efdb3SFam Zheng# 18de9efdb3SFam Zheng# You should have received a copy of the GNU General Public License 19de9efdb3SFam Zheng# along with this program. If not, see <http://www.gnu.org/licenses/>. 20de9efdb3SFam Zheng# 21de9efdb3SFam Zheng 22de9efdb3SFam Zheng# creator 23de9efdb3SFam Zhengowner=famz@redhat.com 24de9efdb3SFam Zheng 25de9efdb3SFam Zhengseq="$(basename $0)" 26de9efdb3SFam Zhengecho "QA output created by $seq" 27de9efdb3SFam Zheng 28de9efdb3SFam Zhengtmp=/tmp/$$ 29de9efdb3SFam Zhengstatus=1 # failure is the default! 30de9efdb3SFam Zheng 31de9efdb3SFam Zheng_cleanup() 32de9efdb3SFam Zheng{ 33de9efdb3SFam Zheng _cleanup_test_img 34f91ecbd7SMax Reitz _rm_test_img "$TEST_IMG.overlay" 35748f831bSMax Reitz rm -f "$SOCK_DIR/nbd.socket" 36de9efdb3SFam Zheng} 37de9efdb3SFam Zhengtrap "_cleanup; exit \$status" 0 1 2 3 15 38de9efdb3SFam Zheng 39de9efdb3SFam Zheng# get standard environment, filters and checks 40de9efdb3SFam Zheng. ./common.rc 41de9efdb3SFam Zheng. ./common.filter 42de9efdb3SFam Zheng. ./common.qemu 43de9efdb3SFam Zheng 44de9efdb3SFam Zheng_supported_fmt qcow2 45de9efdb3SFam Zheng_supported_proto file 46de9efdb3SFam Zheng 47de9efdb3SFam Zhengsize=32M 48de9efdb3SFam Zheng 49f1d5516aSCornelia Huckcase "$QEMU_DEFAULT_MACHINE" in 50f1d5516aSCornelia Huck s390-ccw-virtio) 51f1d5516aSCornelia Huck virtioblk=virtio-blk-ccw 52f1d5516aSCornelia Huck ;; 53f1d5516aSCornelia Huck *) 54f1d5516aSCornelia Huck virtioblk=virtio-blk-pci 55f1d5516aSCornelia Huck ;; 56f1d5516aSCornelia Huckesac 57f1d5516aSCornelia Huck 58de9efdb3SFam Zheng_make_test_img $size 59de9efdb3SFam Zheng 60de9efdb3SFam Zhengecho "Starting QEMU" 61de9efdb3SFam Zheng_launch_qemu -drive file=$TEST_IMG,if=none,id=drive0,file.locking=on \ 62f1d5516aSCornelia Huck -device $virtioblk,drive=drive0 63de9efdb3SFam Zheng 64de9efdb3SFam Zhengecho 65de9efdb3SFam Zhengecho "Starting a second QEMU using the same image should fail" 66c60f6fcfSKevin Wolfecho 'quit' | $QEMU -nographic -monitor stdio \ 67de9efdb3SFam Zheng -drive file=$TEST_IMG,if=none,id=drive0,file.locking=on \ 68f1d5516aSCornelia Huck -device $virtioblk,drive=drive0 2>&1 | _filter_testdir 2>&1 | 69de9efdb3SFam Zheng _filter_qemu | 70de9efdb3SFam Zheng sed -e '/falling back to POSIX file/d' \ 71de9efdb3SFam Zheng -e '/locks can be lost unexpectedly/d' 72de9efdb3SFam Zheng 73de9efdb3SFam Zheng_cleanup_qemu 74de9efdb3SFam Zheng 756d0a4a0fSMax Reitzecho 766d0a4a0fSMax Reitzecho '=== Testing reopen ===' 776d0a4a0fSMax Reitzecho 786d0a4a0fSMax Reitz 796d0a4a0fSMax Reitz# This tests that reopening does not unshare any permissions it should 806d0a4a0fSMax Reitz# not unshare 816d0a4a0fSMax Reitz# (There was a bug where reopening shared exactly the opposite of the 826d0a4a0fSMax Reitz# permissions it was supposed to share) 836d0a4a0fSMax Reitz 846d0a4a0fSMax Reitz_launch_qemu 856d0a4a0fSMax Reitz 866d0a4a0fSMax Reitz_send_qemu_cmd $QEMU_HANDLE \ 876d0a4a0fSMax Reitz "{'execute': 'qmp_capabilities'}" \ 886d0a4a0fSMax Reitz 'return' 896d0a4a0fSMax Reitz 906d0a4a0fSMax Reitz# Open the image without any format layer (we are not going to access 916d0a4a0fSMax Reitz# it, so that is fine) 926d0a4a0fSMax Reitz# This should keep all permissions shared. 936d0a4a0fSMax Reitzsuccess_or_failure=y _send_qemu_cmd $QEMU_HANDLE \ 946d0a4a0fSMax Reitz "{'execute': 'blockdev-add', 956d0a4a0fSMax Reitz 'arguments': { 966d0a4a0fSMax Reitz 'node-name': 'node0', 976d0a4a0fSMax Reitz 'driver': 'file', 986d0a4a0fSMax Reitz 'filename': '$TEST_IMG', 996d0a4a0fSMax Reitz 'locking': 'on' 1006d0a4a0fSMax Reitz } }" \ 1016d0a4a0fSMax Reitz 'return' \ 1026d0a4a0fSMax Reitz 'error' 1036d0a4a0fSMax Reitz 1046d0a4a0fSMax Reitz# This snapshot will perform a reopen to drop R/W to RO. 1056d0a4a0fSMax Reitz# It should still keep all permissions shared. 1066d0a4a0fSMax Reitzsuccess_or_failure=y _send_qemu_cmd $QEMU_HANDLE \ 1076d0a4a0fSMax Reitz "{'execute': 'blockdev-snapshot-sync', 1086d0a4a0fSMax Reitz 'arguments': { 1096d0a4a0fSMax Reitz 'node-name': 'node0', 1106d0a4a0fSMax Reitz 'snapshot-file': '$TEST_IMG.overlay', 1116d0a4a0fSMax Reitz 'snapshot-node-name': 'node1' 1126d0a4a0fSMax Reitz } }" \ 1136d0a4a0fSMax Reitz 'return' \ 1146d0a4a0fSMax Reitz 'error' 1156d0a4a0fSMax Reitz 1166d0a4a0fSMax Reitz# Now open the same file again 1176d0a4a0fSMax Reitz# This does not require any permissions (and does not unshare any), so 1186d0a4a0fSMax Reitz# this will not conflict with node0. 1196d0a4a0fSMax Reitzsuccess_or_failure=y _send_qemu_cmd $QEMU_HANDLE \ 1206d0a4a0fSMax Reitz "{'execute': 'blockdev-add', 1216d0a4a0fSMax Reitz 'arguments': { 1226d0a4a0fSMax Reitz 'node-name': 'node1', 1236d0a4a0fSMax Reitz 'driver': 'file', 1246d0a4a0fSMax Reitz 'filename': '$TEST_IMG', 1256d0a4a0fSMax Reitz 'locking': 'on' 1266d0a4a0fSMax Reitz } }" \ 1276d0a4a0fSMax Reitz 'return' \ 1286d0a4a0fSMax Reitz 'error' 1296d0a4a0fSMax Reitz 1308fabb8beSMax Reitz# Start an NBD server to which we can attach node1 1318fabb8beSMax Reitzsuccess_or_failure=y _send_qemu_cmd $QEMU_HANDLE \ 1328fabb8beSMax Reitz "{'execute': 'nbd-server-start', 1338fabb8beSMax Reitz 'arguments': { 1348fabb8beSMax Reitz 'addr': { 1358fabb8beSMax Reitz 'type': 'unix', 1368fabb8beSMax Reitz 'data': { 137748f831bSMax Reitz 'path': '$SOCK_DIR/nbd.socket' 1388fabb8beSMax Reitz } } } }" \ 1398fabb8beSMax Reitz 'return' \ 1408fabb8beSMax Reitz 'error' 1418fabb8beSMax Reitz 1428fabb8beSMax Reitz# Now we attach the image to the NBD server. This server does require 1438fabb8beSMax Reitz# some permissions (at least WRITE and READ_CONSISTENT), so if 1446d0a4a0fSMax Reitz# reopening node0 unshared any (which it should not have), this will 1456d0a4a0fSMax Reitz# fail (but it should not). 1466d0a4a0fSMax Reitzsuccess_or_failure=y _send_qemu_cmd $QEMU_HANDLE \ 1478fabb8beSMax Reitz "{'execute': 'nbd-server-add', 1486d0a4a0fSMax Reitz 'arguments': { 1498fabb8beSMax Reitz 'device': 'node1' 1506d0a4a0fSMax Reitz } }" \ 1516d0a4a0fSMax Reitz 'return' \ 1526d0a4a0fSMax Reitz 'error' 1536d0a4a0fSMax Reitz 1546d0a4a0fSMax Reitz_cleanup_qemu 1556d0a4a0fSMax Reitz 156dc68c9d3SMax Reitzecho 157dc68c9d3SMax Reitzecho '=== Testing failure to loosen restrictions ===' 158dc68c9d3SMax Reitzecho 159dc68c9d3SMax Reitz 160dc68c9d3SMax Reitz_launch_qemu -drive file=$TEST_IMG,if=none,file.locking=on 161dc68c9d3SMax Reitz 162dc68c9d3SMax Reitz_send_qemu_cmd $QEMU_HANDLE \ 163dc68c9d3SMax Reitz "{'execute': 'qmp_capabilities'}" \ 164dc68c9d3SMax Reitz 'return' 165dc68c9d3SMax Reitz 166dc68c9d3SMax Reitz_cleanup_test_img 167dc68c9d3SMax Reitz 168dc68c9d3SMax Reitz# When quitting qemu, it will try to drop its locks on the test image. 169dc68c9d3SMax Reitz# Because that file no longer exists, it will be unable to do so. 170dc68c9d3SMax Reitz# However, that is not fatal, so it should just move on. 171dc68c9d3SMax Reitz_send_qemu_cmd $QEMU_HANDLE \ 172dc68c9d3SMax Reitz "{'execute': 'quit'}" \ 173dc68c9d3SMax Reitz 'return' 174dc68c9d3SMax Reitz 175dc68c9d3SMax Reitzwait=1 _cleanup_qemu 176dc68c9d3SMax Reitz 177de9efdb3SFam Zheng# success, all done 178de9efdb3SFam Zhengecho "*** done" 179de9efdb3SFam Zhengrm -f $seq.full 180de9efdb3SFam Zhengstatus=0 181