changeset 9734:80e0e25c2220

More tests for freadptr.
author Bruno Haible <bruno@clisp.org>
date Fri, 29 Feb 2008 01:08:18 +0100
parents 969f2ce575c5
children cc334325e69d
files ChangeLog tests/test-freadptr.c tests/test-freadptr.sh
diffstat 3 files changed, 71 insertions(+), 5 deletions(-) [+]
line wrap: on
line diff
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2008-02-28  Bruno Haible  <bruno@clisp.org>
+
+	* tests/test-freadptr.c: Add a test for behaviour after ungetc.
+	* tests/test-freadptr.sh: Also test non-seekable stdin.
+
 2008-02-28  Sergey Poznyakoff  <gray@gnu.org.ua>
 
 	* build-aux/bootstrap (source_base, m4_base)
@@ -5,7 +10,6 @@
 	(gnulib_tool_options): Do not hardcode base directories, use
 	the above variables instead.
 
-
 2008-02-28  Atsushi SAKAI  <sakaia@jp.fujitsu.com>
 
 	* lib/xsize.h: Fix typo in comment: s/tupe/type/.
--- a/tests/test-freadptr.c
+++ b/tests/test-freadptr.c
@@ -47,18 +47,79 @@
 
   if (lseek (0, 0, SEEK_CUR) == nbytes)
     /* An unbuffered stdio, such as BeOS or on uClibc compiled without
-       __STDIO_BUFFERS.  */
+       __STDIO_BUFFERS.  Or stdin is a pipe.  */
     ASSERT (freadahead (stdin) == 0);
   else
     {
       /* Normal buffered stdio.  */
       const char stdin_contents[] =
-	"#!/bin/sh\n\n./test-freadptr${EXEEXT} 5 < \"$srcdir/test-freadptr.sh\" || exit 1\nexit 0\n";
+	"#!/bin/sh\n\n./test-freadptr${EXEEXT} 5 < \"$srcdir/test-freadptr.sh\" || exit 1\ncat \"$srcdir/test-freadptr.sh\" | ./test-freadptr${EXEEXT} 5 || exit 1\nexit 0\n";
       const char *expected = stdin_contents + nbytes;
-      size_t available = freadahead (stdin);
+      size_t available;
+      size_t available2;
+      size_t available3;
+
+      /* Test normal behaviour.  */
+      available = freadahead (stdin);
       ASSERT (available != 0);
       ASSERT (available <= strlen (expected));
-      ASSERT (memcmp (freadptr (stdin), expected, available) == 0);
+      {
+	const char *ptr = freadptr (stdin);
+
+	ASSERT (ptr != NULL);
+	ASSERT (memcmp (ptr, expected, available) == 0);
+      }
+
+      /* Test behaviour after normal ungetc.  */
+      ungetc (fgetc (stdin), stdin);
+      available2 = freadahead (stdin);
+      ASSERT (/* available2 == available - 1 || */ available2 == available);
+#if 0
+      if (available2 == available - 1)
+	{
+	  ASSERT (freadptr (stdin) == NULL);
+	}
+      else
+#endif
+	{
+	  const char *ptr = freadptr (stdin);
+
+	  ASSERT (ptr != NULL);
+	  ASSERT (memcmp (ptr, expected, available) == 0);
+	}
+
+      /* Test behaviour after arbitrary ungetc.  */
+      fgetc (stdin);
+      ungetc ('@', stdin);
+      available3 = freadahead (stdin);
+      ASSERT (available3 == 0 || available3 == 1 || /* available3 == available - 1 || */ available3 == available);
+      if (available3 == 0)
+	;
+      else if (available3 == 1)
+	{
+	  const char *ptr = freadptr (stdin);
+
+	  if (ptr != NULL)
+	    {
+	      ASSERT (ptr[0] == '@');
+	    }
+	}
+#if 0
+      else if (available3 == available - 1)
+	{
+	  ASSERT (freadptr (stdin) == NULL);
+	}
+#endif
+      else
+	{
+	  const char *ptr = freadptr (stdin);
+
+	  if (ptr != NULL)
+	    {
+	      ASSERT (ptr[0] == '@');
+	      ASSERT (memcmp (ptr + 1, expected + 1, available - 1) == 0);
+	    }
+	}
     }
 
   return 0;
--- a/tests/test-freadptr.sh
+++ b/tests/test-freadptr.sh
@@ -1,4 +1,5 @@
 #!/bin/sh
 
 ./test-freadptr${EXEEXT} 5 < "$srcdir/test-freadptr.sh" || exit 1
+cat "$srcdir/test-freadptr.sh" | ./test-freadptr${EXEEXT} 5 || exit 1
 exit 0