chiark / gitweb /
regress: Break out some functions from r1test into a new file
authorIan Jackson <ijackson@chiark.greenend.org.uk>
Sat, 19 Nov 2016 18:02:56 +0000 (18:02 +0000)
committerIan Jackson <ijackson@chiark.greenend.org.uk>
Thu, 11 Jun 2020 15:13:02 +0000 (16:13 +0100)
We are going to want to reuse some of this logic for parsing case-*.sys
files.

Signed-off-by: Ian Jackson <ijackson@chiark.greenend.org.uk>
regress/r1test
regress/shlib [new file with mode: 0644]

index bd5209282c8bd503cf5a71c6642eb5a00c969cd9..74d7df2a9ce35b3ce63f319633d2a86f69141911 100755 (executable)
 
 set -e
 : ${srcdir=.}
+. "$srcdir"/shlib
 mrc=1
 trap 'exit $mrc' 0
 
 casename="$1"
-case="$srcdir/case-$casename"
-ocase="output-$casename"
 
-exec 4<"$case.sys"
-read <&4 program initfile initflags
-read <&4 queryargs
-
-initstring="`cat $srcdir/init-$initfile.text`"
-xinitflagsf=$srcdir/$program-xinitflags.text
-if test -f $xinitflagsf
-then
-       initflags="$initflags `cat $xinitflagsf`";
-else
-       initflags="$initflags /"
-fi
+playback_prepare
 
 rm -f $ocase.*
 
@@ -56,7 +44,6 @@ else
        exec </dev/null
 fi
 
-playback=./${program}_playback
 if test ! -e $playback
 then
        printf "SKIPPED-$casename "
@@ -64,12 +51,15 @@ then
        exit
 fi
 
-set +e
-ADNS_TEST_REPORT_FD=3 ADNS_TEST_IN_FD=4 \
- 3>>"$ocase.report" 4<&4 >"$ocase.out" 2>"$ocase.err" \
- $ADNS_TEST_DEBUG $playback $initflags"$initstring" $queryargs
-rc=$?
-set -e
+playback_execute_callback () {
+       set +e
+       ADNS_TEST_REPORT_FD=3 ADNS_TEST_IN_FD=4 \
+        3>>"$ocase.report" 4<&4 >"$ocase.out" 2>"$ocase.err" \
+        $ADNS_TEST_DEBUG $playback "$@"
+       rc=$?
+       set -e
+}
+playback_execute
 
 if [ "$rc" = 5 ]
 then
diff --git a/regress/shlib b/regress/shlib
new file mode 100644 (file)
index 0000000..3aadb9f
--- /dev/null
@@ -0,0 +1,25 @@
+# -*- shell -*-
+
+playback_prepare () {
+       case="$srcdir/case-$casename"
+       ocase="output-$casename"
+
+       exec 4<"$case.sys"
+       read <&4 program initfile initflags
+       read <&4 queryargs
+
+       initstring="`cat $srcdir/init-$initfile.text`"
+       xinitflagsf=$srcdir/$program-xinitflags.text
+       if test -f $xinitflagsf
+       then
+               initflags="$initflags `cat $xinitflagsf`";
+       else
+               initflags="$initflags /"
+       fi
+
+       playback=./${program}_playback
+}
+
+playback_execute () {
+       playback_execute_callback $initflags"$initstring" $queryargs
+}