From: Bruno Haible Date: Tue, 11 Nov 2008 01:28:25 +0000 (+0100) Subject: Don't rely on the contents of stderr of shell commands. X-Git-Tag: v0.1~6698 X-Git-Url: http://erislabs.org.uk/gitweb/?a=commitdiff_plain;h=f0367599e1c6404e41c6ad3cf24d738f058dd1fb;p=gnulib.git Don't rely on the contents of stderr of shell commands. --- diff --git a/ChangeLog b/ChangeLog index 1105e8441..4a57aa3bb 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,12 @@ 2008-11-10 Bruno Haible + * tests/test-select-fd.c (main): Accept the result file name as fourth + argument. + * tests/test-select-in.sh: Pass t-select-in.tmp as fourth argument. + * tests/test-select-out.sh: Pass t-select-out.tmp as fourth argument. + +2008-11-10 Bruno Haible + * lib/netdb.in.h: Use HAVE_STRUCT_ADDRINFO, HAVE_DECL_GETADDRINFO, HAVE_DECL_FREEADDRINFO, HAVE_DECL_GAI_STRERROR, HAVE_DECL_GETNAMEINFO as autoconf-substituted macros. diff --git a/tests/test-select-fd.c b/tests/test-select-fd.c index d362170a8..ddd2013de 100644 --- a/tests/test-select-fd.c +++ b/tests/test-select-fd.c @@ -25,7 +25,7 @@ int main (int argc, char *argv[]) { - if (argc == 3) + if (argc == 4) { char mode = argv[1][0]; @@ -35,32 +35,38 @@ main (int argc, char *argv[]) if (fd >= 0) { - fd_set fds; - struct timeval timeout; - int ret; + const char *result_file_name = argv[3]; + FILE *result_file = fopen (result_file_name, "wb"); - FD_ZERO (&fds); - FD_SET (fd, &fds); - timeout.tv_sec = 0; - timeout.tv_usec = 10000; - ret = (mode == 'r' - ? select (fd + 1, &fds, NULL, NULL, &timeout) - : select (fd + 1, NULL, &fds, NULL, &timeout)); - if (ret < 0) + if (result_file != NULL) { - perror ("select failed"); - exit (1); - } - if ((ret == 0) != ! FD_ISSET (fd, &fds)) - { - fprintf (stderr, "incorrect return value\n"); - exit (1); + fd_set fds; + struct timeval timeout; + int ret; + + FD_ZERO (&fds); + FD_SET (fd, &fds); + timeout.tv_sec = 0; + timeout.tv_usec = 10000; + ret = (mode == 'r' + ? select (fd + 1, &fds, NULL, NULL, &timeout) + : select (fd + 1, NULL, &fds, NULL, &timeout)); + if (ret < 0) + { + perror ("select failed"); + exit (1); + } + if ((ret == 0) != ! FD_ISSET (fd, &fds)) + { + fprintf (stderr, "incorrect return value\n"); + exit (1); + } + fprintf (result_file, "%d\n", ret); + exit (0); } - fprintf (stderr, "%d\n", ret); - exit (0); } } } - fprintf (stderr, "Usage: test-select-fd mode fd\n"); + fprintf (stderr, "Usage: test-select-fd mode fd result-file-name\n"); exit (1); } diff --git a/tests/test-select-in.sh b/tests/test-select-in.sh index b93fee9a0..8fd9d9c45 100755 --- a/tests/test-select-in.sh +++ b/tests/test-select-in.sh @@ -8,20 +8,24 @@ tmpfiles="$tmpfiles t-select-in.tmp" # Regular files. -./test-select-fd${EXEEXT} r 0 < ./test-select-fd${EXEEXT} 2> t-select-in.tmp +rm -f t-select-in.tmp +./test-select-fd${EXEEXT} r 0 t-select-in.tmp < ./test-select-fd${EXEEXT} test `cat t-select-in.tmp` = "1" || exit 1 # Pipes. -{ sleep 1; echo abc; } | ./test-select-fd${EXEEXT} r 0 2> t-select-in.tmp +rm -f t-select-in.tmp +{ sleep 1; echo abc; } | ./test-select-fd${EXEEXT} r 0 t-select-in.tmp test `cat t-select-in.tmp` = "0" || exit 1 -echo abc | { sleep 1; ./test-select-fd${EXEEXT} r 0; } 2> t-select-in.tmp +rm -f t-select-in.tmp +echo abc | { sleep 1; ./test-select-fd${EXEEXT} r 0 t-select-in.tmp; } test `cat t-select-in.tmp` = "1" || exit 1 # Special files. -./test-select-fd${EXEEXT} r 0 < /dev/null 2> t-select-in.tmp +rm -f t-select-in.tmp +./test-select-fd${EXEEXT} r 0 t-select-in.tmp < /dev/null test `cat t-select-in.tmp` = "1" || exit 1 rm -fr $tmpfiles diff --git a/tests/test-select-out.sh b/tests/test-select-out.sh index f83beeb1f..556aae7b4 100755 --- a/tests/test-select-out.sh +++ b/tests/test-select-out.sh @@ -8,20 +8,24 @@ tmpfiles="$tmpfiles t-select-out.out t-select-out.tmp" # Regular files. -./test-select-fd${EXEEXT} w 1 > t-select-out.out 2> t-select-out.tmp +rm -f t-select-out.tmp +./test-select-fd${EXEEXT} w 1 t-select-out.tmp > t-select-out.out test `cat t-select-out.tmp` = "1" || exit 1 # Pipes. -( { echo abc; ./test-select-fd${EXEEXT} w 1; } | { sleep 1; cat; } ) > /dev/null 2> t-select-out.tmp +rm -f t-select-out.tmp +( { echo abc; ./test-select-fd${EXEEXT} w 1 t-select-out.tmp; } | { sleep 1; cat; } ) > /dev/null test `cat t-select-out.tmp` = "0" || exit 1 -( { sleep 1; echo abc; ./test-select-fd${EXEEXT} w 1; } | cat) > /dev/null 2> t-select-out.tmp +rm -f t-select-out.tmp +( { sleep 1; echo abc; ./test-select-fd${EXEEXT} w 1 t-select-out.tmp; } | cat) > /dev/null test `cat t-select-out.tmp` = "1" || exit 1 # Special files. -./test-select-fd${EXEEXT} w 1 > /dev/null 2> t-select-out.tmp +rm -f t-select-out.tmp +./test-select-fd${EXEEXT} w 1 t-select-out.tmp > /dev/null test `cat t-select-out.tmp` = "1" || exit 1 rm -fr $tmpfiles