mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
f5a5c7feef
Also fix Bug 491045, bug 476996, bug 485318, bug 485374, bug 427136.
819 lines
36 KiB
C
819 lines
36 KiB
C
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
*
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
* http://www.mozilla.org/MPL/
|
|
*
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
* for the specific language governing rights and limitations under the
|
|
* License.
|
|
*
|
|
* The Original Code is the Netscape Portable Runtime (NSPR).
|
|
*
|
|
* The Initial Developer of the Original Code is
|
|
* Netscape Communications Corporation.
|
|
* Portions created by the Initial Developer are Copyright (C) 1998-2000
|
|
* the Initial Developer. All Rights Reserved.
|
|
*
|
|
* Contributor(s):
|
|
*
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
* the provisions above, a recipient may use your version of this file under
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
/*
|
|
* file: y2k.c
|
|
* description: Test for y2k compliance for NSPR.
|
|
*
|
|
* Sep 1999. lth. Added "Sun" specified dates to the test data.
|
|
*/
|
|
/***********************************************************************
|
|
** Includes
|
|
***********************************************************************/
|
|
/* Used to get the command line option */
|
|
#include "plgetopt.h"
|
|
|
|
#include "prinit.h"
|
|
#include "prtime.h"
|
|
#include "prprf.h"
|
|
#include "prlog.h"
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#define PRINT_DETAILS
|
|
|
|
int failed_already=0;
|
|
PRBool debug_mode = PR_FALSE;
|
|
|
|
static char *dayOfWeek[] =
|
|
{ "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "???" };
|
|
static char *month[] =
|
|
{ "Jan", "Feb", "Mar", "Apr", "May", "Jun",
|
|
"Jul", "Aug", "Sep", "Oct", "Nov", "Dec", "???" };
|
|
|
|
PRLogModuleInfo *lm;
|
|
|
|
static void PrintExplodedTime(const PRExplodedTime *et) {
|
|
PRInt32 totalOffset;
|
|
PRInt32 hourOffset, minOffset;
|
|
const char *sign;
|
|
|
|
/* Print day of the week, month, day, hour, minute, and second */
|
|
printf("%s %s %2ld %02ld:%02ld:%02ld ",
|
|
dayOfWeek[et->tm_wday], month[et->tm_month], et->tm_mday,
|
|
et->tm_hour, et->tm_min, et->tm_sec);
|
|
|
|
/* Print year */
|
|
printf("%hd ", et->tm_year);
|
|
|
|
/* Print time zone */
|
|
totalOffset = et->tm_params.tp_gmt_offset + et->tm_params.tp_dst_offset;
|
|
if (totalOffset == 0) {
|
|
printf("UTC ");
|
|
} else {
|
|
sign = "+";
|
|
if (totalOffset < 0) {
|
|
totalOffset = -totalOffset;
|
|
sign = "-";
|
|
}
|
|
hourOffset = totalOffset / 3600;
|
|
minOffset = (totalOffset % 3600) / 60;
|
|
printf("%s%02ld%02ld ", sign, hourOffset, minOffset);
|
|
}
|
|
#ifdef PRINT_DETAILS
|
|
printf("{%d, %d, %d, %d, %d, %d, %d, %d, %d, { %d, %d}}\n",et->tm_usec,
|
|
et->tm_sec,
|
|
et->tm_min,
|
|
et->tm_hour,
|
|
et->tm_mday,
|
|
et->tm_month,
|
|
et->tm_year,
|
|
et->tm_wday,
|
|
et->tm_yday,
|
|
et->tm_params.tp_gmt_offset,
|
|
et->tm_params.tp_dst_offset);
|
|
#endif
|
|
}
|
|
|
|
static int ExplodedTimeIsEqual(const PRExplodedTime *et1,
|
|
const PRExplodedTime *et2)
|
|
{
|
|
if (et1->tm_usec == et2->tm_usec &&
|
|
et1->tm_sec == et2->tm_sec &&
|
|
et1->tm_min == et2->tm_min &&
|
|
et1->tm_hour == et2->tm_hour &&
|
|
et1->tm_mday == et2->tm_mday &&
|
|
et1->tm_month == et2->tm_month &&
|
|
et1->tm_year == et2->tm_year &&
|
|
et1->tm_wday == et2->tm_wday &&
|
|
et1->tm_yday == et2->tm_yday &&
|
|
et1->tm_params.tp_gmt_offset == et2->tm_params.tp_gmt_offset &&
|
|
et1->tm_params.tp_dst_offset == et2->tm_params.tp_dst_offset) {
|
|
return 1;
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
/*
|
|
* TEST 1: TestExplodeImplodeTime
|
|
* Description:
|
|
* For each given timestamp T (a PRTime value), call PR_ExplodeTime
|
|
* with GMT, US Pacific, and local time parameters. Compare the
|
|
* resulting calendar (exploded) time values with the expected
|
|
* values.
|
|
*
|
|
* Note: the expected local time values depend on the local time
|
|
* zone. The local time values stored in this test are for the US
|
|
* Pacific Time Zone. If you are running this test in a different
|
|
* time zone, you need to modify the values in the localt array.
|
|
* An example is provided below.
|
|
*
|
|
* Call PR_ImplodeTime for each of the exploded values and compare
|
|
* the resulting PRTime values with the original input.
|
|
*
|
|
* This test is run for the values of time T corresponding to the
|
|
* following dates:
|
|
* - 12/31/99 - before 2000
|
|
* - 01/01/00 - after 2000
|
|
* - Leap year - Feb 29, 2000
|
|
* - March 1st, 2001 (after 1 year)
|
|
* - March 1st, 2005 (after second leap year)
|
|
* - 09/09/99 (used by some programs as an end of file marker)
|
|
*
|
|
* Call PR_Now, convert to calendar time using PR_ExplodeTime and
|
|
* manually check the result for correctness. The time should match
|
|
* the system clock.
|
|
*
|
|
* Tested functions: PR_Now, PR_ExplodeTime, PR_ImplodeTime,
|
|
* PR_LocalTimeParameters, PR_GMTParameters.
|
|
*/
|
|
|
|
static PRTime prt[] = {
|
|
LL_INIT(220405, 2133125120), /* 946634400000000 */
|
|
LL_INIT(220425, 2633779200), /* 946720800000000 */
|
|
LL_INIT(221612, 2107598848), /* 951818400000000 */
|
|
LL_INIT(228975, 663398400), /* 983440800000000 */
|
|
LL_INIT(258365, 1974568960), /* 1109671200000000 */
|
|
LL_INIT(218132, 1393788928), /* 936871200000000 */
|
|
/* Sun's dates follow */
|
|
LL_INIT( 213062, 4077979648 ), /* Dec 31 1998 10:00:00 */
|
|
LL_INIT( 218152, 1894443008 ), /* Sep 10 1999 10:00:00 */
|
|
LL_INIT( 221592, 1606944768 ), /* Feb 28 2000 10:00:00 */
|
|
LL_INIT( 227768, 688924672 ), /* Dec 31 2000 10:00:00 */
|
|
LL_INIT( 227788, 1189578752 ), /* Jan 1 2001 10:00:00 */
|
|
};
|
|
|
|
static PRExplodedTime gmt[] = {
|
|
{ 0, 0, 0, 10, 31, 11, 1999, 5, 364, {0, 0}}, /* 1999/12/31 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 1, 0, 2000, 6, 0, {0, 0}}, /* 2000/01/01 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 29, 1, 2000, 2, 59, {0, 0}}, /* 2000/02/29 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 1, 2, 2001, 4, 59, {0, 0}}, /* 2001/3/1 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 1, 2, 2005, 2, 59, {0, 0}}, /* 2005/3/1 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 9, 8, 1999, 4, 251, {0, 0}}, /* 1999/9/9 10:00:00 GMT */
|
|
/* Sun's dates follow */
|
|
{ 0, 0, 0, 10, 31, 11, 1998, 4, 364, {0, 0}}, /* 12/31/1998 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 10, 8, 1999, 5, 252, {0, 0}}, /* 9/10/1999 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 28, 1, 2000, 1, 58, {0, 0}}, /* 2/28/2000 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 31, 11, 2000, 0, 365, {0, 0}}, /* 12/31/2000 10:00:00 GMT */
|
|
{ 0, 0, 0, 10, 1, 0, 2001, 1, 0, {0, 0}} /* 1/1/2001 10:00:00 GMT */
|
|
};
|
|
|
|
static PRExplodedTime uspt[] = {
|
|
{ 0, 0, 0, 2, 31, 11, 1999, 5, 364, {-28800, 0}}, /* 1999/12/31 2:00:00 PST */
|
|
{ 0, 0, 0, 2, 1, 0, 2000, 6, 0, {-28800, 0}}, /* 2000/01/01 2:00:00 PST */
|
|
{ 0, 0, 0, 2, 29, 1, 2000, 2, 59, {-28800, 0}}, /* 2000/02/29 2:00:00 PST */
|
|
{ 0, 0, 0, 2, 1, 2, 2001, 4, 59, {-28800, 0}}, /* 2001/3/1 2:00:00 PST */
|
|
{ 0, 0, 0, 2, 1, 2, 2005, 2, 59, {-28800, 0}}, /* 2005/3/1 2:00:00 PST */
|
|
{ 0, 0, 0, 3, 9, 8, 1999, 4, 251, {-28800, 3600}}, /* 1999/9/9 3:00:00 PDT */
|
|
/* Sun's dates follow */
|
|
{ 0, 0, 0, 2, 31, 11, 1998, 4, 364, {-28800, 0}}, /* 12/31/1998 00:00:00 GMT */
|
|
{ 0, 0, 0, 3, 10, 8, 1999, 5, 252, {-28800, 3600}}, /* 9/10/1999 00:00:00 GMT */
|
|
{ 0, 0, 0, 2, 28, 1, 2000, 1, 58, {-28800, 0}}, /* 2/28/2000 00:00:00 GMT */
|
|
{ 0, 0, 0, 2, 31, 11, 2000, 0, 365, {-28800, 0}}, /* 12/31/2000 00:00:00 GMT */
|
|
{ 0, 0, 0, 2, 1, 0, 2001, 1, 0, {-28800, 0}} /* 1/1/2001 00:00:00 GMT */
|
|
};
|
|
|
|
/*
|
|
* This test assumes that we are in US Pacific Time Zone.
|
|
* If you are running this test in a different time zone,
|
|
* you need to modify the localt array and fill in the
|
|
* expected results. The localt array for US Eastern Time
|
|
* Zone is provided as an example.
|
|
*/
|
|
static PRExplodedTime localt[] = {
|
|
{ 0, 0, 0, 2, 31, 11, 1999, 5, 364, {-28800, 0}}, /* 1999/12/31 2:00:00 PST */
|
|
{ 0, 0, 0, 2, 1, 0, 2000, 6, 0, {-28800, 0}}, /* 2000/01/01 2:00:00 PST */
|
|
{ 0, 0, 0, 2, 29, 1, 2000, 2, 59, {-28800, 0}}, /* 2000/02/29 2:00:00 PST */
|
|
{ 0, 0, 0, 2, 1, 2, 2001, 4, 59, {-28800, 0}}, /* 2001/3/1 2:00:00 PST */
|
|
{ 0, 0, 0, 2, 1, 2, 2005, 2, 59, {-28800, 0}}, /* 2005/3/1 2:00:00 PST */
|
|
{ 0, 0, 0, 3, 9, 8, 1999, 4, 251, {-28800, 3600}}, /* 1999/9/9 3:00:00 PDT */
|
|
/* Sun's dates follow */
|
|
{ 0, 0, 0, 2, 31, 11, 1998, 4, 364, {-28800, 0}}, /* 12/31/1998 00:00:00 GMT */
|
|
{ 0, 0, 0, 3, 10, 8, 1999, 5, 252, {-28800, 3600}}, /* 9/10/1999 00:00:00 GMT */
|
|
{ 0, 0, 0, 2, 28, 1, 2000, 1, 58, {-28800, 0}}, /* 2/28/2000 00:00:00 GMT */
|
|
{ 0, 0, 0, 2, 31, 11, 2000, 0, 365, {-28800, 0}}, /* 12/31/2000 00:00:00 GMT */
|
|
{ 0, 0, 0, 2, 1, 0, 2001, 1, 0, {-28800, 0}} /* 1/1/2001 00:00:00 GMT */
|
|
};
|
|
|
|
#ifdef US_EASTERN_TIME
|
|
static PRExplodedTime localt[] = {
|
|
{ 0, 0, 0, 5, 31, 11, 1999, 5, 364, {-18000, 0}}, /* 1999/12/31 2:00:00 EST */
|
|
{ 0, 0, 0, 5, 1, 0, 2000, 6, 0, {-18000, 0}}, /* 2000/01/01 2:00:00 EST */
|
|
{ 0, 0, 0, 5, 29, 1, 2000, 2, 59, {-18000, 0}}, /* 2000/02/29 2:00:00 EST */
|
|
{ 0, 0, 0, 5, 1, 2, 2001, 4, 59, {-18000, 0}}, /* 2001/3/1 2:00:00 EST */
|
|
{ 0, 0, 0, 5, 1, 2, 2005, 2, 59, {-18000, 0}}, /* 2005/3/1 2:00:00 EST */
|
|
{ 0, 0, 0, 6, 9, 8, 1999, 4, 251, {-18000, 3600}}, /* 1999/9/9 3:00:00 EDT */
|
|
/* Sun's dates follow */
|
|
{ 0, 0, 0, 5, 31, 11, 1998, 4, 364, {-18000 0}}, /* 12/31/1998 00:00:00 GMT */
|
|
{ 0, 0, 0, 6, 10, 8, 1999, 5, 252, {-18000 3600}}, /* 9/10/1999 00:00:00 GMT */
|
|
{ 0, 0, 0, 5, 28, 1, 2000, 1, 58, {-18000 0}}, /* 2/28/2000 00:00:00 GMT */
|
|
{ 0, 0, 0, 5, 31, 11, 2000, 0, 365, {-18000 0}}, /* 12/31/2000 00:00:00 GMT */
|
|
{ 0, 0, 0, 5, 1, 0, 2001, 1, 0, {-18000 0}} /* 1/1/2001 00:00:00 GMT */
|
|
};
|
|
#endif
|
|
|
|
static PRStatus TestExplodeImplodeTime(void)
|
|
{
|
|
PRTime prt_tmp;
|
|
PRTime now;
|
|
int idx;
|
|
int array_size = sizeof(prt) / sizeof(PRTime);
|
|
PRExplodedTime et_tmp;
|
|
char buf[1024];
|
|
|
|
for (idx = 0; idx < array_size; idx++) {
|
|
PR_snprintf(buf, sizeof(buf), "%lld", prt[idx]);
|
|
if (debug_mode) printf("Time stamp %s\n", buf);
|
|
PR_ExplodeTime(prt[idx], PR_GMTParameters, &et_tmp);
|
|
if (!ExplodedTimeIsEqual(&et_tmp, &gmt[idx])) {
|
|
fprintf(stderr, "GMT not equal\n");
|
|
PrintExplodedTime(&et_tmp);
|
|
PrintExplodedTime(&gmt[idx]);
|
|
exit(1);
|
|
}
|
|
prt_tmp = PR_ImplodeTime(&et_tmp);
|
|
if (LL_NE(prt_tmp, prt[idx])) {
|
|
fprintf(stderr, "PRTime not equal\n");
|
|
exit(1);
|
|
}
|
|
if (debug_mode) {
|
|
printf("GMT: ");
|
|
PrintExplodedTime(&et_tmp);
|
|
printf("\n");
|
|
}
|
|
|
|
PR_ExplodeTime(prt[idx], PR_USPacificTimeParameters, &et_tmp);
|
|
if (!ExplodedTimeIsEqual(&et_tmp, &uspt[idx])) {
|
|
fprintf(stderr, "US Pacific Time not equal\n");
|
|
PrintExplodedTime(&et_tmp);
|
|
PrintExplodedTime(&uspt[idx]);
|
|
exit(1);
|
|
}
|
|
prt_tmp = PR_ImplodeTime(&et_tmp);
|
|
if (LL_NE(prt_tmp, prt[idx])) {
|
|
fprintf(stderr, "PRTime not equal\n");
|
|
exit(1);
|
|
}
|
|
if (debug_mode) {
|
|
printf("US Pacific Time: ");
|
|
PrintExplodedTime(&et_tmp);
|
|
printf("\n");
|
|
}
|
|
|
|
PR_ExplodeTime(prt[idx], PR_LocalTimeParameters, &et_tmp);
|
|
if (!ExplodedTimeIsEqual(&et_tmp, &localt[idx])) {
|
|
fprintf(stderr, "not equal\n");
|
|
PrintExplodedTime(&et_tmp);
|
|
PrintExplodedTime(&localt[idx]);
|
|
exit(1);
|
|
}
|
|
prt_tmp = PR_ImplodeTime(&et_tmp);
|
|
if (LL_NE(prt_tmp, prt[idx])) {
|
|
fprintf(stderr, "not equal\n");
|
|
exit(1);
|
|
}
|
|
if (debug_mode) {
|
|
printf("Local time:");
|
|
PrintExplodedTime(&et_tmp);
|
|
printf("\n\n");
|
|
}
|
|
}
|
|
|
|
now = PR_Now();
|
|
PR_ExplodeTime(now, PR_GMTParameters, &et_tmp);
|
|
printf("Current GMT is ");
|
|
PrintExplodedTime(&et_tmp);
|
|
printf("\n");
|
|
prt_tmp = PR_ImplodeTime(&et_tmp);
|
|
if (LL_NE(prt_tmp, now)) {
|
|
fprintf(stderr, "not equal\n");
|
|
exit(1);
|
|
}
|
|
PR_ExplodeTime(now, PR_USPacificTimeParameters, &et_tmp);
|
|
printf("Current US Pacific Time is ");
|
|
PrintExplodedTime(&et_tmp);
|
|
printf("\n");
|
|
prt_tmp = PR_ImplodeTime(&et_tmp);
|
|
if (LL_NE(prt_tmp, now)) {
|
|
fprintf(stderr, "not equal\n");
|
|
exit(1);
|
|
}
|
|
PR_ExplodeTime(now, PR_LocalTimeParameters, &et_tmp);
|
|
printf("Current local time is ");
|
|
PrintExplodedTime(&et_tmp);
|
|
printf("\n");
|
|
prt_tmp = PR_ImplodeTime(&et_tmp);
|
|
if (LL_NE(prt_tmp, now)) {
|
|
fprintf(stderr, "not equal\n");
|
|
exit(1);
|
|
}
|
|
printf("Please verify the results\n\n");
|
|
|
|
if (debug_mode) printf("Test 1 passed\n");
|
|
return PR_SUCCESS;
|
|
}
|
|
/* End of Test 1: TestExplodeImplodeTime */
|
|
|
|
/*
|
|
* Test 2: Normalize Time
|
|
*/
|
|
|
|
/*
|
|
* time increment for addition to PRExplodeTime
|
|
*/
|
|
typedef struct time_increment {
|
|
PRInt32 ti_usec;
|
|
PRInt32 ti_sec;
|
|
PRInt32 ti_min;
|
|
PRInt32 ti_hour;
|
|
} time_increment_t;
|
|
|
|
/*
|
|
* Data for testing PR_Normalize
|
|
* Add the increment to base_time, normalize it to GMT and US Pacific
|
|
* Time zone.
|
|
*/
|
|
typedef struct normalize_test_data {
|
|
PRExplodedTime base_time;
|
|
time_increment_t increment;
|
|
PRExplodedTime expected_gmt_time;
|
|
PRExplodedTime expected_uspt_time;
|
|
} normalize_test_data_t;
|
|
|
|
|
|
/*
|
|
* Test data - the base time values cover dates of interest including y2k - 1,
|
|
* y2k + 1, y2k leap year, y2k leap date + 1year,
|
|
* y2k leap date + 4 years
|
|
*/
|
|
normalize_test_data_t normalize_test_array[] = {
|
|
/*usec sec min hour mday mo year wday yday {gmtoff, dstoff }*/
|
|
|
|
/* Fri 12/31/1999 19:32:48 PST */
|
|
{{0, 48, 32, 19, 31, 11, 1999, 5, 364, { -28800, 0}},
|
|
{0, 0, 30, 20},
|
|
{0, 48, 2, 0, 2, 0, 2000, 0, 1, { 0, 0}}, /*Sun Jan 2 00:02:48 UTC 2000*/
|
|
{0, 48, 2, 16, 1, 0, 2000, 6, 0, { -28800, 0}},/* Sat Jan 1 16:02:48
|
|
PST 2000*/
|
|
},
|
|
/* Fri 99-12-31 23:59:02 GMT */
|
|
{{0, 2, 59, 23, 31, 11, 1999, 5, 364, { 0, 0}},
|
|
{0, 0, 45, 0},
|
|
{0, 2, 44, 0, 1, 0, 2000, 6, 0, { 0, 0}},/* Sat Jan 1 00:44:02 UTC 2000*/
|
|
{0, 2, 44, 16, 31, 11, 1999, 5, 364, { -28800, 0}}/*Fri Dec 31 16:44:02
|
|
PST 1999*/
|
|
},
|
|
/* 99-12-25 12:00:00 GMT */
|
|
{{0, 0, 0, 12, 25, 11, 1999, 6, 358, { 0, 0}},
|
|
{0, 0, 0, 364 * 24},
|
|
{0, 0, 0, 12, 23, 11, 2000, 6, 357, { 0, 0}},/*Sat Dec 23 12:00:00
|
|
2000 UTC*/
|
|
{0, 0, 0, 4, 23, 11, 2000, 6, 357, { -28800, 0}}/*Sat Dec 23 04:00:00
|
|
2000 -0800*/
|
|
},
|
|
/* 00-01-1 00:00:00 PST */
|
|
{{0, 0, 0, 0, 1, 0, 2000, 6, 0, { -28800, 0}},
|
|
{0, 0, 0, 48},
|
|
{0, 0, 0, 8, 3, 0, 2000, 1, 2, { 0, 0}},/*Mon Jan 3 08:00:00 2000 UTC*/
|
|
{0, 0, 0, 0, 3, 0, 2000, 1, 2, { -28800, 0}}/*Mon Jan 3 00:00:00 2000
|
|
-0800*/
|
|
},
|
|
/* 00-01-10 12:00:00 PST */
|
|
{{0, 0, 0, 12, 10, 0, 2000, 1, 9, { -28800, 0}},
|
|
{0, 0, 0, 364 * 5 * 24},
|
|
{0, 0, 0, 20, 3, 0, 2005, 1, 2, { 0, 0}},/*Mon Jan 3 20:00:00 2005 UTC */
|
|
{0, 0, 0, 12, 3, 0, 2005, 1, 2, { -28800, 0}}/*Mon Jan 3 12:00:00
|
|
2005 -0800*/
|
|
},
|
|
/* 00-02-28 15:39 GMT */
|
|
{{0, 0, 39, 15, 28, 1, 2000, 1, 58, { 0, 0}},
|
|
{0, 0, 0, 24},
|
|
{0, 0, 39, 15, 29, 1, 2000, 2, 59, { 0, 0}}, /*Tue Feb 29 15:39:00 2000
|
|
UTC*/
|
|
{0, 0, 39, 7, 29, 1, 2000, 2, 59, { -28800, 0}}/*Tue Feb 29 07:39:00
|
|
2000 -0800*/
|
|
},
|
|
/* 01-03-01 12:00 PST */
|
|
{{0, 0, 0, 12, 3, 0, 2001, 3, 2, { -28800, 0}},/*Wed Jan 3 12:00:00
|
|
-0800 2001*/
|
|
{0, 30, 30,45},
|
|
{0, 30, 30, 17, 5, 0, 2001, 5, 4, { 0, 0}}, /*Fri Jan 5 17:30:30 2001
|
|
UTC*/
|
|
{0, 30, 30, 9, 5, 0, 2001, 5, 4, { -28800, 0}} /*Fri Jan 5 09:30:30
|
|
2001 -0800*/
|
|
},
|
|
/* 2004-04-26 12:00 GMT */
|
|
{{0, 0, 0, 20, 3, 0, 2001, 3, 2, { 0, 0}},
|
|
{0, 0, 30,0},
|
|
{0, 0, 30, 20, 3, 0, 2001, 3, 2, { 0, 0}},/*Wed Jan 3 20:30:00 2001 UTC*/
|
|
{0, 0, 30, 12, 3, 0, 2001, 3, 2, { -28800, 0}}/*Wed Jan 3 12:30:00
|
|
2001 -0800*/
|
|
},
|
|
/* 99-09-09 00:00 GMT */
|
|
{{0, 0, 0, 0, 9, 8, 1999, 4, 251, { 0, 0}},
|
|
{0, 0, 0, 12},
|
|
{0, 0, 0, 12, 9, 8, 1999, 4, 251, { 0, 0}},/*Thu Sep 9 12:00:00 1999 UTC*/
|
|
{0, 0, 0, 5, 9, 8, 1999, 4, 251, { -28800, 3600}}/*Thu Sep 9 05:00:00
|
|
1999 -0700*/
|
|
}
|
|
};
|
|
|
|
void add_time_increment(PRExplodedTime *et1, time_increment_t *it)
|
|
{
|
|
et1->tm_usec += it->ti_usec;
|
|
et1->tm_sec += it->ti_sec;
|
|
et1->tm_min += it->ti_min;
|
|
et1->tm_hour += it->ti_hour;
|
|
}
|
|
|
|
/*
|
|
** TestNormalizeTime() -- Test PR_NormalizeTime()
|
|
** For each data item, add the time increment to the base_time and then
|
|
** normalize it for GMT and local time zones. This test assumes that
|
|
** the local time zone is the Pacific Time Zone. The normalized values
|
|
** should match the expected values in the data item.
|
|
**
|
|
*/
|
|
PRStatus TestNormalizeTime(void)
|
|
{
|
|
int idx, count;
|
|
normalize_test_data_t *itemp;
|
|
time_increment_t *itp;
|
|
|
|
count = sizeof(normalize_test_array)/sizeof(normalize_test_array[0]);
|
|
for (idx = 0; idx < count; idx++) {
|
|
itemp = &normalize_test_array[idx];
|
|
if (debug_mode) {
|
|
printf("%2d. %15s",idx +1,"Base time: ");
|
|
PrintExplodedTime(&itemp->base_time);
|
|
printf("\n");
|
|
}
|
|
itp = &itemp->increment;
|
|
if (debug_mode) {
|
|
printf("%20s %2d hrs %2d min %3d sec\n","Add",itp->ti_hour,
|
|
itp->ti_min, itp->ti_sec);
|
|
}
|
|
add_time_increment(&itemp->base_time, &itemp->increment);
|
|
PR_NormalizeTime(&itemp->base_time, PR_LocalTimeParameters);
|
|
if (debug_mode) {
|
|
printf("%19s","PST time: ");
|
|
PrintExplodedTime(&itemp->base_time);
|
|
printf("\n");
|
|
}
|
|
if (!ExplodedTimeIsEqual(&itemp->base_time,
|
|
&itemp->expected_uspt_time)) {
|
|
printf("PR_NormalizeTime failed\n");
|
|
if (debug_mode)
|
|
PrintExplodedTime(&itemp->expected_uspt_time);
|
|
return PR_FAILURE;
|
|
}
|
|
PR_NormalizeTime(&itemp->base_time, PR_GMTParameters);
|
|
if (debug_mode) {
|
|
printf("%19s","GMT time: ");
|
|
PrintExplodedTime(&itemp->base_time);
|
|
printf("\n");
|
|
}
|
|
|
|
if (!ExplodedTimeIsEqual(&itemp->base_time,
|
|
&itemp->expected_gmt_time)) {
|
|
printf("PR_NormalizeTime failed\n");
|
|
return PR_FAILURE;
|
|
}
|
|
}
|
|
return PR_SUCCESS;
|
|
}
|
|
|
|
|
|
/*
|
|
** ParseTest. Structure defining a string time and a matching exploded time
|
|
**
|
|
*/
|
|
typedef struct ParseTest
|
|
{
|
|
char *sDate; /* string to be converted using PR_ParseTimeString() */
|
|
PRExplodedTime et; /* expected result of the conversion */
|
|
} ParseTest;
|
|
|
|
static ParseTest parseArray[] =
|
|
{
|
|
/* |<----- expected result ------------------------------------------->| */
|
|
/* "string to test" usec sec min hour day mo year wday julian {gmtoff, dstoff }*/
|
|
{ "Thursday 1 Jan 1970 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "1 Jan 1970 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "1-Jan-1970 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "01-Jan-1970 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "January 1, 1970", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "January 1, 1970 00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "January 01, 1970 00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "January 01 1970 00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "January 01 1970 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "01-01-1970", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "01/01/1970", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "01/01/70", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "01/01/70 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "70/01/01 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "70/1/1 00:00:", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "00:00 Thursday, January 1, 1970",{ 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "1-Jan-70 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "70-01-01 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
{ "70/01/01 00:00:00", { 000000, 00, 00, 00, 1, 0, 1970, 4, 0, {-28800, 0 }}},
|
|
|
|
/* 31-Dec-1969 */
|
|
{ "Wed 31 Dec 1969 00:00:00", { 000000, 00, 00, 00, 31, 11, 1969, 3, 364, {-28800, 0 }}},
|
|
{ "31 Dec 1969 00:00:00", { 000000, 00, 00, 00, 31, 11, 1969, 3, 364, {-28800, 0 }}},
|
|
{ "12/31/69 00:00:00", { 000000, 00, 00, 00, 31, 11, 2069, 2, 364, {-28800, 0 }}},
|
|
{ "12/31/1969 00:00:00", { 000000, 00, 00, 00, 31, 11, 1969, 3, 364, {-28800, 0 }}},
|
|
{ "12-31-69 00:00:00", { 000000, 00, 00, 00, 31, 11, 2069, 2, 364, {-28800, 0 }}},
|
|
{ "12-31-1969 00:00:00", { 000000, 00, 00, 00, 31, 11, 1969, 3, 364, {-28800, 0 }}},
|
|
{ "69-12-31 00:00:00", { 000000, 00, 00, 00, 31, 11, 2069, 2, 364, {-28800, 0 }}},
|
|
{ "69/12/31 00:00:00", { 000000, 00, 00, 00, 31, 11, 2069, 2, 364, {-28800, 0 }}},
|
|
|
|
/* "Sun". 31-Dec-1998 (?) */
|
|
{ "Thu 31 Dec 1998 00:00:00", { 00000, 00, 00, 00, 31, 11, 1998, 4, 364, {-28800, 0 }}},
|
|
{ "12/31/98 00:00:00", { 00000, 00, 00, 00, 31, 11, 1998, 4, 364, {-28800, 0 }}},
|
|
{ "12/31/1998 00:00:00", { 00000, 00, 00, 00, 31, 11, 1998, 4, 364, {-28800, 0 }}},
|
|
{ "12-31-98 00:00:00", { 00000, 00, 00, 00, 31, 11, 1998, 4, 364, {-28800, 0 }}},
|
|
{ "12-31-1998 00:00:00", { 00000, 00, 00, 00, 31, 11, 1998, 4, 364, {-28800, 0 }}},
|
|
{ "98-12-31 00:00:00", { 00000, 00, 00, 00, 31, 11, 1998, 4, 364, {-28800, 0 }}},
|
|
{ "98/12/31 00:00:00", { 00000, 00, 00, 00, 31, 11, 1998, 4, 364, {-28800, 0 }}},
|
|
|
|
/* 09-Sep-1999. Interesting because of its use as an eof marker? */
|
|
{ "09 Sep 1999 00:00:00", { 000000, 00, 00, 00, 9, 8, 1999, 4, 251, {-28800, 3600 }}},
|
|
{ "9/9/99 00:00:00", { 000000, 00, 00, 00, 9, 8, 1999, 4, 251, {-28800, 3600 }}},
|
|
{ "9/9/1999 00:00:00", { 000000, 00, 00, 00, 9, 8, 1999, 4, 251, {-28800, 3600 }}},
|
|
{ "9-9-99 00:00:00", { 000000, 00, 00, 00, 9, 8, 1999, 4, 251, {-28800, 3600 }}},
|
|
{ "9-9-1999 00:00:00", { 000000, 00, 00, 00, 9, 8, 1999, 4, 251, {-28800, 3600 }}},
|
|
{ "09-09-99 00:00:00", { 000000, 00, 00, 00, 9, 8, 1999, 4, 251, {-28800, 3600 }}},
|
|
{ "09-09-1999 00:00:00", { 000000, 00, 00, 00, 9, 8, 1999, 4, 251, {-28800, 3600 }}},
|
|
{ "99-09-09 00:00:00", { 000000, 00, 00, 00, 9, 8, 1999, 4, 251, {-28800, 3600 }}},
|
|
|
|
/* "Sun". 10-Sep-1999. Because Sun said so. */
|
|
{ "10 Sep 1999 00:00:00", { 000000, 00, 00, 00, 10, 8, 1999, 5, 252, {-28800, 3600 }}},
|
|
{ "9/10/99 00:00:00", { 000000, 00, 00, 00, 10, 8, 1999, 5, 252, {-28800, 3600 }}},
|
|
{ "9/10/1999 00:00:00", { 000000, 00, 00, 00, 10, 8, 1999, 5, 252, {-28800, 3600 }}},
|
|
{ "9-10-99 00:00:00", { 000000, 00, 00, 00, 10, 8, 1999, 5, 252, {-28800, 3600 }}},
|
|
{ "9-10-1999 00:00:00", { 000000, 00, 00, 00, 10, 8, 1999, 5, 252, {-28800, 3600 }}},
|
|
{ "09-10-99 00:00:00", { 000000, 00, 00, 00, 10, 8, 1999, 5, 252, {-28800, 3600 }}},
|
|
{ "09-10-1999 00:00:00", { 000000, 00, 00, 00, 10, 8, 1999, 5, 252, {-28800, 3600 }}},
|
|
{ "99-09-10 00:00:00", { 000000, 00, 00, 00, 10, 8, 1999, 5, 252, {-28800, 3600 }}},
|
|
|
|
/* 31-Dec-1999 */
|
|
{ "31 Dec 1999 00:00:00", { 000000, 00, 00, 00, 31, 11, 1999, 5, 364, {-28800, 0 }}},
|
|
{ "12/31/99 00:00:00", { 000000, 00, 00, 00, 31, 11, 1999, 5, 364, {-28800, 0 }}},
|
|
{ "12/31/1999 00:00:00", { 000000, 00, 00, 00, 31, 11, 1999, 5, 364, {-28800, 0 }}},
|
|
{ "12-31-99 00:00:00", { 000000, 00, 00, 00, 31, 11, 1999, 5, 364, {-28800, 0 }}},
|
|
{ "12-31-1999 00:00:00", { 000000, 00, 00, 00, 31, 11, 1999, 5, 364, {-28800, 0 }}},
|
|
{ "99-12-31 00:00:00", { 000000, 00, 00, 00, 31, 11, 1999, 5, 364, {-28800, 0 }}},
|
|
{ "99/12/31 00:00:00", { 000000, 00, 00, 00, 31, 11, 1999, 5, 364, {-28800, 0 }}},
|
|
|
|
/* 01-Jan-2000 */
|
|
{ "01 Jan 2000 00:00:00", { 000000, 00, 00, 00, 1, 0, 2000, 6, 0, {-28800, 0 }}},
|
|
{ "1/1/00 00:00:00", { 000000, 00, 00, 00, 1, 0, 2000, 6, 0, {-28800, 0 }}},
|
|
{ "1/1/2000 00:00:00", { 000000, 00, 00, 00, 1, 0, 2000, 6, 0, {-28800, 0 }}},
|
|
{ "1-1-00 00:00:00", { 000000, 00, 00, 00, 1, 0, 2000, 6, 0, {-28800, 0 }}},
|
|
{ "1-1-2000 00:00:00", { 000000, 00, 00, 00, 1, 0, 2000, 6, 0, {-28800, 0 }}},
|
|
{ "01-01-00 00:00:00", { 000000, 00, 00, 00, 1, 0, 2000, 6, 0, {-28800, 0 }}},
|
|
{ "Saturday 01-01-2000 00:00:00", { 000000, 00, 00, 00, 1, 0, 2000, 6, 0, {-28800, 0 }}},
|
|
|
|
/* "Sun". 28-Feb-2000 */
|
|
{ "28 Feb 2000 00:00:00", { 000000, 00, 00, 00, 28, 1, 2000, 1, 58, {-28800, 0 }}},
|
|
{ "2/28/00 00:00:00", { 000000, 00, 00, 00, 28, 1, 2000, 1, 58, {-28800, 0 }}},
|
|
{ "2/28/2000 00:00:00", { 000000, 00, 00, 00, 28, 1, 2000, 1, 58, {-28800, 0 }}},
|
|
{ "2-28-00 00:00:00", { 000000, 00, 00, 00, 28, 1, 2000, 1, 58, {-28800, 0 }}},
|
|
{ "2-28-2000 00:00:00", { 000000, 00, 00, 00, 28, 1, 2000, 1, 58, {-28800, 0 }}},
|
|
{ "02-28-00 00:00:00", { 000000, 00, 00, 00, 28, 1, 2000, 1, 58, {-28800, 0 }}},
|
|
{ "02-28-2000 00:00:00", { 000000, 00, 00, 00, 28, 1, 2000, 1, 58, {-28800, 0 }}},
|
|
|
|
/* 29-Feb-2000 */
|
|
{ "29 Feb 2000 00:00:00", { 000000, 00, 00, 00, 29, 1, 2000, 2, 59, {-28800, 0 }}},
|
|
{ "2/29/00 00:00:00", { 000000, 00, 00, 00, 29, 1, 2000, 2, 59, {-28800, 0 }}},
|
|
{ "2/29/2000 00:00:00", { 000000, 00, 00, 00, 29, 1, 2000, 2, 59, {-28800, 0 }}},
|
|
{ "2-29-00 00:00:00", { 000000, 00, 00, 00, 29, 1, 2000, 2, 59, {-28800, 0 }}},
|
|
{ "2-29-2000 00:00:00", { 000000, 00, 00, 00, 29, 1, 2000, 2, 59, {-28800, 0 }}},
|
|
{ "02-29-00 00:00:00", { 000000, 00, 00, 00, 29, 1, 2000, 2, 59, {-28800, 0 }}},
|
|
{ "02-29-2000 00:00:00", { 000000, 00, 00, 00, 29, 1, 2000, 2, 59, {-28800, 0 }}},
|
|
|
|
/* 01-Mar-2000 */
|
|
{ "01 Mar 2000 00:00:00", { 000000, 00, 00, 00, 1, 2, 2000, 3, 60, {-28800, 0 }}},
|
|
{ "3/1/00 00:00:00", { 000000, 00, 00, 00, 1, 2, 2000, 3, 60, {-28800, 0 }}},
|
|
{ "3/1/2000 00:00:00", { 000000, 00, 00, 00, 1, 2, 2000, 3, 60, {-28800, 0 }}},
|
|
{ "3-1-00 00:00:00", { 000000, 00, 00, 00, 1, 2, 2000, 3, 60, {-28800, 0 }}},
|
|
{ "03-01-00 00:00:00", { 000000, 00, 00, 00, 1, 2, 2000, 3, 60, {-28800, 0 }}},
|
|
{ "03-01-2000 00:00:00", { 000000, 00, 00, 00, 1, 2, 2000, 3, 60, {-28800, 0 }}},
|
|
|
|
/* "Sun". 31-Dec-2000 */
|
|
{ "31 Dec 2000 00:00:00", { 000000, 00, 00, 00, 31, 11, 2000, 0, 365, {-28800, 0 }}},
|
|
{ "12/31/00 00:00:00", { 000000, 00, 00, 00, 31, 11, 2000, 0, 365, {-28800, 0 }}},
|
|
{ "12/31/2000 00:00:00", { 000000, 00, 00, 00, 31, 11, 2000, 0, 365, {-28800, 0 }}},
|
|
{ "12-31-00 00:00:00", { 000000, 00, 00, 00, 31, 11, 2000, 0, 365, {-28800, 0 }}},
|
|
{ "12-31-2000 00:00:00", { 000000, 00, 00, 00, 31, 11, 2000, 0, 365, {-28800, 0 }}},
|
|
{ "00-12-31 00:00:00", { 000000, 00, 00, 00, 31, 11, 2000, 0, 365, {-28800, 0 }}},
|
|
{ "00/12/31 00:00:00", { 000000, 00, 00, 00, 31, 11, 2000, 0, 365, {-28800, 0 }}},
|
|
|
|
/* "Sun". 01-Jan-2001 */
|
|
{ "01 Jan 2001 00:00:00", { 000000, 00, 00, 00, 1, 0, 2001, 1, 0, {-28800, 0 }}},
|
|
{ "1/1/01 00:00:00", { 000000, 00, 00, 00, 1, 0, 2001, 1, 0, {-28800, 0 }}},
|
|
{ "1/1/2001 00:00:00", { 000000, 00, 00, 00, 1, 0, 2001, 1, 0, {-28800, 0 }}},
|
|
{ "1-1-01 00:00:00", { 000000, 00, 00, 00, 1, 0, 2001, 1, 0, {-28800, 0 }}},
|
|
{ "1-1-2001 00:00:00", { 000000, 00, 00, 00, 1, 0, 2001, 1, 0, {-28800, 0 }}},
|
|
{ "01-01-01 00:00:00", { 000000, 00, 00, 00, 1, 0, 2001, 1, 0, {-28800, 0 }}},
|
|
{ "Saturday 01-01-2001 00:00:00", { 000000, 00, 00, 00, 1, 0, 2001, 1, 0, {-28800, 0 }}},
|
|
|
|
/* 01-Mar-2001 */
|
|
{ "01 Mar 2001 00:00:00", { 000000, 00, 00, 00, 1, 2, 2001, 4, 59, {-28800, 0 }}},
|
|
{ "3/1/01 00:00:00", { 000000, 00, 00, 00, 1, 2, 2001, 4, 59, {-28800, 0 }}},
|
|
{ "3/1/2001 00:00:00", { 000000, 00, 00, 00, 1, 2, 2001, 4, 59, {-28800, 0 }}},
|
|
{ "3-1-01 00:00:00", { 000000, 00, 00, 00, 1, 2, 2001, 4, 59, {-28800, 0 }}},
|
|
{ "3-1-2001 00:00:00", { 000000, 00, 00, 00, 1, 2, 2001, 4, 59, {-28800, 0 }}},
|
|
{ "03-01-01 00:00:00", { 000000, 00, 00, 00, 1, 2, 2001, 4, 59, {-28800, 0 }}},
|
|
{ "03-01-2001 00:00:00", { 000000, 00, 00, 00, 1, 2, 2001, 4, 59, {-28800, 0 }}},
|
|
|
|
/* 29-Feb-2004 */
|
|
{ "29 Feb 2004 00:00:00", { 000000, 00, 00, 00, 29, 1, 2004, 0, 59, {-28800, 0 }}},
|
|
{ "2/29/04 00:00:00", { 000000, 00, 00, 00, 29, 1, 2004, 0, 59, {-28800, 0 }}},
|
|
{ "2/29/2004 00:00:00", { 000000, 00, 00, 00, 29, 1, 2004, 0, 59, {-28800, 0 }}},
|
|
{ "2-29-04 00:00:00", { 000000, 00, 00, 00, 29, 1, 2004, 0, 59, {-28800, 0 }}},
|
|
{ "2-29-2004 00:00:00", { 000000, 00, 00, 00, 29, 1, 2004, 0, 59, {-28800, 0 }}},
|
|
|
|
/* 01-Mar-2004 */
|
|
{ "01 Mar 2004 00:00:00", { 000000, 00, 00, 00, 1, 2, 2004, 1, 60, {-28800, 0 }}},
|
|
{ "3/1/04 00:00:00", { 000000, 00, 00, 00, 1, 2, 2004, 1, 60, {-28800, 0 }}},
|
|
{ "3/1/2004 00:00:00", { 000000, 00, 00, 00, 1, 2, 2004, 1, 60, {-28800, 0 }}},
|
|
{ "3-1-04 00:00:00", { 000000, 00, 00, 00, 1, 2, 2004, 1, 60, {-28800, 0 }}},
|
|
{ "3-1-2004 00:00:00", { 000000, 00, 00, 00, 1, 2, 2004, 1, 60, {-28800, 0 }}},
|
|
{ "03-01-04 00:00:00", { 000000, 00, 00, 00, 1, 2, 2004, 1, 60, {-28800, 0 }}},
|
|
{ "03-01-2004 00:00:00", { 000000, 00, 00, 00, 1, 2, 2004, 1, 60, {-28800, 0 }}},
|
|
|
|
/* 01-Mar-2005 */
|
|
{ "01 Mar 2005 00:00:00", { 000000, 00, 00, 00, 1, 2, 2005, 2, 59, {-28800, 0 }}},
|
|
{ "3/1/05 00:00:00", { 000000, 00, 00, 00, 1, 2, 2005, 2, 59, {-28800, 0 }}},
|
|
{ "3/1/2005 00:00:00", { 000000, 00, 00, 00, 1, 2, 2005, 2, 59, {-28800, 0 }}},
|
|
{ "3-1-05 00:00:00", { 000000, 00, 00, 00, 1, 2, 2005, 2, 59, {-28800, 0 }}},
|
|
{ "3-1-2005 00:00:00", { 000000, 00, 00, 00, 1, 2, 2005, 2, 59, {-28800, 0 }}},
|
|
{ "03-01-05 00:00:00", { 000000, 00, 00, 00, 1, 2, 2005, 2, 59, {-28800, 0 }}},
|
|
{ "03-01-2005 00:00:00", { 000000, 00, 00, 00, 1, 2, 2005, 2, 59, {-28800, 0 }}},
|
|
|
|
/* last element. string must be null */
|
|
{ NULL }
|
|
}; /* end array of ParseTest */
|
|
|
|
/*
|
|
** TestParseTime() -- Test PR_ParseTimeString() for y2k compliance
|
|
**
|
|
** TestParseTime() loops thru the array parseArray. For each element in
|
|
** the array, he calls PR_ParseTimeString() with sDate as the conversion
|
|
** argument. The result (ct) is then converted to a PRExplodedTime structure
|
|
** and compared with the exploded time value (parseArray[n].et) in the
|
|
** array element; if equal, the element passes the test.
|
|
**
|
|
** The array parseArray[] contains entries that are interesting to the
|
|
** y2k problem.
|
|
**
|
|
**
|
|
*/
|
|
static PRStatus TestParseTime( void )
|
|
{
|
|
ParseTest *ptp = parseArray;
|
|
PRTime ct;
|
|
PRExplodedTime cet;
|
|
char *sp = ptp->sDate;
|
|
PRStatus rc;
|
|
PRStatus rv = PR_SUCCESS;
|
|
|
|
while ( sp != NULL)
|
|
{
|
|
rc = PR_ParseTimeString( sp, PR_FALSE, &ct );
|
|
if ( PR_FAILURE == rc )
|
|
{
|
|
printf("TestParseTime(): PR_ParseTimeString() failed to convert: %s\n", sp );
|
|
rv = PR_FAILURE;
|
|
failed_already = 1;
|
|
}
|
|
else
|
|
{
|
|
PR_ExplodeTime( ct, PR_LocalTimeParameters , &cet );
|
|
|
|
if ( !ExplodedTimeIsEqual( &cet, &ptp->et ))
|
|
{
|
|
printf("TestParseTime(): Exploded time compare failed: %s\n", sp );
|
|
if ( debug_mode )
|
|
{
|
|
PrintExplodedTime( &cet );
|
|
printf("\n");
|
|
PrintExplodedTime( &ptp->et );
|
|
printf("\n");
|
|
}
|
|
|
|
rv = PR_FAILURE;
|
|
failed_already = 1;
|
|
}
|
|
}
|
|
|
|
/* point to next element in array, keep going */
|
|
ptp++;
|
|
sp = ptp->sDate;
|
|
} /* end while() */
|
|
|
|
return( rv );
|
|
} /* end TestParseTime() */
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
/* The command line argument: -d is used to determine if the test is being run
|
|
in debug mode. The regress tool requires only one line output:PASS or FAIL.
|
|
All of the printfs associated with this test has been handled with a if (debug_mode)
|
|
test.
|
|
Usage: test_name -d
|
|
*/
|
|
PLOptStatus os;
|
|
PLOptState *opt;
|
|
|
|
PR_STDIO_INIT();
|
|
opt = PL_CreateOptState(argc, argv, "d");
|
|
while (PL_OPT_EOL != (os = PL_GetNextOpt(opt)))
|
|
{
|
|
if (PL_OPT_BAD == os) continue;
|
|
switch (opt->option)
|
|
{
|
|
case 'd': /* debug mode */
|
|
debug_mode = PR_TRUE;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
PL_DestroyOptState(opt);
|
|
|
|
/* main test */
|
|
|
|
PR_Init(PR_USER_THREAD, PR_PRIORITY_NORMAL, 0);
|
|
lm = PR_NewLogModule("test");
|
|
|
|
if ( PR_FAILURE == TestExplodeImplodeTime())
|
|
{
|
|
PR_LOG( lm, PR_LOG_ERROR,
|
|
("TestExplodeImplodeTime() failed"));
|
|
}
|
|
else
|
|
printf("Test 1: Calendar Time Test passed\n");
|
|
|
|
if ( PR_FAILURE == TestNormalizeTime())
|
|
{
|
|
PR_LOG( lm, PR_LOG_ERROR,
|
|
("TestNormalizeTime() failed"));
|
|
}
|
|
else
|
|
printf("Test 2: Normalize Time Test passed\n");
|
|
|
|
if ( PR_FAILURE == TestParseTime())
|
|
{
|
|
PR_LOG( lm, PR_LOG_ERROR,
|
|
("TestParseTime() failed"));
|
|
}
|
|
else
|
|
printf("Test 3: Parse Time Test passed\n");
|
|
|
|
if (failed_already)
|
|
return 1;
|
|
else
|
|
return 0;
|
|
} /* end main() y2k.c */
|
|
|