X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=adns.git;a=blobdiff_plain;f=regress%2Fr1test;h=d1607824bf702c503347c203d7741c804fd86fa5;hp=0773e6205247f6a40d07a1493d5580c985fbeb5d;hb=58a876e5ac9539ff14acb7dc3ea3633f5bdb41d8;hpb=39196d5f5abd0559b60ea2dcdaa6f37dde9d9fd9 diff --git a/regress/r1test b/regress/r1test index 0773e62..d160782 100755 --- a/regress/r1test +++ b/regress/r1test @@ -1,40 +1,109 @@ #!/bin/sh # usage: r1test +# test execution script, for running one test +# +# This file is part of adns, which is +# Copyright (C) 1997-2000,2003,2006,2014 Ian Jackson +# Copyright (C) 2014 Mark Wooding +# Copyright (C) 1999-2000,2003,2006 Tony Finch +# Copyright (C) 1991 Massachusetts Institute of Technology +# (See the file INSTALL for full details.) +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3, or (at your option) +# any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software Foundation. set -e +: ${srcdir=.} +mrc=1 +trap 'exit $mrc' 0 + casename="$1" -case="case-$casename" +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 -exec <"$case.sys" -read initfile -read queryargs +rm -f $ocase.* -initstring="`cat init-$initfile.text`" +EF_DISABLE_BANNER=1 +export EF_DISABLE_BANNER + +if test -f "$case.in" +then + exec <"$case.in" +else + exec >"$case.report-o" >"$case.stdout-o" 2>"$case.stderr-o" \ - ./hplayback "/$initstring" $queryargs +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 -if test $rc != 0 +if [ "$rc" = 5 ] then - egrep . -- "$case.report-o" "$case.stdout-o" "$case.stderr-o" - echo >&2 "FAILED $case - EXIT STATUS $rc" - exit 2 + printf "SKIPPED-$casename " + mrc=5 + exit fi -for part in stdout stderr +echo "rc=$rc" >>$ocase.out + +failed=false +for part in err out do - if diff -- "$case.$part" "$case.$part-o" + if diff -u -- "$case.$part" "$ocase.$part" then : else - echo >&2 "FAILED $case - WRONG OUTPUT" - exit 2 + failwhy="$failwhy WRONG OUTPUT" fi done -echo -n "$casename " +cat <&4 >"$ocase.leftover" +if egrep . /dev/null "$ocase.leftover" +then + failwhy="$failwhy EXITED EARLY" +fi + +if [ "x$failwhy" != x ] +then + scremain="`wc -l <\"$ocase.leftover\"`" + echo >&2 "FAILED $case -$failwhy - lines of syscall remaining $scremain" + mrc=2 + exit +fi -exit 0 +printf "$casename " +mrc=0