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

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

Revision 1.9, Thu Jun 12 04:17:41 2003 UTC (14 years, 4 months ago) by fsgqa
Branch: MAIN
Changes since 1.8: +1 -1 lines

Fix QA tests which use dd so that they specify posixly correct output

#! /bin/sh
# XFS QA Test No. 015
# $Id: 1.1 $
#
# check out-of-space behaviour
#
#-----------------------------------------------------------------------
# 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=dxm@sgi.com

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

here=`pwd`
tmp=/tmp/$$
status=1	# success is the default!

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

_cleanup()
{
	umount $SCRATCH_MNT
}

trap "_cleanup; exit \$status" 0 1 2 3 15

_free()
{
    _df_dir $SCRATCH_MNT | $AWK_PROG '{ print $5 }'
}

_filter_dd()
{
    $AWK_PROG '
        /records in/                { next }
        /records out/               { next }
        /No space left on device/   { print "   !!! disk full (expected)" 
                                      next }
                                    { print "   *** " $0 }
    '
}

# real QA test starts here
_require_scratch

_scratch_mkfs_xfs -d size=50m >/dev/null
_scratch_mount
out=$SCRATCH_MNT/fillup.$$
rm -f $seq.full

free0=`_free`
if [ -z "$free0" ]
then
    echo "   *** failed to get free space (0)"
    exit 1
fi
echo "free space at start $free0" >> $seq.full

echo "fill disk:"	# well, filesystem really - not disk

POSIXLY_CORRECT=yes dd if=/dev/zero of=$out bs=1024k 2>&1 | _filter_dd

echo "check free space:"

free1=`_free`
if [ -z "$free1" ]
then
    echo "   *** failed to get free space (1)"
    exit 1
fi
echo "free space after fill $free1" >> $seq.full

if [ ! -e $out ]
then
    echo "   *** file not created"
    exit 1
fi

if [ ! -s $out ]
then
    echo "   *** file created with zero length"
    ls -l $out
    exit 1
fi

echo "delete fill:"

if ! rm $out
then
    echo "   *** file not deleted"
    exit 1
fi

if [ -e $out ]
then
    echo "   *** file still exists"
    ls -l $out
    exit 1
fi

echo "check free space:"

free2=`_free`
if [ -z "$free2" ]
then
    echo "   *** failed to get free space (2)"
    exit 1
fi
echo "free space after delete $free2" >> $seq.full

echo -n "   !!! "
_within_tolerance "free space" $free2 $free0 1% -v

status=0
exit