summaryrefslogtreecommitdiff
path: root/tests/trivial-test-driver
blob: 819865ec50a0821c2de4e165b2ba6edd92012bab (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#! /bin/sh
# Copyright (C) 2011-2012 Free Software Foundation, Inc.
#
# 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 2, 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, see <http://www.gnu.org/licenses/>.

#
# Test driver for a very simple test protocol used by the Automake
# testsuite to check support for custom test drivers allowing for more
# test results per test script.
#
# The exit status of the wrapped script is ignored.  Lines in its stdout
# and stderr beginning with `PASS', `FAIL', `XFAIL', `XPASS', `SKIP' or
# `ERROR' count as a test case result with the obviously-corresponding
# outcome.  Every other line is ignored for what concerns the testsuite
# outcome.
#
# This script is used at least by the `driver-custom-multitest*.test'
# tests.
#

# Help to avoid typo-related bugs.
set -u

## Option parsing.

test_name=INVALID.NAME
log_file=BAD.LOG
trs_file=BAD.TRS
while test $# -gt 0; do
  case $1 in
    --test-name) test_name=$2; shift;;
    --log-file) log_file=$2; shift;;
    --trs-file) trs_file=$2; shift;;
    # Ignored.
    --expect-failure) shift;;
    --color-tests) shift;;
    --enable-hard-errors) shift;;
    # Explicitly terminate option list.
    --) shift; break;;
    # Shouldn't happen
    *) echo "$0: invalid option/argument: '$1'" >&2; exit 2;;
  esac
  shift
done

## Log file header.
{
  echo "RUN: $test_name"
  echo "RUN: $test_name" | sed 's/./=/g'
  echo
} > $log_file

## Run the test script, get test cases results, display them on console.

"$@" 2>&1 | tee -a $log_file | (
  i=0 st=0
  exec 5> $trs_file
  while read line; do
    result=
    case $line in
      PASS:*)  result=PASS  ;;
      FAIL:*)  result=FAIL  ;;
      XPASS:*) result=XPASS ;;
      XFAIL:*) result=XFAIL ;;
      SKIP:*)  result=SKIP  ;;
      ERROR:*) result=ERROR ;;
    esac
    if test -n "$result"; then
      case $result in FAIL|XPASS|ERROR) st=1;; esac
      # Output testcase result to console.
      echo "$result: $test_name"
      # Register testcase outcome for the log file.
      echo ":test-result: $line" >&5
      echo >&5
    fi
  done
  if test $st -eq 0; then
    recheck=no
    copy_in_global_log=no
  else
    recheck=yes
    copy_in_global_log=yes
  fi
  echo ":recheck: $recheck" >&5
  echo ":copy-in-global-log: $copy_in_global_log" >&5
  exec 5>&-
) | awk '{ print $0 ", testcase " NR }'

## And we're done.

exit 0