xfsqa 185 shouldn't have uninitialised variables in the golden output
[xfstests-dev.git] / 096
1 #! /bin/sh
2 # FS QA Test No. 096
3 #
4 # test out mkfs_xfs output on IRIX/Linux and some of its error handling
5 # ensure pv#920679 is addressed
6 #
7 #-----------------------------------------------------------------------
8 # Copyright (c) 2000-2004 Silicon Graphics, Inc.  All Rights Reserved.
9 #-----------------------------------------------------------------------
10 #
11 # creator
12 owner=tes@sgi.com
13
14 seq=`basename $0`
15 echo "QA output created by $seq"
16
17 here=`pwd`
18 tmp=/tmp/$$
19 status=1        # failure is the default!
20 trap "_cleanup; exit \$status" 0 1 2 3 15
21
22 _cleanup()
23 {
24     cd /
25     rm -f $tmp.*
26 }
27
28 # get standard environment, filters and checks
29 . ./common.rc
30 . ./common.filter
31 . ./common.log
32
33 #
34 # filter out counts which will vary
35 #   - extsz, blocks, agsize, agcount, device name, rtextents
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 $seq.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/agsize=[0-9][0-9]*/agsize=N/' \
59         -e 's/agcount=[0-9][0-9]*/agcount=N/' \
60         -e 's/swidth=[0-9][0-9]* blks$/&, unwritten=1/' \
61         -e 's/rtextents=[0-9][0-9]*/rtextents=N/' \
62         -e 's/meta-data=[^ ]*/meta-data=DEV/' \
63         -e 's/ *isize/ isize/' \
64         -e '/ *= *sectsz=[0-9][0-9]* *attr=[0-9][0-9]*$/d' \
65         -e '/ *= *mmr=[0-9][0-9]* *$/d' \
66         -e 's/ *mixed-case=[YN]//' \
67         -e 's/sectsz=[0-9][0-9]* *//' \
68         -e 's/, lazy-count.*//' \
69         -e '/inode-paths/d' \
70         -e 's/\(log[    ]*=\).*bsize/\1LOG                    bsize/' \
71         -e 's/\(realtime[       ]*=\).*extsz/\1REALTIME               extsz/' \
72         -e 's/ *$//' \
73    | grep -v parent
74 }
75
76 # real QA test starts here
77 rm -f $seq.full
78
79 # Modify as appropriate.
80 _supported_fs xfs
81 _supported_os IRIX Linux
82 _require_scratch
83 _require_v2log
84
85 # choose .out file based on internal/external log
86 rm -f $seq.out
87 if [ "$USE_EXTERNAL" = yes ]; then
88         ln -s $seq.external $seq.out
89 else
90         ln -s $seq.internal $seq.out
91 fi
92
93 # maximum log record size
94 max_lr_size=`expr 256 \* 1024`
95
96 big_su=`expr $max_lr_size + 4096`
97
98 #
99 # Test out various mkfs param combinations
100 #
101 cat >$tmp.seq.params <<EOF
102 # su too big but must be a multiple of fs block size too
103   -l version=2,su=`expr $max_lr_size + 512`
104 # test log stripe greater than LR size
105   -l version=2,su=$big_su
106 # same test but get log stripe from data stripe
107   -l version=2 -d su=$big_su,sw=1
108 # test out data stripe
109   -l version=1 -d su=$big_su,sw=1
110 # test out data stripe the same but using sunit & swidth
111   -l version=1 -d sunit=`expr $big_su / 512`,swidth=`expr $big_su / 512`
112 EOF
113
114
115 #
116 # call mkfs in a loop for various params
117 #
118 echo ""
119 cat $tmp.seq.params \
120 | while read mkfs
121 do
122     if echo $mkfs | grep -q '^#'; then
123         # print out header & ignore comment
124         echo $mkfs
125         continue
126     fi
127     echo "--- mkfs=$mkfs ---"
128     export MKFS_OPTIONS="$mkfs"
129     _scratch_mkfs_xfs | _mkfs_filter
130     echo ""
131     echo ""
132 done
133
134 # success, all done
135 status=0
136 exit