diff options
author | Albert Cheng <acheng@hdfgroup.org> | 2001-02-05 04:36:30 (GMT) |
---|---|---|
committer | Albert Cheng <acheng@hdfgroup.org> | 2001-02-05 04:36:30 (GMT) |
commit | e80c106497cfacb0f87d5c8a26358ee165143937 (patch) | |
tree | 81ec6e07628da66214803955b3a119dd9662195d /bin/runtest | |
parent | 5fa7f93263e18ec0bf63c0d4cff5ba310c768205 (diff) | |
download | hdf5-e80c106497cfacb0f87d5c8a26358ee165143937.zip hdf5-e80c106497cfacb0f87d5c8a26358ee165143937.tar.gz hdf5-e80c106497cfacb0f87d5c8a26358ee165143937.tar.bz2 |
[svn-r3348] Purpose:
new feature
Description:
It now reads a configuration file ($HOME/snapshots-hdf5/snaptest.cfg)
to set up the configure options of the tests, and what type of tests
to run for each host.
Platforms tested:
Eirene launched a full blown test on all machines involved in the
daily test.
Diffstat (limited to 'bin/runtest')
-rwxr-xr-x | bin/runtest | 90 |
1 files changed, 58 insertions, 32 deletions
diff --git a/bin/runtest b/bin/runtest index 2345b09..e9e8098 100755 --- a/bin/runtest +++ b/bin/runtest @@ -277,25 +277,56 @@ RUNSNAPTEST() } -# Snap Test configuration parsing -SNAPTEST_CONFIG() +# Record a type of test requested. Separate new request from +# existing requests by a semicolon (;). +# $1 is the type of test requested +ADD_TEST_TYPE() +{ +echo TEST_TYPES=$TEST_TYPES +} + +# configuration parsing. +# Taking configuration from input. +# This should be invoke with configure file as stdin. +SNAPTEST_CONFIG_PARSE() { - if [ ! -f $SNAPTESTCFG ]; then - return - fi while read x y ; do case "$x" in - '#') # comment. Continue. + '#'*) + # comment. Continue. ;; - standard) #standard configuration + standard) + #standard configuration STANDARD_OPT="$y" ;; - *) # unknown configuration option + all: | ${HOSTNAME}:) + # types of test for all hosts or this host + if [ -n "$TEST_TYPES" ]; then + TEST_TYPES="$TEST_TYPES ; $y" + else + TEST_TYPES="$y" + fi + ;; + *:) # ignore types of test for other hosts + ;; + *) # unknown configuration option echo $x $y echo "***Unknown configuration option. Ignored.***" ;; esac - done < $SNAPTESTCFG + done +} + +# Snap Test configuration parsing. +# If TEST_TYPES is not set, set it to do the "standard" test. +SNAPTEST_CONFIG() +{ + TEST_TYPES= + STANDARD_OPT= + if [ -f $SNAPTESTCFG ]; then + SNAPTEST_CONFIG_PARSE < $SNAPTESTCFG + fi + TEST_TYPES=${TEST_TYPES:-'standard'} } @@ -367,6 +398,8 @@ StartTime=`SecOfDay` # Process the configuration SNAPTEST_CONFIG +echo STANDARD_OPT=$STANDARD_OPT +echo TEST_TYPES=$TEST_TYPES # Do a checkout if one has not been done today # Also check MANIFEST file @@ -424,32 +457,25 @@ if [ -n "$TESTHOST" -a $HOSTNAME != "$TESTHOST" ]; then exit 0 fi -# Running the standard test in this host. -RUNSNAPTEST standard -REPORT_RESULT -PRINT_TRAILER - -# -# Running the parallel test if this is parallel host too -if ( echo $PARALLELHOST | grep -s $HOSTNAME > /dev/null ) then - RUNSNAPTEST parallel +# run the test(s) +# Note that first field is cut without -s but all subsequent cut +# must use -s. If -s is not used at all, a $TEST_TYPES that has +# no ';' (only 1 test), will pass through intact in all cut. That +# results in infinite looping. +# If -s is used with the first field, it will suppress completely +# a $TYPE_TYPES that has no ';' (only 1 tst ). That results in no +# test at all. +# +n_test=1 +TEST="`echo $TEST_TYPES | cut -f1 -d';'`" +while [ -n "$TEST" ]; do + RUNSNAPTEST $TEST REPORT_RESULT PRINT_TRAILER -fi -# -# If this is modi4, run -n32 tests too. -if [ $HOSTNAME = modi4 ]; then - # - # Serial test - RUNSNAPTEST -n32 standard - REPORT_RESULT - PRINT_TRAILER - # parallel test - RUNSNAPTEST -n32 parallel - REPORT_RESULT - PRINT_TRAILER -fi + n_test=`expr $n_test + 1` + TEST="`echo $TEST_TYPES | cut -f$n_test -s -d';'`" +done FLUSH_FILES |