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