get output for out-of-space handling test right
[xfstests-dev.git] / 008
1 #! /bin/sh
2 # XFS QA Test No. 008
3 #
4 # randholes test
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 pgsize=`$here/src/feature -p`
48 trap "rm -f $tmp.*; _cleanup; exit \$status" 0 1 2 3 15
49
50 _cleanup()
51 {
52     rm -rf $TEST_DIR/randholes.$$.*
53 }
54
55 _filter()
56 {
57     sed -e "s/-b $pgsize/-b PGSIZE/g"
58 }
59
60 # get standard environment, filters and checks
61 . ./common.rc
62 . ./common.filter
63
64 _do_test()
65 {
66     _n="$1"
67     _holes="$2"
68     _param="$3"
69     
70     out=$TEST_DIR/randholes.$$.$_n
71     echo ""
72     echo "randholes.$_n : $_param" | _filter
73     echo "------------------------------------------"
74     if $here/src/randholes $_param $out >$tmp.out
75     then
76         # quick check - how many holes did we get?
77         count=`xfs_bmap $out | egrep -c ': hole'`
78         # blocks can end up adjacent, therefore number of holes varies
79         _within_tolerance "holes" $count $_holes 10% -v
80     else
81         echo "    randholes returned $? - see $seq.out.full"
82         echo "--------------------------------------"       >>$here/$seq.out.full
83         echo "$_n - output from randholes:"                 >>$here/$seq.out.full
84         echo "--------------------------------------"       >>$here/$seq.out.full
85         cat $tmp.out                                        >>$here/$seq.out.full
86         echo "--------------------------------------"       >>$here/$seq.out.full
87         echo "$_n - output from bmap:"                      >>$here/$seq.out.full
88         echo "--------------------------------------"       >>$here/$seq.out.full
89         xfs_bmap -vvv $out                                  >>$here/$seq.out.full
90         status=1
91     fi
92 }
93
94 # real QA test starts here
95
96 rm -f $here/$seq.out.full
97
98 _do_test 1 50 "-l 5000000 -c 50 -b $pgsize"
99 _do_test 2 100 "-l 10000000 -c 100 -b $pgsize"
100 _do_test 3 100 "-l 10000000 -c 100 -b 512"   # test partial pages
101
102 # rinse, lather, repeat for direct IO
103 _do_test 4 50 "-d -l 5000000 -c 50 -b $pgsize"
104 _do_test 5 100 "-d -l 10000000 -c 100 -b $pgsize"
105 # note: direct IO requires page aligned IO
106
107 # todo: realtime.
108
109 # success, all done
110 exit