* tests/test-pread.c (main): Test for failure, too.
* tests/test-pread.sh: Invoke with stdin on a pipe.
Suggested by Eric Blake.
2009-11-25 Jim Meyering <meyering@redhat.com>
+ test-pread: cover failure with ESPIPE and EINVAL
+ * tests/test-pread.c (main): Test for failure, too.
+ * tests/test-pread.sh: Invoke with stdin on a pipe.
+ Suggested by Eric Blake.
+
pread: improvement and fix
* modules/pread (Depends-on): Depend on lseek, for portability to
e.g., mingw. Suggested by Eric Blake.
#include <stdlib.h>
#include <sys/types.h>
#include <fcntl.h>
+#include <errno.h>
#define ASSERT(expr) \
do \
}
}
+ {
+ /* Invalid offset must evoke failure with EINVAL. */
+ char byte;
+ ASSERT (pread (fd, &byte, 1, (off_t) -1) == -1);
+ ASSERT (errno == EINVAL);
+ }
+
ASSERT (close (fd) == 0);
+ {
+ char byte;
+ /* Trying to operate on a pipe must evoke failure with ESPIPE.
+ This assumes that stdin is a pipe, and hence not seekable. */
+ ASSERT (pread (STDIN_FILENO, &byte, 1, 1) == -1);
+ ASSERT (errno == ESPIPE);
+ }
+
return 0;
}
. $srcdir/init.sh --set-path=.
fail=0;
-test-pread || fail=1
+echo abc | test-pread || fail=1
Exit $fail