xfs/096: filter out the "Discarding..." output
[xfstests-dev.git] / tests / xfs / 096
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. 096
6 #
7 # test out mkfs_xfs output on IRIX/Linux and some of its error handling
8 # ensure pv#920679 is addressed
9 #
10 seqfull=$0
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 }
25
26 # get standard environment, filters and checks
27 . ./common/rc
28 . ./common/filter
29 . ./common/log
30
31 #
32 # filter out counts which will vary
33 #   - extsz, blocks, agsize, agcount, device name, rtextents
34 #   - log version varies for crc enabled fs
35 #   - lsunit varies for 512/4k sector devices
36 # filter out differences between linux and irix:
37 #   - sectsz on Linux
38 #   - mmr, mixed-case on IRIX
39 #   - lazy-count on IRIX
40 #   - inode-paths on IRIX
41 #   - trailing spaces on Linux but not on IRIX
42 #
43 # Example output:
44 #  meta-data=DEV isize=256    agcount=N, agsize=N blks
45 #  data     =                       bsize=4096   blocks=N, imaxpct=25
46 #           =                       sunit=65     swidth=65 blks, unwritten=1
47 #  naming   =version 2              bsize=4096
48 #  log      =internal log           bsize=4096   blocks=N, version=1
49 #           =                       sunit=0 blks
50 #  realtime =none                   extsz=65536  blocks=N, rtextents=N
51 #
52 mkfs_filter()
53 {
54    tee -a $seqres.full | \
55    sed \
56         -e 's/extsz=[0-9][0-9]*[ ]*/extsz=N, /' \
57         -e 's/blocks=[0-9][0-9]*/blocks=N/' \
58         -e 's/imaxpct=[0-9][0-9]*/imaxpct=N/' \
59         -e 's/agsize=[0-9][0-9]*/agsize=N/' \
60         -e 's/agcount=[0-9][0-9]*/agcount=N/' \
61         -e 's/swidth=[0-9][0-9]* blks$/&, unwritten=1/' \
62         -e 's/rtextents=[0-9][0-9]*/rtextents=N/' \
63         -e 's/meta-data=[^ ]*/meta-data=DEV/' \
64         -e 's/ *isize=[0-9]* / isize=N /' \
65         -e '/ *= *sectsz=[0-9][0-9]* *attr=[0-9][0-9]*.*$/d' \
66         -e '/ *= *mmr=[0-9][0-9]* *$/d' \
67         -e 's/ *mixed-case=[YN]//' \
68         -e 's/ *ascii-ci=[01]//' \
69         -e 's/\(version=\)\([12]\)/\1N/' \
70         -e 's/\(sunit=\)\([018] blks\)/\1N blks/' \
71         -e 's/sectsz=[0-9][0-9]* *//' \
72         -e 's/, lazy-count.*//' \
73         -e '/inode-paths/d' \
74         -e 's/\(log[    ]*=\).*bsize/\1LOG                    bsize/' \
75         -e 's/\(realtime[       ]*=\).*extsz/\1REALTIME               extsz/' \
76         -e '/.*crc=/d' \
77         -e 's/ *$//' \
78         -e 's/ ftype=[01]//' \
79         -e '/^log stripe unit.*too large/d' \
80         -e '/^log stripe unit adjusted/d' \
81         -e '/Discarding/d' \
82    | grep -v parent
83 }
84
85 # real QA test starts here
86 rm -f $seqres.full
87
88 # Modify as appropriate.
89 _supported_fs xfs
90 _supported_os Linux
91 _require_scratch
92 _require_v2log
93 _require_xfs_mkfs_without_validation
94
95 # choose .out file based on internal/external log
96 rm -f $seqfull.out
97 if [ "$USE_EXTERNAL" = yes ]; then
98         ln -s $seq.out.external $seqfull.out
99 else
100         ln -s $seq.out.internal $seqfull.out
101 fi
102
103 # maximum log record size
104 max_lr_size=`expr 256 \* 1024`
105
106 big_su=`expr $max_lr_size + 4096`
107
108 #
109 # Test out various mkfs param combinations
110 #
111 cat >$tmp.seq.params <<EOF
112 # su too big but must be a multiple of fs block size too
113   -l version=2,su=`expr $max_lr_size + 512`
114 # test log stripe greater than LR size
115   -l version=2,su=$big_su
116 # same test but get log stripe from data stripe
117   -l version=2 -d su=$big_su,sw=1
118 # test out data stripe
119   -m crc=0 -l version=1 -d su=$big_su,sw=1
120 # test out data stripe the same but using sunit & swidth
121   -m crc=0 -l version=1 -d sunit=`expr $big_su / 512`,swidth=`expr $big_su / 512`
122 EOF
123
124 #
125 # call mkfs in a loop for various params
126 #
127 echo ""
128 cat $tmp.seq.params \
129 | while read mkfs
130 do
131     if echo $mkfs | grep -q '^#'; then
132         # print out header & ignore comment
133         echo $mkfs
134         continue
135     fi
136     echo "--- mkfs=$mkfs ---"
137     export MKFS_OPTIONS="$mkfs"
138     _scratch_mkfs_xfs 2>&1 | mkfs_filter
139     echo ""
140     echo ""
141 done
142
143 # success, all done
144 status=0
145 exit