generic: add test for boundary in xfs_attr_shortform_verify
[xfstests-dev.git] / tests / generic / 055
1 #! /bin/bash
2 # SPDX-License-Identifier: GPL-2.0
3 # Copyright (c) 2000-2004 Silicon Graphics, Inc.  All Rights Reserved.
4 #
5 # FS QA Test No. 055
6 #
7 # * like 054 but want to create more/different kinds of metadata
8 #   and so will use fsstress
9 # * also can interrupt metadata with godown
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 "rm -f $tmp.*; exit \$status" 0 1 2 3 15
19
20 # get standard environment, filters and checks
21 . ./common/rc
22 . ./common/filter
23 . ./common/log
24 . ./common/quota
25
26 _do_meta()
27 {
28     out=$SCRATCH_MNT/fsstress
29     count=10000
30     param="-p 4 -z -f rmdir=10 -f link=10 -f creat=10 -f mkdir=10 \
31            -f rename=30 -f stat=30 -f unlink=30 -f truncate=20"
32     _echofull "calling fsstress $param -m8 -n $count"
33     FSSTRESS_ARGS=`_scale_fsstress_args $param $FSSTRESS_AVOID -m 8 -n $count -d $out`
34     if ! $FSSTRESS_PROG $FSSTRESS_ARGS >>$seqres.full 2>&1
35     then
36         _echofull "fsstress failed"
37     fi
38 }
39
40 _get_quota_option()
41 {
42     case $FSTYP in
43     xfs)
44         _require_xfs_quota
45         echo "-o uquota"
46         ;;
47     *)
48         ;;
49     esac
50 }
51
52 # real QA test starts here
53 _supported_fs generic
54 _supported_os Linux
55
56 rm -f $seqres.full $tmp.*
57 _require_scratch
58 _require_scratch_shutdown
59 _require_logstate
60
61 QUOTA_OPTION=`_get_quota_option`
62
63 echo "*** init FS"
64 _scratch_unmount >/dev/null 2>&1
65
66 _scratch_mkfs >/dev/null 2>&1
67 _require_metadata_journaling $SCRATCH_DEV
68
69 _get_log_configs > $tmp.seq.params
70
71 cat $tmp.seq.params \
72 | while read mkfs mnt restofline
73 do
74     if [ "$mkfs" = "#" ]; then
75         continue
76     fi
77
78     echo "--- mkfs=$mkfs, mnt=$mnt ---" >> $seqres.full
79     export MKFS_OPTIONS="-l $mkfs"
80     export MOUNT_OPTIONS="-o $mnt"
81
82     # mkfs the FS
83     _echofull "mkfs"
84     _scratch_mkfs >>$seqres.full 2>&1
85     if [ $? -ne 0 ] ; then
86         _echofull "mkfs failed: $MKFS_OPTIONS"
87         continue
88     fi
89
90     # mount the FS
91     _echofull "mount"
92     if ! _try_scratch_mount $QUOTA_OPTION >>$seqres.full 2>&1; then
93         _echofull "mount failed: $MOUNT_OPTIONS"
94         continue
95     fi
96
97     # create the metadata
98     _do_meta
99
100     # check before on what FS should look like
101     _echofull "ls -RF SCRATCH_MNT"
102     ls -RF $SCRATCH_MNT >$tmp.ls1
103
104     _echofull "godown"
105     _scratch_shutdown -v -f >> $seqres.full
106
107     _echofull "unmount"
108     _scratch_unmount >>$seqres.full 2>&1 \
109         || _fail "umount failed"
110
111     _echofull "logprint after going down..."
112     _print_logstate
113
114     _full "logprint headers"
115     _scratch_xfs_logprint -n >>$seqres.full 2>&1
116
117     _echofull "mount with replay"
118     _try_scratch_mount $QUOTA_OPTION >>$seqres.full 2>&1 \
119         || _fail "mount failed: $MOUNT_OPTIONS"
120
121     # check on what FS looks like after log recovery
122     _echofull "ls -RF SCRATCH_MNT"
123     ls -RF $SCRATCH_MNT >$tmp.ls2
124
125     _echofull "diff ls before and after"
126     diff -us $tmp.ls1 $tmp.ls2 | sed "s#$tmp#TMP#g"
127
128     _echofull "unmount"
129     _scratch_unmount
130
131     _echofull "logprint after mount and replay..."
132     _print_logstate
133
134     if _check_scratch_fs; then
135         _echofull "filesystem is checked ok"
136     else
137         _echofull "filesystem is NOT ok"
138     fi
139 done
140
141 status=0
142 exit