[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
fseek failure output [was: [m4-1.4.11] build feedback]
From: |
Eric Blake |
Subject: |
fseek failure output [was: [m4-1.4.11] build feedback] |
Date: |
Fri, 04 Apr 2008 07:04:40 -0600 |
User-agent: |
Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.12) Gecko/20080213 Thunderbird/2.0.0.12 Mnenhy/0.7.5.666 |
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
According to Eric Blake on 4/3/2008 8:01 PM:
| |
| | FAIL: test-fseeko.sh
|
| Not much detail on the failure there. I guess we could improve
| test-fseeko.c to do better line number reporting. Can you please run
| test-fseeko in a debugger to see where the failure is? I'm guessing it
| has to do with ungetc of random bytes, which doesn't impact m4 behavior
| (m4 only ungets previously read bytes, which tends to be more reliable).
I'm checking in the following, so that test-fseeko.c will give better
diagnostics.
- --
Don't work too hard, make some time for fun as well!
Eric Blake address@hidden
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.9 (Cygwin)
Comment: Public key at home.comcast.net/~ericblake/eblake.gpg
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org
iEYEARECAAYFAkf2Jm0ACgkQ84KuGfSFAYAQRgCg1skGivRSTm39RDS2TmzAkivM
Mg0An163L8TVilpqgSY13prcXMjpGE/V
=62uK
-----END PGP SIGNATURE-----
>From be933433b7ad24c4087c187b0107690d6da174ef Mon Sep 17 00:00:00 2001
From: Eric Blake <address@hidden>
Date: Fri, 4 Apr 2008 06:58:46 -0600
Subject: [PATCH] Make test-fseeko.c failures meaningful.
* tests/test-fseeko.c: Print line number on failure.
* tests/test-fseek.c: Likewise.
Reported by Nelson H. F. Beebe.
Signed-off-by: Eric Blake <address@hidden>
---
ChangeLog | 5 ++++
tests/test-fseek.c | 48 +++++++++++++++++++++++++++------------------
tests/test-fseeko.c | 53 ++++++++++++++++++++++++++++----------------------
3 files changed, 64 insertions(+), 42 deletions(-)
diff --git a/ChangeLog b/ChangeLog
index a1a3041..4d39160 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
2008-04-04 Eric Blake <address@hidden>
+ Make test-fseeko.c failures meaningful.
+ * tests/test-fseeko.c: Print line number on failure.
+ * tests/test-fseek.c: Likewise.
+ Reported by Nelson H. F. Beebe.
+
Improve strtod bug detection check.
* m4/strtod.m4 (gl_FUNC_STRTOD): Also check for hex-float parsing,
required for Solaris 10.
diff --git a/tests/test-fseek.c b/tests/test-fseek.c
index 0c7db95..c38c485 100644
--- a/tests/test-fseek.c
+++ b/tests/test-fseek.c
@@ -1,5 +1,5 @@
/* Test of fseek() function.
- Copyright (C) 2007 Free Software Foundation, Inc.
+ Copyright (C) 2007, 2008 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -19,33 +19,43 @@
#include <config.h>
#include <stdio.h>
+#include <stdlib.h>
+
+#define ASSERT(expr) \
+ do \
+ { \
+ if (!(expr)) \
+ { \
+ fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \
+ abort (); \
+ } \
+ } \
+ while (0)
int
main (int argc, char **argv)
{
- /* Assume stdin is non-empty and seekable iff argc > 1. */
+ /* Assume stdin is non-empty, seekable, and starts with '#!/bin/sh'
+ iff argc > 1. */
int expected = argc > 1 ? 0 : -1;
- if (fseek (stdin, 0, SEEK_CUR) != expected)
- return 1;
+ ASSERT (fseek (stdin, 0, SEEK_CUR) == expected);
if (argc > 1)
{
- /* Test that fseek discards ungetc data. */
+ /* Test that fseek discards previously read ungetc data. */
int ch = fgetc (stdin);
- if (ch == EOF)
- return 1;
- if (ungetc (ch ^ 0xff, stdin) != (ch ^ 0xff))
- return 1;
- if (fseek (stdin, 0, SEEK_END))
- return 1;
- if (fgetc (stdin) != EOF)
- return 1;
+ ASSERT (ch == '#');
+ ASSERT (ungetc (ch, stdin) == ch);
+ ASSERT (fseek (stdin, 2, SEEK_SET) == 0);
+ /* Test that fseek discards random ungetc data. */
+ ch = fgetc (stdin);
+ ASSERT (ch == '/');
+ ASSERT (ungetc (ch ^ 0xff, stdin) == (ch ^ 0xff));
+ ASSERT (fseek (stdin, 0, SEEK_END) == 0);
+ ASSERT (fgetc (stdin) == EOF);
/* Test that fseek resets end-of-file marker. */
- if (!feof (stdin))
- return 1;
- if (fseek (stdin, 0, SEEK_END))
- return 1;
- if (feof (stdin))
- return 1;
+ ASSERT (feof (stdin));
+ ASSERT (fseek (stdin, 0, SEEK_END) == 0);
+ ASSERT (!feof (stdin));
}
return 0;
}
diff --git a/tests/test-fseeko.c b/tests/test-fseeko.c
index 25289ce..d7ec443 100644
--- a/tests/test-fseeko.c
+++ b/tests/test-fseeko.c
@@ -1,5 +1,5 @@
/* Test of fseeko() function.
- Copyright (C) 2007 Free Software Foundation, Inc.
+ Copyright (C) 2007, 2008 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
@@ -19,39 +19,46 @@
#include <config.h>
#include <stdio.h>
+#include <stdlib.h>
-/* Get off_t. */
-#include <sys/types.h>
+#define ASSERT(expr) \
+ do \
+ { \
+ if (!(expr)) \
+ { \
+ fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \
+ abort (); \
+ } \
+ } \
+ while (0)
int
main (int argc, char **argv)
{
- /* Assume stdin is non-empty and seekable iff argc > 1. */
+ /* Assume stdin is non-empty, seekable, and starts with '#!/bin/sh'
+ iff argc > 1. */
int expected = argc > 1 ? 0 : -1;
/* Exit with success only if fseek/fseeko agree. */
- int r1 = fseeko (stdin, (off_t)0, SEEK_CUR);
- int r2 = fseek (stdin, (long)0, SEEK_CUR);
- if (r1 != r2 || r1 != expected)
- return 1;
+ int r1 = fseeko (stdin, 0, SEEK_CUR);
+ int r2 = fseek (stdin, 0, SEEK_CUR);
+ ASSERT (r1 == r2 && r1 == expected);
if (argc > 1)
{
- /* Test that fseek discards ungetc data. */
+ /* Test that fseek discards previously read ungetc data. */
int ch = fgetc (stdin);
- if (ch == EOF)
- return 1;
- if (ungetc (ch ^ 0xff, stdin) != (ch ^ 0xff))
- return 1;
- if (fseeko (stdin, (off_t) 0, SEEK_END))
- return 1;
- if (fgetc (stdin) != EOF)
- return 1;
+ ASSERT (ch == '#');
+ ASSERT (ungetc (ch, stdin) == ch);
+ ASSERT (fseeko (stdin, 2, SEEK_SET) == 0);
+ /* Test that fseek discards random ungetc data. */
+ ch = fgetc (stdin);
+ ASSERT (ch == '/');
+ ASSERT (ungetc (ch ^ 0xff, stdin) == (ch ^ 0xff));
+ ASSERT (fseeko (stdin, 0, SEEK_END) == 0);
+ ASSERT (fgetc (stdin) == EOF);
/* Test that fseek resets end-of-file marker. */
- if (!feof (stdin))
- return 1;
- if (fseeko (stdin, (off_t) 0, SEEK_END))
- return 1;
- if (feof (stdin))
- return 1;
+ ASSERT (feof (stdin));
+ ASSERT (fseeko (stdin, 0, SEEK_END) == 0);
+ ASSERT (!feof (stdin));
}
return 0;
}
--
1.5.4
- [m4-1.4.11] build feedback, Nelson H. F. Beebe, 2008/04/03
- Re: [m4-1.4.11] build feedback, Eric Blake, 2008/04/03
- Re: [m4-1.4.11] build feedback, Bruno Haible, 2008/04/04
- fseek failure output [was: [m4-1.4.11] build feedback],
Eric Blake <=
- Re: [m4-1.4.11] build feedback, Bruno Haible, 2008/04/12
- Re: [m4-1.4.11] build feedback, Tom G. Christensen, 2008/04/13
- Re: [m4-1.4.11] build feedback, Bruno Haible, 2008/04/13
- Re: [m4-1.4.11] build feedback, Tom G. Christensen, 2008/04/13
- Re: [m4-1.4.11] build feedback, Bruno Haible, 2008/04/13
- Re: [m4-1.4.11] build feedback, Tom G. Christensen, 2008/04/13
- Re: [m4-1.4.11] build feedback, Bruno Haible, 2008/04/13
- Re: [m4-1.4.11] build feedback, Tom G. Christensen, 2008/04/14