xref: /freebsd/tools/test/stress2/run.sh (revision 8a272653d9fbd9fc37691c9aad6a05089b4ecb4d)
1*8a272653SPeter Holm#!/bin/sh
2*8a272653SPeter Holm
3*8a272653SPeter Holm#
4*8a272653SPeter Holm# Copyright (c) 2008 Peter Holm <pho@FreeBSD.org>
5*8a272653SPeter Holm# All rights reserved.
6*8a272653SPeter Holm#
7*8a272653SPeter Holm# Redistribution and use in source and binary forms, with or without
8*8a272653SPeter Holm# modification, are permitted provided that the following conditions
9*8a272653SPeter Holm# are met:
10*8a272653SPeter Holm# 1. Redistributions of source code must retain the above copyright
11*8a272653SPeter Holm#    notice, this list of conditions and the following disclaimer.
12*8a272653SPeter Holm# 2. Redistributions in binary form must reproduce the above copyright
13*8a272653SPeter Holm#    notice, this list of conditions and the following disclaimer in the
14*8a272653SPeter Holm#    documentation and/or other materials provided with the distribution.
15*8a272653SPeter Holm#
16*8a272653SPeter Holm# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17*8a272653SPeter Holm# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*8a272653SPeter Holm# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*8a272653SPeter Holm# ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20*8a272653SPeter Holm# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21*8a272653SPeter Holm# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22*8a272653SPeter Holm# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23*8a272653SPeter Holm# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24*8a272653SPeter Holm# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25*8a272653SPeter Holm# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26*8a272653SPeter Holm# SUCH DAMAGE.
27*8a272653SPeter Holm#
28*8a272653SPeter Holm
29*8a272653SPeter Holm# Run 1) with no argument: the default test cases
30*8a272653SPeter Holm#     2) with the "-a" arguments all the *.cfg test variations
31*8a272653SPeter Holm#     3) with one argument: that specific test case
32*8a272653SPeter Holm
33*8a272653SPeter Holmwhile getopts a name; do
34*8a272653SPeter Holm   case $name in
35*8a272653SPeter Holm   a) aflag=1;;
36*8a272653SPeter Holm   ?) printf "Usage: %s: [-a] [arg]\n" $0
37*8a272653SPeter Holm      exit 2;;
38*8a272653SPeter Holm   esac
39*8a272653SPeter Holmdone
40*8a272653SPeter Holmshift $(($OPTIND - 1))
41*8a272653SPeter Holm
42*8a272653SPeter Holm[ -x ./testcases/run/run ] ||
43*8a272653SPeter Holm    { echo "Please run \"make\" first." && exit 1; }
44*8a272653SPeter Holm[ `basename ${stress2origin:-X}` != misc ] &&
45*8a272653SPeter Holm    echo "Note: all.sh in stress2/misc is the preferred test to run." \
46*8a272653SPeter Holm    1>&2
47*8a272653SPeter Holmfind ./testcases -perm -1 \( -name "*.debug" -o -name "*.full" \) -delete \
48*8a272653SPeter Holm    2>/dev/null
49*8a272653SPeter Holmif [ ! -z "$aflag" ]; then
50*8a272653SPeter Holm   . ./default.cfg
51*8a272653SPeter Holm   export runRUNTIME=5m
52*8a272653SPeter Holm   t1=`date '+%s'`
53*8a272653SPeter Holm   while true;do
54*8a272653SPeter Holm      for i in `ls *.cfg | grep -v default`; do
55*8a272653SPeter Holm         t2=`date '+%s'`
56*8a272653SPeter Holm         e=` date -u -j -f '%s' '+%T' $((t2 - t1))`
57*8a272653SPeter Holm         echo "`date '+%Y%m%d %T'` $i, elapsed $e"
58*8a272653SPeter Holm         echo "`date '+%Y%m%d %T'` $i, elapsed $e" >> /tmp/all.log
59*8a272653SPeter Holm         logger "Starting test $i"
60*8a272653SPeter Holm         [ -w /dev/console ] &&
61*8a272653SPeter Holm            printf "`date '+%Y%m%d %T'` run $i\r\n" > /dev/console
62*8a272653SPeter Holm         $0 $i
63*8a272653SPeter Holm      done
64*8a272653SPeter Holm   done
65*8a272653SPeter Holmelse
66*8a272653SPeter Holm   CONFIG=./default.cfg
67*8a272653SPeter Holm   if [ $# -eq 1 ]; then
68*8a272653SPeter Holm      [ ! -r $1 ] && echo "$0: $1 not found!" && exit 1
69*8a272653SPeter Holm      CONFIG=$1
70*8a272653SPeter Holm   fi
71*8a272653SPeter Holm   . $CONFIG
72*8a272653SPeter Holm
73*8a272653SPeter Holm   [ -z "$RUNDIR" ] && echo "$0: RUNDIR is unset!" && exit 1
74*8a272653SPeter Holm   [ `basename $RUNDIR` != stressX ] && \
75*8a272653SPeter Holm      echo "$0: Basename of RUNDIR must be stressX!" && exit 2
76*8a272653SPeter Holm   [ -d "$RUNDIR" ] && (cd $RUNDIR && find . -delete)
77*8a272653SPeter Holm
78*8a272653SPeter Holm   [ -z "$EXCLUDETESTS" ] && EXCLUDETESTS=DuMmY
79*8a272653SPeter Holm
80*8a272653SPeter Holm   [ -z "$TESTPROGS" ] && \
81*8a272653SPeter Holm      TESTPROGS=`find testcases/ -perm -1 -type f | \
82*8a272653SPeter Holm          egrep -v "/run/|$EXCLUDETESTS|\.full|\.debug"`
83*8a272653SPeter Holm   ./testcases/run/run $TESTPROGS
84*8a272653SPeter Holmfi
85