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