initial import
[vuplus_webkit] / Source / JavaScriptCore / tests / mozilla / ecma / Date / 15.9.5.10-2.js
1 /* The contents of this file are subject to the Netscape Public
2  * License Version 1.1 (the "License"); you may not use this file
3  * except in compliance with the License. You may obtain a copy of
4  * the License at http://www.mozilla.org/NPL/
5  *
6  * Software distributed under the License is distributed on an "AS
7  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
8  * implied. See the License for the specific language governing
9  * rights and limitations under the License.
10  *
11  * The Original Code is Mozilla Communicator client code, released March
12  * 31, 1998.
13  *
14  * The Initial Developer of the Original Code is Netscape Communications
15  * Corporation. Portions created by Netscape are
16  * Copyright (C) 1998 Netscape Communications Corporation. All
17  * Rights Reserved.
18  *
19  * Contributor(s): 
20  * 
21  */
22 /**
23     File Name:          15.9.5.10.js
24     ECMA Section:       15.9.5.10
25     Description:        Date.prototype.getDate
26
27     1.Let t be this time value.
28     2.If t is NaN, return NaN.
29     3.Return DateFromTime(LocalTime(t)).
30
31     Author:             christine@netscape.com
32     Date:               12 november 1997
33 */
34
35     var SECTION = "15.9.5.10";
36     var VERSION = "ECMA_1";
37     startTest();
38     var TITLE   = "Date.prototype.getDate()";
39
40     writeHeaderToLog( SECTION + " "+ TITLE);
41
42     var testcases = new Array();
43
44     var TZ_ADJUST = TZ_DIFF * msPerHour;
45
46     // get the current time
47     var now = (new Date()).valueOf();
48
49     // get time for 29 feb 2000
50
51     var UTC_FEB_29_2000 = TIME_2000 + 31*msPerDay + 28*msPerHour;
52
53     // get time for 1 jan 2005
54
55     var UTC_JAN_1_2005 = TIME_2000 + TimeInYear(2000)+TimeInYear(2001)+
56     TimeInYear(2002)+TimeInYear(2003)+TimeInYear(2004);
57
58     // some daylight savings time cases
59
60     var DST_START_1998 = UTC( GetSecondSundayInMarch(TimeFromYear(1998)) + 2*msPerHour )
61
62     var DST_END_1998 = UTC( GetFirstSundayInNovember(TimeFromYear(1998)) + 2*msPerHour );
63
64     addTestCase( TIME_YEAR_0 );
65 /*
66     addTestCase( TIME_1970 );
67     addTestCase( TIME_1900 );
68     addTestCase( TIME_2000 );
69     addTestCase( UTC_FEB_29_2000 );
70     addTestCase( UTC_JAN_1_2005 );
71     addTestCase( DST_START_1998 );
72     addTestCase( DST_START_1998-1 );
73     addTestCase( DST_START_1998+1 );
74     addTestCase( DST_END_1998 );
75     addTestCase( DST_END_1998-1 );
76     addTestCase( DST_END_1998+1 );
77 */
78
79     testcases[tc++] = new TestCase( SECTION,
80                                     "(new Date(NaN)).getDate()",
81                                     NaN,
82                                     (new Date(NaN)).getDate() );
83
84     testcases[tc++] = new TestCase( SECTION,
85                                     "Date.prototype.getDate.length",
86                                     0,
87                                     Date.prototype.getDate.length );
88     test();
89 function addTestCase( t ) {
90     for ( d = 0; d < TimeInMonth(MonthFromTime(t)); d+= msPerDay ) {
91         t += d;
92         testcases[tc++] = new TestCase( SECTION,
93                                     "(new Date("+t+")).getDate()",
94                                     DateFromTime(LocalTime(t)),
95                                     (new Date(t)).getDate() );
96     }
97 }
98 function test() {
99     for ( tc=0; tc < testcases.length; tc++ ) {
100         testcases[tc].passed = writeTestCaseResult(
101                             testcases[tc].expect,
102                             testcases[tc].actual,
103                             testcases[tc].description +" = "+
104                             testcases[tc].actual );
105
106         testcases[tc].reason += ( testcases[tc].passed ) ? "" : "wrong value ";
107     }
108     stopTest();
109     return ( testcases );
110 }