]> git.saurik.com Git - apple/javascriptcore.git/blob - tests/mozilla/ecma/Date/15.9.5.10-3.js
JavaScriptCore-461.tar.gz
[apple/javascriptcore.git] / tests / mozilla / ecma / Date / 15.9.5.10-3.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_1970 );
65 /*
66 addTestCase( TIME_1900 );
67 addTestCase( TIME_2000 );
68 addTestCase( UTC_FEB_29_2000 );
69 addTestCase( UTC_JAN_1_2005 );
70 addTestCase( DST_START_1998 );
71 addTestCase( DST_START_1998-1 );
72 addTestCase( DST_START_1998+1 );
73 addTestCase( DST_END_1998 );
74 addTestCase( DST_END_1998-1 );
75 addTestCase( DST_END_1998+1 );
76 */
77
78 testcases[tc++] = new TestCase( SECTION,
79 "(new Date(NaN)).getDate()",
80 NaN,
81 (new Date(NaN)).getDate() );
82
83 testcases[tc++] = new TestCase( SECTION,
84 "Date.prototype.getDate.length",
85 0,
86 Date.prototype.getDate.length );
87 test();
88 function addTestCase( t ) {
89 for ( d = 0; d < TimeInMonth(MonthFromTime(t)); d+= msPerDay ) {
90 t += d;
91 testcases[tc++] = new TestCase( SECTION,
92 "(new Date("+t+")).getDate()",
93 DateFromTime(LocalTime(t)),
94 (new Date(t)).getDate() );
95 }
96 }
97 function test() {
98 for ( tc=0; tc < testcases.length; tc++ ) {
99 testcases[tc].passed = writeTestCaseResult(
100 testcases[tc].expect,
101 testcases[tc].actual,
102 testcases[tc].description +" = "+
103 testcases[tc].actual );
104
105 testcases[tc].reason += ( testcases[tc].passed ) ? "" : "wrong value ";
106 }
107 stopTest();
108 return ( testcases );
109 }