support cvs-driven updates in addition to ptools commands.
[xfstests-dev.git] / 029
1 #! /bin/sh
2 # XFS QA Test No. 029
3 # $Id: 1.1 $
4 #
5 # exercise mkfs log (internal/external) zeroing
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=nathans@sgi.com
41
42 seq=`basename $0`
43 echo "QA output created by $seq"
44
45 here=`pwd`
46 tmp=/tmp/$$
47 status=1        # failure is the default
48 trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15
49
50 # get standard environment, filters and checks
51 . ./common.rc
52 . ./common.filter
53
54 mkfs_args=""
55 logp_args=""
56 if [ ! -z "$SCRATCH_LOGDEV" ]   # test external log if possible
57 then
58         mkfs_args="-l logdev=$SCRATCH_LOGDEV,size=1200b"
59         logp_args="-l $SCRATCH_LOGDEV"
60 fi
61
62 _filter_logprint()
63 {
64         perl -ne '
65             s/data device: ([\w|\/]+)/data device: DDEV/;
66             s/log device: ([\w|\/]+) daddr: (\d+) length: (\d+)/log device: LDEV daddr: XXX length: XXX/;
67             s/log file: "([\w|\/]+)" daddr: (\d+) length: (\d+)/log device: LDEV daddr: XXX length: XXX/;
68             s/skipped (\w+) zeroed blocks/skipped XXX zeroed blocks/;
69             s/^uuid: *[0-9a-f-][0-9a-f-]* *format: *.*$/uuid: <UUID> format: <FORMAT>/;
70             print;
71         '
72 }
73
74 # real QA test starts here
75
76 _require_scratch
77
78 echo
79 mkfs -t xfs -f $mkfs_args $SCRATCH_DEV | _filter_mkfs 2>/dev/null
80
81 echo
82 xfs_logprint $logp_args $SCRATCH_DEV | _filter_logprint
83
84 status=0
85 exit