aboutsummaryrefslogtreecommitdiffstats
path: root/time/tst-strptime2.c
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>2005-07-18 03:33:45 +0000
committerRoland McGrath <roland@gnu.org>2005-07-18 03:33:45 +0000
commitb5bb1655ab7cc2991d4389c3180ece3e4de47cea (patch)
tree7dbef27cd6ab978e4ecc697b166cb5d59b544952 /time/tst-strptime2.c
parent2005-06-17 Ulrich Drepper <drepper@redhat.com> (diff)
downloadglibc-b5bb1655ab7cc2991d4389c3180ece3e4de47cea.tar.xz
glibc-b5bb1655ab7cc2991d4389c3180ece3e4de47cea.zip
2005-04-26 Ulrich Drepper <drepper@redhat.com>
[BZ #1105] * time/strptime_l.c (__strptime_internal): Handle 'z' to set tm_gmtoff. * time/Makefile (tests): Add tst-strptime2. * time/tst-strptime2.c: New file.
Diffstat (limited to '')
-rw-r--r--time/tst-strptime2.c59
1 files changed, 59 insertions, 0 deletions
diff --git a/time/tst-strptime2.c b/time/tst-strptime2.c
new file mode 100644
index 0000000000..73552bb8f8
--- /dev/null
+++ b/time/tst-strptime2.c
@@ -0,0 +1,59 @@
+#include <limits.h>
+#include <stdio.h>
+#include <time.h>
+
+
+static const struct
+{
+ const char *fmt;
+ long int gmtoff;
+} tests[] =
+ {
+ { "1113472456 +1000", 36000 },
+ { "1113472456 -1000", -36000 },
+ { "1113472456 +10", 36000 },
+ { "1113472456 -10", -36000 },
+ { "1113472456 +1030", 37800 },
+ { "1113472456 -1030", -37800 },
+ { "1113472456 +0030", 1800 },
+ { "1113472456 -0030", -1800 },
+ { "1113472456 -1330", LONG_MAX },
+ { "1113472456 +1330", LONG_MAX },
+ { "1113472456 -1060", LONG_MAX },
+ { "1113472456 +1060", LONG_MAX },
+ { "1113472456 1030", LONG_MAX },
+ };
+#define ntests (sizeof (tests) / sizeof (tests[0]))
+
+
+int
+main (void)
+{
+ int result = 0;
+
+ for (int i = 0; i < ntests; ++i)
+ {
+ struct tm tm;
+
+ if (strptime (tests[i].fmt, "%s %z", &tm) == NULL)
+ {
+ if (tests[i].gmtoff != LONG_MAX)
+ {
+ printf ("round %d: strptime unexpectedly failed\n", i);
+ result = 1;
+ }
+ continue;
+ }
+
+ if (tm.tm_gmtoff != tests[i].gmtoff)
+ {
+ printf ("round %d: tm_gmtoff is %ld\n", i, (long int) tm.tm_gmtoff);
+ result = 1;
+ }
+ }
+
+ if (result == 0)
+ puts ("all OK");
+
+ return 0;
+}