btrfs: check qgroup doesn't crash when beyond limit
[xfstests-dev.git] / tests / btrfs / 230
1 #! /bin/bash
2 # SPDX-License-Identifier: GPL-2.0
3 # Copyright (c) 2020 SUSE Linux Products GmbH. All Rights Reserved.
4 #
5 # FS QA Test 230
6 #
7 # Test if btrfs qgroup would crash if we're modifying the fs
8 # after exceeding the limit
9 #
10 seq=`basename $0`
11 seqres=$RESULT_DIR/$seq
12 echo "QA output created by $seq"
13
14 here=`pwd`
15 tmp=/tmp/$$
16 status=1        # failure is the default!
17 trap "_cleanup; exit \$status" 0 1 2 3 15
18
19 _cleanup()
20 {
21         cd /
22         rm -f $tmp.*
23 }
24
25 # get standard environment, filters and checks
26 . ./common/rc
27 . ./common/filter
28
29 # remove previous $seqres.full before test
30 rm -f $seqres.full
31
32 # real QA test starts here
33
34 _supported_fs btrfs
35
36 # Need at least 2GiB
37 _require_scratch_size $((2 * 1024 * 1024))
38 _scratch_mkfs > /dev/null 2>&1
39 _scratch_mount
40
41 _pwrite_byte 0xcd 0 1G $SCRATCH_MNT/file >> $seqres.full
42 # Make sure the data reach disk so later qgroup scan can see it
43 sync
44
45 $BTRFS_UTIL_PROG quota enable $SCRATCH_MNT
46 $BTRFS_UTIL_PROG quota rescan -w $SCRATCH_MNT >> $seqres.full
47
48 # Set the limit to just 512MiB, which is way below the existing usage
49 $BTRFS_UTIL_PROG qgroup limit  512M 0/5 $SCRATCH_MNT
50
51 # Touch above file, if kernel not patched, it will trigger an ASSERT()
52 #
53 # Even for patched kernel, we will still get EDQUOT error, but that
54 # is expected behavior.
55 touch $SCRATCH_MNT/file 2>&1 | _filter_scratch
56
57 # success, all done
58 status=0
59 exit