[BACK]Return to 029 CVS log [TXT][DIR] Up to [Development] / xfs-cmds / xfstests

File: [Development] / xfs-cmds / xfstests / 029 (download)

Revision 1.8, Sun Sep 1 11:11:13 2002 UTC (15 years, 1 month ago) by nathans
Branch: MAIN
Changes since 1.7: +1 -0 lines

changes for supporting the version 2 log format.

#! /bin/sh
# XFS QA Test No. 029
# $Id: 1.1 $
#
# exercise mkfs log (internal/external) zeroing
#
#-----------------------------------------------------------------------
# Copyright (c) 2000-2002 Silicon Graphics, Inc.  All Rights Reserved.
# 
# This program is free software; you can redistribute it and/or modify it
# under the terms of version 2 of the GNU General Public License as
# published by the Free Software Foundation.
# 
# This program is distributed in the hope that it would be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# 
# Further, this software is distributed without any warranty that it is
# free of the rightful claim of any third person regarding infringement
# or the like.  Any license provided herein, whether implied or
# otherwise, applies only to this software file.  Patent licenses, if
# any, provided herein do not apply to combinations of this program with
# other software, or any other product whatsoever.
# 
# You should have received a copy of the GNU General Public License along
# with this program; if not, write the Free Software Foundation, Inc., 59
# Temple Place - Suite 330, Boston MA 02111-1307, USA.
# 
# Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
# Mountain View, CA  94043, or:
# 
# http://www.sgi.com 
# 
# For further information regarding this notice, see: 
# 
# http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
#-----------------------------------------------------------------------
#
# creator
owner=nathans@sgi.com

seq=`basename $0`
echo "QA output created by $seq"

here=`pwd`
tmp=/tmp/$$
status=1	# failure is the default
trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15

# get standard environment, filters and checks
. ./common.rc
. ./common.filter

mkfs_args=""
logp_args=""
if [ ! -z "$SCRATCH_LOGDEV" ]	# test external log if possible
then
	_require_logdev
	mkfs_args="-l logdev=$SCRATCH_LOGDEV,size=1200b"
	logp_args="-l $SCRATCH_LOGDEV"
fi

_filter_logprint()
{
	perl -ne '
	    s/data device: ([\w|\/.-]+)/data device: DDEV/;
	    s/log device: ([\w|\/.-]+) daddr: (\d+) length: (\d+)/log device: LDEV daddr: XXX length: XXX/;
	    s/log file: "([\w|\/.-]+)" daddr: (\d+) length: (\d+)/log device: LDEV daddr: XXX length: XXX/;
	    s/skipped (\w+) zeroed blocks/skipped XXX zeroed blocks/;
            s/^uuid: *[0-9a-f-][0-9a-f-]* *format: *.*$/uuid: <UUID> format: <FORMAT>/;
            s/version: \d/version: <VERN>/;
	    print;
	'
}

# real QA test starts here
_require_scratch

echo
mkfs_xfs $mkfs_args $SCRATCH_DEV | _filter_mkfs 2>/dev/null

echo
xfs_logprint $logp_args $SCRATCH_DEV | _filter_logprint

status=0
exit