From: Bruno Haible Date: Sat, 24 Mar 2007 22:08:14 +0000 (+0000) Subject: Produce no output in expected situations. Fail in unexpected situations. X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=9c9ede9d21a19d835107ecb5152e499d4e95b60d;p=pspp Produce no output in expected situations. Fail in unexpected situations. --- diff --git a/ChangeLog b/ChangeLog index cd9a160856..c3cc634da9 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2007-03-24 Bruno Haible + + * tests/test-read-file.c (main): Don't produce spurious output for + expected situations. Make the test fail if it encountered unexpected + results. + 2007-03-24 Bruno Haible * m4/locale-fr.m4 (gt_LOCALE_FR): Remove the special-casing of NetBSD, diff --git a/tests/test-read-file.c b/tests/test-read-file.c index d163b60280..423b19e3a8 100644 --- a/tests/test-read-file.c +++ b/tests/test-read-file.c @@ -25,6 +25,7 @@ #include #include +#include #define FILE1 "/etc/resolv.conf" #define FILE2 "/dev/null" @@ -32,35 +33,69 @@ int main (void) { - { - size_t len; - char *out = read_file (FILE1, &len); + struct stat statbuf; + int err = 0; - if (!out) - perror ("Could not read file"); + /* We can perform the test only if the file exists and is readable. + Test whether it exists, then assume it is world-readable. */ + if (stat (FILE1, &statbuf) >= 0) + { + size_t len; + char *out = read_file (FILE1, &len); - if (out[len] != '\0') - perror ("BAD: out[len] not zero"); + if (!out) + { + perror ("Could not read file"); + err = 1; + } + else + { + if (out[len] != '\0') + { + perror ("BAD: out[len] not zero"); + err = 1; + } - printf ("Read %ld from %s...\n", (unsigned long) len, FILE1); + /* Assume FILE1 is a regular file or a symlink to a regular file. */ + if (len != statbuf.st_size) + { + fprintf (stderr, "Read %ld from %s...\n", (unsigned long) len, FILE1); + err = 1; + } + free (out); + } + } - free (out); - } + /* We can perform the test only if the file exists and is readable. + Test whether it exists, then assume it is world-readable. */ + if (stat (FILE2, &statbuf) >= 0) + { + size_t len; + char *out = read_file (FILE2, &len); - { - size_t len; - char *out = read_file (FILE2, &len); + if (!out) + { + perror ("Could not read file"); + err = 1; + } + else + { + if (out[len] != '\0') + { + perror ("BAD: out[len] not zero"); + err = 1; + } - if (!out) - perror ("Could not read file"); + /* /dev/null should always be empty. Ignore statbuf.st_size, since it + is not a regular file. */ + if (len != 0) + { + fprintf (stderr, "Read %ld from %s...\n", (unsigned long) len, FILE2); + err = 1; + } + free (out); + } + } - if (out[len] != '\0') - perror ("BAD: out[len] not zero"); - - printf ("Read %ld from %s...\n", (unsigned long) len, FILE2); - - free (out); - } - - return 0; + return err; }