aboutsummaryrefslogtreecommitdiffstats
path: root/soak
blob: d5c4229ad6e79b3a5a381e31f0eff61d10955edb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2000-2002 Silicon Graphics, Inc.  All Rights Reserved.
#

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

tmp=/tmp/$$
seq=soak
status=1	# failure is the default!

_cleanup()
{
    echo "        *** umount"
    _scratch_unmount >/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"

_scratch_unmount 2>&1 >>$FULL

_log "        *** clean scratch device"

mkfs_xfs -f $SCRATCH_DEV 2>&1 >>$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 | \
        >>$FULL

    _log "        *** unmounting scratch device"

    _scratch_unmount 2>&1 | _logp \
                            || _fail "            !!! failed to umount"
    
    let "pass = pass + 1"
done