Added feature to allow remaining tests to be written to file
[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 #   - blocks, agsize, agcount, device name
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=0
51 #
52 _mkfs_filter()
53 {
54    tee -a $seq.full | \
55    sed \
56         -e 's/blocks=[0-9][0-9]*/blocks=N/' \
57         -e 's/agsize=[0-9][0-9]*/agsize=N/' \
58         -e 's/agcount=[0-9][0-9]*/agcount=N/' \
59         -e 's/meta-data=[^ ]*/meta-data=DEV/' \
60         -e 's/ *isize/ isize/' \
61         -e '/ *= *sectsz=[0-9][0-9]* *attr=[0-9][0-9]*$/d' \
62         -e '/ *= *mmr=[0-9][0-9]* *$/d' \
63         -e 's/ *mixed-case=[YN]//' \
64         -e 's/sectsz=[0-9][0-9]* *//' \
65         -e 's/, lazy-count.*//' \
66         -e '/inode-paths/d' \
67         -e 's/\(log[    ]*=\).*bsize/\1LOG                    bsize/' \
68         -e 's/ *$//' \
69    | grep -v parent
70 }
71
72 # real QA test starts here
73 rm -f $seq.full
74
75 # Modify as appropriate.
76 _supported_fs xfs
77 _supported_os IRIX Linux
78 _require_scratch
79 _require_v2log
80
81 # choose .out file based on internal/external log
82 rm -f $seq.out
83 if [ "$USE_EXTERNAL" = yes ]; then
84         ln -s $seq.external $seq.out
85 else
86         ln -s $seq.internal $seq.out
87 fi
88
89 # maximum log record size
90 max_lr_size=`expr 256 \* 1024`
91
92 big_su=`expr $max_lr_size + 4096`
93
94 #
95 # Test out various mkfs param combinations
96 #
97 cat >$tmp.seq.params <<EOF
98 # su too big but must be a multiple of fs block size too
99   -l version=2,su=`expr $max_lr_size + 512`
100 # test log stripe greater than LR size
101   -l version=2,su=$big_su
102 # same test but get log stripe from data stripe
103   -l version=2 -d su=$big_su,sw=1
104 # test out data stripe
105   -d su=$big_su,sw=1
106 # test out data stripe the same but using sunit & swidth
107   -d sunit=`expr $big_su / 512`,swidth=`expr $big_su / 512`
108 EOF
109
110
111 #
112 # call mkfs in a loop for various params
113 #
114 echo ""
115 cat $tmp.seq.params \
116 | while read mkfs
117 do
118     if echo $mkfs | grep -q '^#'; then
119         # print out header & ignore comment
120         echo $mkfs
121         continue
122     fi
123     echo "--- mkfs=$mkfs ---"
124     export MKFS_OPTIONS="$mkfs"
125     _scratch_mkfs_xfs | _mkfs_filter
126     echo ""
127     echo ""
128 done
129
130 # success, all done
131 status=0
132 exit