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.3.1.js 24 ECMA Section: 15.9.3.1 new Date (year, month, date, hours, minutes, seconds, ms) 25 Description: The [[Prototype]] property of the newly constructed 26 object is set to the original Date prototype object, 27 the one that is the initial value of Date.prototype. 28 29 The [[Class]] property of the newly constructed object 30 is set as follows: 31 1. Call ToNumber(year) 32 2. Call ToNumber(month) 33 3. Call ToNumber(date) 34 4. Call ToNumber(hours) 35 5. Call ToNumber(minutes) 36 6. Call ToNumber(seconds) 37 7. Call ToNumber(ms) 38 8. If Result(1) is NaN and 0 <= ToInteger(Result(1)) <= 39 99, Result(8) is 1900+ToInteger(Result(1)); otherwise, 40 Result(8) is Result(1) 41 9. Compute MakeDay(Result(8), Result(2), Result(3) 42 10. Compute MakeTime(Result(4), Result(5), Result(6), 43 Result(7) 44 11. Compute MakeDate(Result(9), Result(10)) 45 12. Set the [[Value]] property of the newly constructed 46 object to TimeClip(UTC(Result(11))). 47 48 49 This tests the returned value of a newly constructed 50 Date object. 51 52 Author: christine@netscape.com 53 Date: 7 july 1997 54*/ 55 56 var SECTION = "15.9.3.1"; 57 var VERSION = "ECMA_1"; 58 startTest(); 59 var TITLE = "new Date( year, month, date, hours, minutes, seconds, ms )"; 60 61 var TIME = 0; 62 var UTC_YEAR = 1; 63 var UTC_MONTH = 2; 64 var UTC_DATE = 3; 65 var UTC_DAY = 4; 66 var UTC_HOURS = 5; 67 var UTC_MINUTES = 6; 68 var UTC_SECONDS = 7; 69 var UTC_MS = 8; 70 71 var YEAR = 9; 72 var MONTH = 10; 73 var DATE = 11; 74 var DAY = 12; 75 var HOURS = 13; 76 var MINUTES = 14; 77 var SECONDS = 15; 78 var MS = 16; 79 80 writeHeaderToLog( SECTION + " "+ TITLE); 81 82 var testcases = new Array(); 83 84 getTestCases(); 85 test(); 86 87function getTestCases( ) { 88 // all the "ResultArrays" below are hard-coded to Pacific Standard Time values - 89 var TZ_ADJUST = TZ_PST * msPerHour; 90 91 // Dates around 29 Feb 2000 92 93 var UTC_FEB_29_2000 = TIME_2000 + ( 30 * msPerDay ) + ( 29 * msPerDay ); 94 95 addNewTestCase( new Date(2000,1,28,16,0,0,0), 96 "new Date(2000,1,28,16,0,0,0)", 97 [UTC_FEB_29_2000,2000,1,29,2,0,0,0,0,2000,1,28,1,16,0,0,0] ); 98 99 addNewTestCase( new Date(2000,1,29,0,0,0,0), 100 "new Date(2000,1,29,0,0,0,0)", 101 [UTC_FEB_29_2000-TZ_ADJUST,2000,1,29,2,8,0,0,0,2000,1,29,2,0,0,0,0] ); 102 103 addNewTestCase( new Date(2000,1,28,24,0,0,0), 104 "new Date(2000,1,28,24,0,0,0)", 105 [UTC_FEB_29_2000-TZ_ADJUST,2000,1,29,2,8,0,0,0,2000,1,29,2,0,0,0,0] ); 106/* 107 // Dates around 1900 108 109 addNewTestCase( new Date(1899,11,31,16,0,0,0), 110 "new Date(1899,11,31,16,0,0,0)", 111 [TIME_1900,1900,0,1,1,0,0,0,0,1899,11,31,0,16,0,0,0] ); 112 113 addNewTestCase( new Date(1899,11,31,15,59,59,999), 114 "new Date(1899,11,31,15,59,59,999)", 115 [TIME_1900-1,1899,11,31,0,23,59,59,999,1899,11,31,0,15,59,59,999] ); 116 117 addNewTestCase( new Date(1899,11,31,23,59,59,999), 118 "new Date(1899,11,31,23,59,59,999)", 119 [TIME_1900-TZ_ADJUST-1,1900,0,1,1,7,59,59,999,1899,11,31,0,23,59,59,999] ); 120 121 addNewTestCase( new Date(1900,0,1,0,0,0,0), 122 "new Date(1900,0,1,0,0,0,0)", 123 [TIME_1900-TZ_ADJUST,1900,0,1,1,8,0,0,0,1900,0,1,1,0,0,0,0] ); 124 125 addNewTestCase( new Date(1900,0,1,0,0,0,1), 126 "new Date(1900,0,1,0,0,0,1)", 127 [TIME_1900-TZ_ADJUST+1,1900,0,1,1,8,0,0,1,1900,0,1,1,0,0,0,1] ); 128 129 // Dates around 2005 130 131 var UTC_YEAR_2005 = TIME_2000 + TimeInYear(2000) + TimeInYear(2001) + 132 TimeInYear(2002) + TimeInYear(2003) + TimeInYear(2004); 133 134 addNewTestCase( new Date(2005,0,1,0,0,0,0), 135 "new Date(2005,0,1,0,0,0,0)", 136 [UTC_YEAR_2005-TZ_ADJUST,2005,0,1,6,8,0,0,0,2005,0,1,6,0,0,0,0] ); 137 138 addNewTestCase( new Date(2004,11,31,16,0,0,0), 139 "new Date(2004,11,31,16,0,0,0)", 140 [UTC_YEAR_2005,2005,0,1,6,0,0,0,0,2004,11,31,5,16,0,0,0] ); 141*/ 142/* 143 This test case is incorrect. Need to fix the DaylightSavings functions in 144 shell.js for this to work properly. 145 146 // Daylight Savings test case 147 148 var DST_START_1998 = UTC( GetSecondSundayInMarch(TimeFromYear(1998)) + 2*msPerHour ) 149 150 addNewTestCase( new Date(1998,3,5,1,59,59,999), 151 "new Date(1998,3,5,1,59,59,999)", 152 [DST_START_1998-1,1998,3,5,0,9,59,59,999,1998,3,5,0,1,59,59,999] ); 153 154 addNewTestCase( new Date(1998,3,5,2,0,0,0), 155 "new Date(1998,3,5,2,0,0,0)", 156 [DST_START_1998,1998,3,5,0,10,0,0,0,1998,3,5,0,3,0,0,0]); 157 158 var DST_END_1998 = UTC( GetFirstSundayInNovember(TimeFromYear(1998)) + 2*msPerHour ); 159 160 addNewTestCase ( new Date(1998,9,25,1,59,59,999), 161 "new Date(1998,9,25,1,59,59,999)", 162 [DST_END_1998-1,1998,9,25,0,8,59,59,999,1998,9,25,0,1,59,59,999] ); 163 164 addNewTestCase ( new Date(1998,9,25,2,0,0,0), 165 "new Date(1998,9,25,2,0,0,0)", 166 [DST_END_1998,1998,9,25,0,9,0,0,0,1998,9,25,0,1,0,0,0] ); 167*/ 168} 169 170function addNewTestCase( DateCase, DateString, ResultArray ) { 171 //adjust hard-coded ResultArray for tester's timezone instead of PST 172 adjustResultArray(ResultArray); 173 174 var item = testcases.length; 175 176 testcases[item++] = new TestCase( SECTION, DateString+".getTime()", ResultArray[TIME], DateCase.getTime() ); 177 testcases[item++] = new TestCase( SECTION, DateString+".valueOf()", ResultArray[TIME], DateCase.valueOf() ); 178 179 testcases[item++] = new TestCase( SECTION, DateString+".getUTCFullYear()", ResultArray[UTC_YEAR], DateCase.getUTCFullYear() ); 180 testcases[item++] = new TestCase( SECTION, DateString+".getUTCMonth()", ResultArray[UTC_MONTH], DateCase.getUTCMonth() ); 181 testcases[item++] = new TestCase( SECTION, DateString+".getUTCDate()", ResultArray[UTC_DATE], DateCase.getUTCDate() ); 182 testcases[item++] = new TestCase( SECTION, DateString+".getUTCDay()", ResultArray[UTC_DAY], DateCase.getUTCDay() ); 183 testcases[item++] = new TestCase( SECTION, DateString+".getUTCHours()", ResultArray[UTC_HOURS], DateCase.getUTCHours() ); 184 testcases[item++] = new TestCase( SECTION, DateString+".getUTCMinutes()", ResultArray[UTC_MINUTES],DateCase.getUTCMinutes() ); 185 testcases[item++] = new TestCase( SECTION, DateString+".getUTCSeconds()", ResultArray[UTC_SECONDS],DateCase.getUTCSeconds() ); 186 testcases[item++] = new TestCase( SECTION, DateString+".getUTCMilliseconds()", ResultArray[UTC_MS], DateCase.getUTCMilliseconds() ); 187 188 testcases[item++] = new TestCase( SECTION, DateString+".getFullYear()", ResultArray[YEAR], DateCase.getFullYear() ); 189 testcases[item++] = new TestCase( SECTION, DateString+".getMonth()", ResultArray[MONTH], DateCase.getMonth() ); 190 testcases[item++] = new TestCase( SECTION, DateString+".getDate()", ResultArray[DATE], DateCase.getDate() ); 191 testcases[item++] = new TestCase( SECTION, DateString+".getDay()", ResultArray[DAY], DateCase.getDay() ); 192 testcases[item++] = new TestCase( SECTION, DateString+".getHours()", ResultArray[HOURS], DateCase.getHours() ); 193 testcases[item++] = new TestCase( SECTION, DateString+".getMinutes()", ResultArray[MINUTES], DateCase.getMinutes() ); 194 testcases[item++] = new TestCase( SECTION, DateString+".getSeconds()", ResultArray[SECONDS], DateCase.getSeconds() ); 195 testcases[item++] = new TestCase( SECTION, DateString+".getMilliseconds()", ResultArray[MS], DateCase.getMilliseconds() ); 196} 197 198function test() { 199 for( tc = 0; tc < testcases.length; tc++ ) { 200 201 testcases[tc].passed = writeTestCaseResult( 202 testcases[tc].expect, 203 testcases[tc].actual, 204 testcases[tc].description +" = " + 205 testcases[tc].actual ); 206 } 207 stopTest(); 208 return testcases; 209} 210