mirror of
https://github.com/linux-apfs/apfstests.git
synced 2026-05-01 15:01:44 -07:00
0925cbea74
Back many years ago, the owner field was used to email the test owner when auto-qa failed that test. It is not needed anymore - if you want to know who wrote the test, look it up in git.... Script used was: $ sed -i -e "/^# creator/d" -e "/^owner/d" [0-3][0-9][0-9] Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Phil White <pwhite@sgi.com> [rjohnston@sgi.com added TOT changes] Signed-off-by: Rich Johnston <rjohnston@sgi.com>
137 lines
3.0 KiB
Bash
Executable File
137 lines
3.0 KiB
Bash
Executable File
#!/bin/bash
|
|
#-----------------------------------------------------------------------
|
|
# 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 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
|
|
#
|
|
#-----------------------------------------------------------------------
|
|
#
|
|
|
|
# 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"
|
|
|
|
mkfs_xfs -f $SCRATCH_DEV 2>&1 | _fix_malloc >>$FULL \
|
|
|| _fail " !!! failed to mkfs SCRATCH_DEV"
|
|
|
|
pass=1
|
|
|
|
while [ $pass -le $passes -o $passes -lt 0 ]
|
|
do
|
|
_log " *** pass $pass (`date`)"
|
|
|
|
_log " *** check"
|
|
_check_scratch_fs
|
|
|
|
_log " *** mounting scratch device"
|
|
|
|
if ! _scratch_mount 2>&1 | _logp
|
|
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"
|
|
_check_scratch_fs
|
|
fi
|
|
|
|
_log " *** mkdir"
|
|
mkdir $SCRATCH_MNT/soak_test \
|
|
|| _fail " !!! couldn't delete old dir"
|
|
|
|
_log " *** stress"
|
|
ltp/fsstress -d $SCRATCH_MNT/soak_test -p $proc -n $stress $FSSTRESS_AVOID 2>&1 | \
|
|
_fix_malloc >>$FULL
|
|
|
|
_log " *** unmounting scratch device"
|
|
|
|
umount $SCRATCH_DEV 2>&1 | _logp \
|
|
|| _fail " !!! failed to umount"
|
|
|
|
let "pass = pass + 1"
|
|
done
|
|
|