reindent-20030715
[openafs.git] / src / util / test / test_ktime.c
1 /*
2  * Copyright 2000, International Business Machines Corporation and others.
3  * All Rights Reserved.
4  * 
5  * This software has been released under the terms of the IBM Public
6  * License.  For details, see the LICENSE file in the top-level source
7  * directory or online at http://www.openafs.org/dl/license10.html
8  */
9
10 #include <afsconfig.h>
11 #include <afs/param.h>
12
13 RCSID
14     ("$Header$");
15
16 #include "ktime.h"
17
18 static struct testTime {
19     char *time;
20     long code;
21     long sec;
22 } testTimes[] = {
23     "now", 1 /* lookup current time */ , 0,
24         "never", 0, 0xffffffff, "12/3/89", 0, 628664400, "1/1/1", 0,
25         978325200, "1/0/80", -2, 0, "13/1/80", -2, 0, "0/1/80", -2, 0,
26         "1/32/80", -2, 0, "2/30/80", 0, 320734799,
27         /* Oh, well: note that 2/30 is bigger than any real date in February, and
28          * since this algorithm approaches the correct value from below, this is
29          * the closest it can come. */
30         "3/1/80", 0, 320734800, "3/1/80 0:00", 0, 320734800, "2/30/80 24:00", -2, 0, "2/30/80 23:60", -2, 0, "22/22/22", -2, 0, "12/31/69 19:07", 0, 420, "12/31/99 23:59", 0, 946702740, "12/31/99 23:59:59", 0, 946702740,    /* ignores seconds */
31         "23:12", -1, 0, "22/12", -1, 0, "22/22/22 12", -1, 0, "12/31/199 23:59:59", -1, 0, "12/31/1888", -1, 0, "-13/-44/22 -15:77", -1, 0, "4/14/24", 0, 1713067200, "4/14/2024", 0, 1713067200, "4/14/68", 0, 0x7fffffff,     /* sadly, legal but w/ sign bit on */
32 "4/14/69", 0, 0, 0, 0};
33
34 main(argc, argv)
35      int argc;
36      char *argv[];
37 {
38     long code;
39     int errors;
40     long t;
41     struct testTime *tt;
42
43     /* should do timezone and daylight savings time correction so this program
44      * work in other than EST */
45
46     if (argc > 1) {
47         code = util_GetLong(argv[1], &t);
48         if (code) {             /* assume its a date string */
49             code = ktime_DateToLong(argv[1], &t);
50             printf("The string %s gives %d; ctime yields %s", argv[1], t,
51                    ctime(&t));
52         } else {
53             printf("The value %d is %s", t, ctime(&t));
54         }
55         exit(0);
56     }
57     errors = 0;
58     for (tt = testTimes; tt->time; tt++) {
59         code = ktime_DateToLong(tt->time, &t);
60         if (code) {
61             if (tt->code < 0)
62                 continue;       /* got error as we should have */
63             printf("ktime_DateToLong returned %d given '%s'\n", code,
64                    tt->time);
65             errors++;
66             continue;
67         } else if (tt->code < 0) {
68             printf("ktime_DateToLong didn't failed on %s, instead got %d\n",
69                    tt->time, t);
70             errors++;
71             continue;
72         }
73         if (tt->code == 1) {
74             if (time(0) - t <= 1)
75                 continue;
76         } else if (t == tt->sec)
77             continue;
78         printf("Error converting %s to long: got %d should be %d\n", tt->time,
79                t, tt->sec);
80         errors++;
81         continue;
82     }
83     exit(errors);
84 }