Hash :
c8db74fc
Author :
Date :
2007-11-08T22:32:15
Implement colorized test output. * automake.in (handle_tests): Set COLOR depending on `color-tests'. * configure.ac (AM_INIT_AUTOMAKE): Use `color-tests'. * doc/automake.texi (Tests, Options): Document test results, document new option, document AM_COLOR_TESTS. * lib/Automake/Options.pm (_process_option_list): Handle it. * lib/am/check.am (am__tty_colors): New variable. Enable colored output if TERM is not dumb and depending on AM_COLOR_TESTS and whether stdout is connected to a terminal. (check-TESTS): Use am__tty_colors. * NEWS: Mention color-tests. * tests/color.test: New test. * tests/Makefile.am: Adjust.
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 103 104
#! /bin/sh
# Copyright (C) 2007 Free Software Foundation, Inc.
#
# This file is part of GNU Automake.
#
# GNU Automake 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.
#
# GNU Automake 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 Automake; see the file COPYING. If not, write to
# the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
# Boston, MA 02110-1301, USA.
# Test Automake TESTS color output.
. ./defs || exit 1
set -e
red='[0;31m'
grn='[0;32m'
lgn='[1;32m'
blu='[1;34m'
std='[m'
cat >>configure.in <<END
AC_OUTPUT
END
cat >Makefile.am <<'END'
AUTOMAKE_OPTIONS = color-tests
TESTS = $(check_SCRIPTS)
check_SCRIPTS = pass fail skip xpass xfail
XFAIL_TESTS = xpass xfail
END
cat >pass <<END
#! /bin/sh
exit 0
END
cat >fail <<END
#! /bin/sh
exit 1
END
cat >skip <<END
#! /bin/sh
exit 77
END
cp fail xfail
cp pass xpass
chmod +x pass fail skip xpass xfail
$ACLOCAL
$AUTOMAKE
$AUTOCONF
./configure
test_color ()
{
grep ": pass" stdout | $FGREP "$grn"
grep ": fail" stdout | $FGREP "$red"
grep ": xfail" stdout | $FGREP "$lgn"
grep ": xpass" stdout | $FGREP "$red"
grep ": skip" stdout | $FGREP "$blu"
}
test_no_color ()
{
grep ": pass" stdout | $FGREP "$grn" && exit 1
grep ": fail" stdout | $FGREP "$red" && exit 1
grep ": xfail" stdout | $FGREP "$lgn" && exit 1
grep ": xpass" stdout | $FGREP "$red" && exit 1
grep ": skip" stdout | $FGREP "$blu" && exit 1
:
}
cat >expect-make <<'END'
#! /usr/bin/expect -f
spawn $env(MAKE) check $argv
expect eof
END
$MAKE check AM_COLOR_TESTS=always >stdout && { cat stdout; exit 1; }
cat stdout
test_color
MAKE=$MAKE expect -f expect-make foo= >stdout || exit 77
cat stdout
test_color
MAKE=$MAKE expect -f expect-make AM_COLOR_TESTS=no >stdout || exit 77
cat stdout
test_no_color
: