2010-04-29 09:59:24 +10:00
|
|
|
#!/bin/bash
|
2001-01-15 05:01:19 +00:00
|
|
|
#-----------------------------------------------------------------------
|
2002-06-04 23:07:56 +00:00
|
|
|
# Copyright (c) 2000-2002 Silicon Graphics, Inc. All Rights Reserved.
|
2009-06-05 15:41:14 -05:00
|
|
|
#
|
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
|
# modify it under the terms 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. See the
|
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
|
#
|
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
|
# along with this program; if not, write the Free Software Foundation,
|
|
|
|
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
#
|
2001-01-15 05:01:19 +00:00
|
|
|
#-----------------------------------------------------------------------
|
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
# get standard environment, filters and checks
|
|
|
|
|
. ./common.rc
|
|
|
|
|
. ./common.filter
|
|
|
|
|
|
|
|
|
|
tmp=/tmp/$$
|
|
|
|
|
seq=soak
|
|
|
|
|
status=1 # failure is the default!
|
|
|
|
|
|
|
|
|
|
_cleanup()
|
|
|
|
|
{
|
|
|
|
|
echo " *** umount"
|
|
|
|
|
umount $SCRATCH_DEV >/dev/null 2>&1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
trap "_cleanup; exit \$status" 0 1 2 3 15
|
|
|
|
|
|
|
|
|
|
ROOT="."
|
|
|
|
|
LOG="$ROOT/soak.log"
|
|
|
|
|
FULL="$ROOT/soak.full"
|
|
|
|
|
|
|
|
|
|
_log()
|
|
|
|
|
{
|
|
|
|
|
echo "$*" 1>&2
|
|
|
|
|
echo "$*" >>$LOG
|
|
|
|
|
echo "$*" >>$FULL
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_logp()
|
|
|
|
|
{
|
|
|
|
|
tee -a $FULL
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_fail()
|
|
|
|
|
{
|
|
|
|
|
_log "$*"
|
|
|
|
|
status=1
|
|
|
|
|
exit 1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_require_scratch
|
|
|
|
|
|
|
|
|
|
passes=-1
|
|
|
|
|
stress=100000
|
|
|
|
|
proc=1
|
|
|
|
|
|
|
|
|
|
if [ $# -gt 0 ]
|
|
|
|
|
then
|
|
|
|
|
passes=$1
|
|
|
|
|
if [ $# -gt 1 ]
|
|
|
|
|
then
|
|
|
|
|
stress=$2
|
|
|
|
|
if [ $# -gt 2 ]
|
|
|
|
|
then
|
|
|
|
|
proc=$3
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
echo "" >$FULL
|
|
|
|
|
echo "" >$LOG
|
|
|
|
|
_log "*** soak test started (passes=$passes, stress=$stress, proc=$proc)"
|
|
|
|
|
_log "*** (`date`)"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_log " *** init"
|
|
|
|
|
_log " *** unmounting scratch device"
|
|
|
|
|
|
|
|
|
|
umount $SCRATCH_DEV 2>&1 | _fix_malloc >>$FULL
|
|
|
|
|
|
|
|
|
|
_log " *** clean scratch device"
|
|
|
|
|
|
2002-01-20 00:47:43 +00:00
|
|
|
mkfs_xfs -f $SCRATCH_DEV 2>&1 | _fix_malloc >>$FULL \
|
2001-01-15 05:01:19 +00:00
|
|
|
|| _fail " !!! failed to mkfs SCRATCH_DEV"
|
|
|
|
|
|
|
|
|
|
pass=1
|
|
|
|
|
|
|
|
|
|
while [ $pass -le $passes -o $passes -lt 0 ]
|
|
|
|
|
do
|
|
|
|
|
_log " *** pass $pass (`date`)"
|
|
|
|
|
|
|
|
|
|
_log " *** check"
|
2003-05-22 04:16:45 +00:00
|
|
|
_check_scratch_fs
|
2001-01-15 05:01:19 +00:00
|
|
|
|
|
|
|
|
_log " *** mounting scratch device"
|
|
|
|
|
|
2003-05-22 04:16:45 +00:00
|
|
|
if ! _scratch_mount 2>&1 | _logp
|
2001-01-15 05:01:19 +00:00
|
|
|
then
|
|
|
|
|
_fail " !!! failed to mount"
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
if [ $pass != 1 ]
|
|
|
|
|
then
|
|
|
|
|
_log " *** cleanup"
|
|
|
|
|
rm -rf $SCRATCH_MNT/soak_test \
|
|
|
|
|
|| _fail " !!! couldn't delete old dir"
|
|
|
|
|
|
|
|
|
|
_log " *** check"
|
2003-05-22 04:16:45 +00:00
|
|
|
_check_scratch_fs
|
2001-01-15 05:01:19 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
_log " *** mkdir"
|
|
|
|
|
mkdir $SCRATCH_MNT/soak_test \
|
|
|
|
|
|| _fail " !!! couldn't delete old dir"
|
|
|
|
|
|
|
|
|
|
_log " *** stress"
|
2003-07-07 06:36:46 +00:00
|
|
|
ltp/fsstress -d $SCRATCH_MNT/soak_test -p $proc -n $stress $FSSTRESS_AVOID 2>&1 | \
|
2001-01-15 05:01:19 +00:00
|
|
|
_fix_malloc >>$FULL
|
|
|
|
|
|
|
|
|
|
_log " *** unmounting scratch device"
|
|
|
|
|
|
|
|
|
|
umount $SCRATCH_DEV 2>&1 | _logp \
|
|
|
|
|
|| _fail " !!! failed to umount"
|
|
|
|
|
|
|
|
|
|
let "pass = pass + 1"
|
|
|
|
|
done
|
|
|
|
|
|