X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=tests%2Ftest-freading.c;h=1a38b9e44e7b48e1b68bceaefdb7a3302c6ba951;hb=9faed5de047d34fddbd4cddbfee73d1fbcea5e32;hp=e51d7ab184310442c74cde661984e13a0fc6d77f;hpb=503e2514a1404a19a00117845216993a3c2ccf5f;p=gnulib.git diff --git a/tests/test-freading.c b/tests/test-freading.c index e51d7ab18..1a38b9e44 100644 --- a/tests/test-freading.c +++ b/tests/test-freading.c @@ -21,9 +21,19 @@ #include "freading.h" +#include #include -#define ASSERT(expr) if (!(expr)) abort (); +#define ASSERT(expr) \ + do \ + { \ + if (!(expr)) \ + { \ + fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \ + abort (); \ + } \ + } \ + while (0) #define TESTFILE "t-freading.tmp" @@ -73,6 +83,7 @@ main () freading is only deterministic after input or output, but this test case should be portable even on open, after reposition, and at EOF. */ + /* First a scenario with only fgetc, fseek, fputc. */ fp = fopen (TESTFILE, "r+"); if (fp == NULL) goto skip; @@ -91,12 +102,14 @@ main () if (fseek (fp, 0, SEEK_CUR) != 0) goto skip; /* freading (fp) is undefined here, but fwriting (fp) is false. */ - if (fputc ('z', fp) != 'z') + if (fputc ('x', fp) != 'x') goto skip; ASSERT (!freading (fp)); if (fseek (fp, 0, SEEK_END)) goto skip; - ASSERT (!freading (fp)); + /* freading (fp) is undefined here, because on some implementations (e.g. + glibc) fseek causes a buffer to be read. + fwriting (fp) is undefined as well. */ if (fclose (fp)) goto skip; @@ -105,6 +118,7 @@ main () freading is only deterministic after input or output, but this test case should be portable even on open, after reposition, and at EOF. */ + /* Here a scenario that includes fflush. */ fp = fopen (TESTFILE, "r+"); if (fp == NULL) goto skip; @@ -120,7 +134,7 @@ main () ASSERT (freading (fp)); fflush (fp); /* freading (fp) is undefined here, but fwriting (fp) is false. */ - if (fgetc (fp) != 'a') + if (fgetc (fp) != 'x') goto skip; ASSERT (freading (fp)); /* This fseek call is necessary when switching from reading to writing. @@ -133,7 +147,9 @@ main () ASSERT (!freading (fp)); if (fseek (fp, 0, SEEK_END)) goto skip; - ASSERT (!freading (fp)); + /* freading (fp) is undefined here, because on some implementations (e.g. + glibc) fseek causes a buffer to be read. + fwriting (fp) is undefined as well. */ if (fclose (fp)) goto skip;