projects
/
gnulib.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Use a slightly cleaner hack on BSD systems.
[gnulib.git]
/
tests
/
test-freading.c
diff --git
a/tests/test-freading.c
b/tests/test-freading.c
index
e51d7ab
..
1a38b9e
100644
(file)
--- a/
tests/test-freading.c
+++ b/
tests/test-freading.c
@@
-21,9
+21,19
@@
#include "freading.h"
#include "freading.h"
+#include <stdio.h>
#include <stdlib.h>
#include <stdlib.h>
-#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"
#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. */
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;
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 (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;
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;
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. */
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;
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. */
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.
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));
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;
if (fclose (fp))
goto skip;