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

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

Revision 1.1, Mon Jan 15 05:01:19 2001 UTC (16 years, 9 months ago) by nathans
Branch: MAIN
CVS Tags: Release-1_0_0, Linux-2_4_5-merge

cmd/xfs/stress/017 1.8 Renamed to cmd/xfstests/017

#! /bin/sh
# XFS QA Test No. 017
# $Id: 1.1 $
#
# test remount ro - pv 795642 
#
#-----------------------------------------------------------------------
# Copyright (c) 2000 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

_cleanup()
{
    echo "*** unmount"
    umount $SCRATCH_MNT 2>/dev/null
}
trap "_cleanup; rm -f $tmp.*; exit \$status" 0 1 2 3 15

_clean_log()
{
    echo ""                                 >>$seq.full
    echo "*** xfs_logprint ***"             >>$seq.full
    echo ""                                 >>$seq.full
    xfs_logprint -tb $1                     | tee -a $seq.full \
        | head | grep -q "<CLEAN>" || _fail "DIRTY LOG"
}

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

# real QA test starts here

_require_scratch

echo "*** init FS"

rm -f $seq.full
umount $SCRATCH_DEV >/dev/null 2>&1
echo "*** MKFS ***"                         >>$seq.full
echo ""                                     >>$seq.full
mkfs -t xfs -f $SCRATCH_DEV                 >>$seq.full 2>&1 \
    || _fail "mkfs failed"
mount -t xfs $SCRATCH_DEV $SCRATCH_MNT      >>$seq.full 2>&1 \
    || _fail "mount failed"

echo "*** test"

for l in 0 1 2 3 4
do
        echo "    *** test $l"
        src/fsstress -d $SCRATCH_MNT -n 1000 $FSSTRESS_AVOID >>$seq.full
        
        mount -o remount,ro $SCRATCH_DEV \
            || _fail "remount ro failed"
            
        _clean_log $SCRATCH_DEV 
        
        echo ""                             >>$seq.full
        echo "*** XFS_CHECK ***"            >>$seq.full
        echo ""                             >>$seq.full
        xfs_check $SCRATCH_DEV              >>$seq.full 2>&1 \
            || _fail "xfs_check failed"
        mount -o remount,rw $SCRATCH_DEV \
            || _fail "remount rw failed"
done

echo "*** done"
# happy exit
rm -f $seq.full
status=0
exit 0