diff options
author | Siddhesh Poyarekar <siddhesh@redhat.com> | 2012-12-06 11:10:18 +0530 |
---|---|---|
committer | Siddhesh Poyarekar <siddhesh@redhat.com> | 2012-12-06 11:10:18 +0530 |
commit | 7728c57488f3d75c6c2865ef36eae262daf8947a (patch) | |
tree | cccb0785afa177acd0f458d044daade6f9660009 | |
parent | 17aa0516c859f3130f2339cc75c6d89a3f30161c (diff) | |
download | glibc-7728c57488f3d75c6c2865ef36eae262daf8947a.zip glibc-7728c57488f3d75c6c2865ef36eae262daf8947a.tar.gz glibc-7728c57488f3d75c6c2865ef36eae262daf8947a.tar.bz2 |
Add newline to last test in stdio-common/tst-put-error.c
The newline ensures that the buffer is flushed and the test executes
as expected.
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | stdio-common/tst-put-error.c | 12 |
2 files changed, 16 insertions, 1 deletions
@@ -1,3 +1,8 @@ +2012-12-06 Siddhesh Poyarekar <siddhesh@redhat.com> + + * stdio-common/tst-put-error.c (do_test): Add newline to the + padded test to ensure flush. + 2012-12-05 Jeff Law <law@redhat.com> * sunrpc/etc.rpc (fedfs_admin): Add entry. diff --git a/stdio-common/tst-put-error.c b/stdio-common/tst-put-error.c index 5209cce..71c1103 100644 --- a/stdio-common/tst-put-error.c +++ b/stdio-common/tst-put-error.c @@ -34,20 +34,30 @@ do_test (void) FILE *fp = fdopen (fd, "w"); if (fp == NULL) error (EXIT_FAILURE, errno, "fdopen"); + + /* All of the tests below verify that flushing buffers result in failure of + the fprintf calls. We ensure that the buffer is flushed at the end of + each fprintf call by doing two things - setting the file pointer to + line-buffered so that it is flushed whenever it encounters a newline and + then ensuring that there is a newline in each of the format strings we + pass to fprintf. */ + setlinebuf (fp); close (fd); unlink (tmpl); + int n = fprintf (fp, "hello world\n"); printf ("fprintf = %d\n", n); if (n >= 0) error (EXIT_FAILURE, 0, "first fprintf succeeded"); + n = fprintf (fp, "hello world\n"); printf ("fprintf = %d\n", n); if (n >= 0) error (EXIT_FAILURE, 0, "second fprintf succeeded"); /* Padded printing takes a different code path. */ - n = fprintf (fp, "%10000000s", "foo"); + n = fprintf (fp, "%100s\n", "foo"); printf ("fprintf = %d\n", n); if (n >= 0) error (EXIT_FAILURE, 0, "padded fprintf succeeded"); |