# HG changeset patch # User Jim Meyering # Date 1259169995 -3600 # Node ID 6fe970af0447a030c8f3a0131f59bdb90790d92c # Parent 7d728682ee08139b5e469391f395aa3ceb4e10b9 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. diff --git a/ChangeLog b/ChangeLog --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,10 @@ 2009-11-25 Jim Meyering + 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. diff --git a/tests/test-pread.c b/tests/test-pread.c --- a/tests/test-pread.c +++ b/tests/test-pread.c @@ -24,6 +24,7 @@ #include #include #include +#include #define ASSERT(expr) \ do \ @@ -72,7 +73,22 @@ } } + { + /* 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; } diff --git a/tests/test-pread.sh b/tests/test-pread.sh --- a/tests/test-pread.sh +++ b/tests/test-pread.sh @@ -3,6 +3,6 @@ . $srcdir/init.sh --set-path=. fail=0; -test-pread || fail=1 +echo abc | test-pread || fail=1 Exit $fail