common/xfs: refactor commands to select a particular xfs backing device
[xfstests-dev.git] / tests / overlay / 005
1 #! /bin/bash
2 # SPDX-License-Identifier: GPL-2.0
3 # Copyright (c) 2016 Red Hat Inc. All Rights Reserved.
4 #
5 # FS QA Test 005
6 #
7 # Memleak in overlayfs copy-up error handling path leads to panic
8 # when unmount the underlying fs.
9 # Kernel commit ab79efab0 fixed this issue.
10 #
11 seq=`basename $0`
12 seqres=$RESULT_DIR/$seq
13 echo "QA output created by $seq"
14
15 here=`pwd`
16 tmp=/tmp/$$
17 status=1        # failure is the default!
18 trap "_cleanup; exit \$status" 0 1 2 3 15
19
20 _cleanup()
21 {
22         cd /
23         rm -f $tmp.*
24         _destroy_loop_device $fs_loop_dev
25         _destroy_loop_device $upper_loop_dev
26         rm -f $lower_img
27         rm -f $upper_img
28 }
29
30 # get standard environment, filters and checks
31 . ./common/rc
32 . ./common/filter
33
34 # remove previous $seqres.full before test
35 rm -f $seqres.full
36
37 # real QA test starts here
38
39 # Modify as appropriate.
40 _supported_fs overlay
41 # Use non-default scratch underlying overlay dirs, we need to check
42 # them explicity after test.
43 _require_scratch_nocheck
44 _require_loop
45
46 # Remove all files from previous tests
47 _scratch_mkfs
48
49 # setup loop images fs for overlayfs
50 lower_img=${OVL_BASE_SCRATCH_MNT}/${seq}.$$.img
51 $XFS_IO_PROG -f -c "truncate 120m" $lower_img >>$seqres.full 2>&1
52 fs_loop_dev=`_create_loop_device $lower_img`
53 $MKFS_XFS_PROG -f -n ftype=1 $fs_loop_dev >>$seqres.full 2>&1
54
55 # only 20m for upper dir
56 upper_img=${OVL_BASE_SCRATCH_MNT}/$$.${seq}.img
57 $XFS_IO_PROG -f -c "truncate 20m" $upper_img >>$seqres.full 2>&1
58 upper_loop_dev=`_create_loop_device $upper_img`
59 $MKFS_XFS_PROG -f -n ftype=1 $upper_loop_dev >>$seqres.full 2>&1
60
61 # mount underlying xfs
62 mkdir -p ${OVL_BASE_SCRATCH_MNT}/lowermnt
63 mkdir -p ${OVL_BASE_SCRATCH_MNT}/uppermnt
64 $MOUNT_PROG $fs_loop_dev ${OVL_BASE_SCRATCH_MNT}/lowermnt
65 $MOUNT_PROG $upper_loop_dev ${OVL_BASE_SCRATCH_MNT}/uppermnt
66
67 # prepare dirs
68 mkdir -p ${OVL_BASE_SCRATCH_MNT}/lowermnt/lower
69 mkdir -p ${OVL_BASE_SCRATCH_MNT}/uppermnt/upper
70 mkdir -p ${OVL_BASE_SCRATCH_MNT}/uppermnt/work
71
72 lowerd=${OVL_BASE_SCRATCH_MNT}/lowermnt/lower
73 upperd=${OVL_BASE_SCRATCH_MNT}/uppermnt/upper
74 workd=${OVL_BASE_SCRATCH_MNT}/uppermnt/work
75
76 # Create test file in lower dir, with too big a size for
77 # upper dir to copy up.
78 $XFS_IO_PROG -f -c "truncate 48m" ${lowerd}/test_file \
79         >>$seqres.full 2>&1
80
81 # mount new overlayfs
82 _overlay_scratch_mount_dirs $lowerd $upperd $workd
83
84 # the open call triggers copy-up and it will fail ENOSPC
85 $XFS_IO_PROG -f -c "o" ${SCRATCH_MNT}/test_file \
86         >>$seqres.full 2>&1
87
88 # unmount overlayfs
89 $UMOUNT_PROG $SCRATCH_MNT
90
91 # check overlayfs
92 _overlay_check_scratch_dirs $lowerd $upperd $workd
93
94 # unmount undelying xfs, this tiggers panic if memleak happens
95 $UMOUNT_PROG ${OVL_BASE_SCRATCH_MNT}/uppermnt
96 $UMOUNT_PROG ${OVL_BASE_SCRATCH_MNT}/lowermnt
97
98 # success, all done
99 echo "Silence is golden"
100 status=0
101 exit