From: Stefano Lattarini Date: Tue, 14 Jun 2011 07:41:14 +0000 (+0200) Subject: tests: check portable fd redirection in TESTS_ENVIRONMENT X-Git-Tag: ng-0.5a~167 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=ecebc6c22d7edd81372df837677de4bdce363199;p=thirdparty%2Fautomake.git tests: check portable fd redirection in TESTS_ENVIRONMENT * tests/tests-environment-fd-redirect.test: New test. * tests/Makefile.am (TESTS): Update. Motivated by coreutils bug#8846: See also following CC:ed thread on bug-autoconf list: --- diff --git a/ChangeLog b/ChangeLog index aad41c789..e482cbd6e 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,13 @@ +2011-06-14 Stefano Lattarini + + tests: check portable fd redirection in TESTS_ENVIRONMENT + * tests/tests-environment-fd-redirect.test: New test. + * tests/Makefile.am (TESTS): Update. + Motivated by coreutils bug#8846: + + See also following CC:ed thread on bug-autoconf list: + + 2011-06-08 Stefano Lattarini test defs: new function 'fatal_', for hard errors diff --git a/tests/Makefile.am b/tests/Makefile.am index e68f6d70f..c0f39ce5e 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -949,6 +949,7 @@ tar2.test \ tar3.test \ target-cflags.test \ targetclash.test \ +tests-environment-fd-redirect.test \ txinfo.test \ txinfo2.test \ txinfo3.test \ diff --git a/tests/Makefile.in b/tests/Makefile.in index 7e5fd0964..4c223fca8 100644 --- a/tests/Makefile.in +++ b/tests/Makefile.in @@ -1216,6 +1216,7 @@ tar2.test \ tar3.test \ target-cflags.test \ targetclash.test \ +tests-environment-fd-redirect.test \ txinfo.test \ txinfo2.test \ txinfo3.test \ diff --git a/tests/tests-environment-fd-redirect.test b/tests/tests-environment-fd-redirect.test new file mode 100755 index 000000000..f9e6d2bf2 --- /dev/null +++ b/tests/tests-environment-fd-redirect.test @@ -0,0 +1,75 @@ +#! /bin/sh +# Copyright (C) 2011 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 . + +# Test for a behaviour of `TESTS_ENVIRONMENT' and `AM_TESTS_ENVIRONMENT' +# w.r.t. file descriptor redirections which, although undocumented, +# is nonetheless required by Gnulib's 'tests/init.sh' and by coreutils' +# testsuite. +# The checked behaviour is that we can portably do file descriptor +# redirections by placing them at the end of a {AM_,}TESTS_ENVIRONMENT +# definition without a following semicolon. The need to support this +# is detailedly motivated by coreutils bug#8846: +# +# and the following CC:ed thread on bug-autoconf list: +# + +parallel_tests=yes +. ./defs || Exit 1 + +cat >> configure.in << 'END' +AC_OUTPUT +END + +cat >foo.test <<'END' +#! /bin/sh +echo " " $0: foofoofoo >&8 +echo " " $0: barbarbar >&9 +END +chmod a+x foo.test + +$ACLOCAL +$AUTOCONF + +# /bin/ksh seems more vulnerable to the issue highlighted in coreutils +# bug#8846 than other shells are. In particular, the default Korn Shell +# on Debian GNU/Linux is affected by the issue. So let's try to run our +# test with /bin/ksh too, if that's available. +if test "$SHELL" != /bin/ksh && test -f /bin/ksh; then + bin_ksh=/bin/ksh +else + bin_ksh=: +fi + +for sh in "$SHELL" "$bin_ksh"; do + test "$sh" = : && continue + for pfx in AM_ ''; do + unindent > Makefile.am <&1 9>&8 +END + $AUTOMAKE -a + CONFIG_SHELL="$sh" $sh ./configure CONFIG_SHELL="$sh" + $MAKE check >stdout || { cat stdout; Exit 1; } + cat stdout + grep '[ /]foo\.test: foofoofoo$' stdout + grep '[ /]foo\.test: barbarbar$' stdout + $EGREP '(foofoofoo|barbarbar)' foo.log && Exit 1 + : # For shells with buggy 'set -e'. + done +done + +: