Sync up with other xfs packages build mechanism
[xfstests-dev.git] / 013
1 #! /bin/sh
2 # XFS QA Test No. 013
3 #
4 # fsstress
5 #
6 #-----------------------------------------------------------------------
7 # Copyright (c) 2000-2002 Silicon Graphics, Inc.  All Rights Reserved.
8
9 # This program is free software; you can redistribute it and/or modify it
10 # under the terms of version 2 of the GNU General Public License as
11 # published by the Free Software Foundation.
12
13 # This program is distributed in the hope that it would be useful, but
14 # WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16
17 # Further, this software is distributed without any warranty that it is
18 # free of the rightful claim of any third person regarding infringement
19 # or the like.  Any license provided herein, whether implied or
20 # otherwise, applies only to this software file.  Patent licenses, if
21 # any, provided herein do not apply to combinations of this program with
22 # other software, or any other product whatsoever.
23
24 # You should have received a copy of the GNU General Public License along
25 # with this program; if not, write the Free Software Foundation, Inc., 59
26 # Temple Place - Suite 330, Boston MA 02111-1307, USA.
27
28 # Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
29 # Mountain View, CA  94043, or:
30
31 # http://www.sgi.com 
32
33 # For further information regarding this notice, see: 
34
35 # http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
36 #-----------------------------------------------------------------------
37 #
38 # creator
39 owner=dxm@sgi.com
40
41 seq=`basename $0`
42 echo "QA output created by $seq"
43
44 here=`pwd`
45 tmp=/tmp/$$
46 status=0        # success is the default!
47 trap "_cleanup; exit \$status" 0 1 2 3 15
48
49 _cleanup()
50 {
51     # we might get here with a RO FS
52     mount -o remount,rw $TEST_DEV >/dev/null 2>&1
53     # now kill!
54     rm -rf $TEST_DIR/fsstress.$$.*
55 }
56
57 _filesize()
58 {
59     ls -l $1 | $AWK_PROG '{print "    filesize = " $5}'
60 }
61
62 # get standard environment, filters and checks
63 . ./common.rc
64 . ./common.filter
65
66 _do_test()
67 {
68     _n="$1"
69     _param="$2"
70     _count="$3"
71     
72     failed=0
73     
74     out=$TEST_DIR/fsstress.$$.$_n
75     rm -rf $out
76     if ! mkdir $out
77     then
78         echo "    failed to mkdir $out"
79         status=1
80         exit
81     fi
82     
83     echo ""
84     echo "-----------------------------------------------"
85     echo "fsstress.$_n : $_param"
86     echo "-----------------------------------------------"
87     # -v >$tmp.out
88     if ! $here/ltp/fsstress $_param $FSSTRESS_AVOID -n $_count -d $out >/dev/null 2>&1
89     then
90         echo "    fsstress (count=$_count) returned $? - see $seq.full"
91         
92         echo "--------------------------------------"       >>$here/$seq.full
93         echo "$_n - output from fsstress:"                  >>$here/$seq.full
94         echo "--------------------------------------"       >>$here/$seq.full
95         echo "<NOT LOGGED>"                                 >>$here/$seq.full
96         #cat $tmp.out                                       >>$here/$seq.full
97         status=1
98     fi
99     
100     _check_test_fs
101 }
102
103
104 # real QA test starts here
105
106 rm -f $here/$seq.full
107 echo "brevity is wit..."
108
109 count=1000
110
111 _check_test_fs
112
113 # the default
114
115 _do_test 1 "-r" $count
116
117 # and the default with multiprocess
118
119 _do_test 2 "-p 5 -r" $count
120
121 # from Glen's notes
122
123 _do_test 3 "-p 4 -z -f rmdir=10 -f link=10 -f creat=10 -f mkdir=10 -f rename=30 -f stat=30 -f unlink=30 -f truncate=20" $count
124
125 exit
126
127 # Test with error injection:
128
129 # (error injection)
130 # fsstress -n 1000 -d $scratch -p 4 -z -f rmdir=10 -f link=10 -f creat=10 \
131 #          -f mkdir=10 -f rename=30 -f stat=30 -f unlink=30 -f truncate=20 \
132 #          -e 1
133
134 # Error values 1 - 6 test IFLUSH
135 #         1 - corrupt buffer being flushed to di_core.di_magic
136 #         2 - corrupt inode being flushed i_d.di_magic
137 #         3 - corrupt IFREG format check
138 #         4 - corrupt IFDIR format check
139 #         5 - corrupt i_d.di_nextents
140 #         6 - corrupt i_d.di_forkoff > sb_inodesize