Whamcloud - gitweb
LU-13019 tests: replace usleep in test scripts
[fs/lustre-release.git] / lustre / tests / run_IOR.sh
1 #!/bin/bash
2
3 TMP=${TMP:-/tmp}
4
5 TESTLOG_PREFIX=${TESTLOG_PREFIX:-$TMP/recovery-mds-scale}
6 TESTNAME=${TESTNAME:-""}
7 [ -n "$TESTNAME" ] && TESTLOG_PREFIX=$TESTLOG_PREFIX.$TESTNAME
8
9 LOG=$TESTLOG_PREFIX.$(basename $0 .sh)_stdout.$(hostname -s).log
10 DEBUGLOG=$(echo $LOG | sed 's/\(.*\)stdout/\1debug/')
11
12 mkdir -p ${LOG%/*}
13
14 rm -f $LOG $DEBUGLOG
15 exec 2>$DEBUGLOG
16 set -x
17
18 . $(dirname $0)/functions.sh
19
20 IOR=${IOR:-"$(which IOR)"}
21
22 assert_env MOUNT END_RUN_FILE LOAD_PID_FILE IOR
23
24 trap signaled TERM
25
26 # if MACHINEFILE set and exists -- use it
27 if [ -z $MACHINEFILE ] || [ ! -e $MACHINEFILE ]; then
28     MACHINEFILE=$TMP/$(basename $0)-$(hostname).machines
29     echo $(hostname) >$MACHINEFILE
30 fi
31
32 THREADS_PER_CLIENT=${THREADS_PER_CLIENT:-3}
33 NUM_CLIENTS=$(cat $MACHINEFILE | wc -l)
34
35 # recovery-*-scale scripts use this to signal the client loads to die
36 echo $$ >$LOAD_PID_FILE
37
38 TESTDIR=${TESTDIR:-$MOUNT/d0.ior-$(hostname)}
39
40 CONTINUE=true
41 while [ ! -e "$END_RUN_FILE" ] && $CONTINUE; do
42         echoerr "$(date +'%F %H:%M:%S'): IOR run starting"
43         mkdir -p $TESTDIR
44         # need this only if TESTDIR is not default
45         chmod -R 777 $TESTDIR
46
47         sync
48
49         run_ior fpp $TESTDIR  1>$LOG &
50
51         load_pid=$!
52         wait $load_pid
53         if [ ${PIPESTATUS[0]} -eq 0 ]; then
54                 echoerr "$(date +'%F %H:%M:%S'): IOR succeeded"
55                 cd $TMP
56                 rm -rf $TESTDIR
57                 echoerr "$(date +'%F %H:%M:%S'): IOR run finished"
58         else
59                 echoerr "$(date +'%F %H:%M:%S'): IOR failed"
60                 if [ -z "$ERRORS_OK" ]; then
61                         echo $(hostname) >> $END_RUN_FILE
62                 fi
63                 if [ $BREAK_ON_ERROR ]; then
64                         # break
65                         CONTINUE=false
66                 fi
67         fi
68 done
69
70 echoerr "$(date +'%F %H:%M:%S'): IOR run exiting"