15.9.2.1.js   [plain text]


/* The contents of this file are subject to the Netscape 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/NPL/
 *
 * 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 Mozilla Communicator client code, released March
 * 31, 1998.
 *
 * The Initial Developer of the Original Code is Netscape Communications
 * Corporation. Portions created by Netscape are
 * Copyright (C) 1998 Netscape Communications Corporation. All
 * Rights Reserved.
 *
 * Contributor(s): 
 * 
 */
/**
    File Name:          15.9.2.1.js
    ECMA Section:       15.9.2.1 Date constructor used as a function
                        Date( year, month, date, hours, minutes, seconds, ms )
    Description:        The arguments are accepted, but are completely ignored.
                        A string is created and returned as if by the
                        expression (new Date()).toString().

    Author:             christine@netscape.com
    Date:               28 october 1997

*/
    var VERSION =   "ECMA_1";
    startTest();
    var SECTION =   "15.9.2.1";
    var TITLE =     "Date Constructor used as a function";
    var TYPEOF  =   "string";

    writeHeaderToLog("15.9.2.1 The Date Constructor Called as a Function:  " +
                     "Date( year, month, date, hours, minutes, seconds, ms )" );
    var tc= 0;
    var testcases = getTestCases();

//  all tests must call a function that returns an array of TestCase objects.
    test();

function getTestCases() {
    var array = new Array();
    var item = 0;

    var TODAY = new Date();

    // allow up to 1 second difference due to possibility
    // the date may change by 1 second in between calls to Date

    var d1;
    var d2;

    // Dates around 1970

    d1 = new Date();
    d2 = Date.parse(Date(1970,0,1,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(1970,0,1,0,0,0,0)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(1969,11,31,15,59,59,999));
    array[item++] = new TestCase(SECTION, "Date(1969,11,31,15,59,59,999)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(1969,11,31,16,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(1969,11,31,16,0,0,0)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(1969,11,31,16,0,0,1));
    array[item++] = new TestCase(SECTION, "Date(1969,11,31,16,0,0,1)", true, d2 - d1 <= 1000);

    // Dates around 2000
    d1 = new Date();
    d2 = Date.parse(Date(1999,11,15,59,59,999));
    array[item++] = new TestCase(SECTION, "Date(1999,11,15,59,59,999)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(1999,11,16,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(1999,11,16,0,0,0,0)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(1999,11,31,23,59,59,999));
    array[item++] = new TestCase(SECTION, "Date(1999,11,31,23,59,59,999)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2000,0,0,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(2000,0,1,0,0,0,0)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2000,0,0,0,0,0,1));
    array[item++] = new TestCase(SECTION, "Date(2000,0,1,0,0,0,1)", true, d2 - d1 <= 1000);

    // Dates around 1900

    d1 = new Date();
    d2 = Date.parse(Date(1899,11,31,23,59,59,999));
    array[item++] = new TestCase(SECTION, "Date(1899,11,31,23,59,59,999)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(1900,0,1,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(1900,0,1,0,0,0,0)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(1900,0,1,0,0,0,1));
    array[item++] = new TestCase(SECTION, "Date(1900,0,1,0,0,0,1)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(1899,11,31,16,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(1899,11,31,16,0,0,0,0)", true, d2 - d1 <= 1000);

    // Dates around feb 29, 2000

    d1 = new Date();
    d2 = Date.parse(Date(2000,1,29,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(2000,1,29,0,0,0,0)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2000,1,28,23,59,59,999));
    array[item++] = new TestCase(SECTION, "Date(2000,1,28,23,59,59,999)", true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2000,1,27,16,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(2000,1,27,16,0,0,0)", true, d2 - d1 <= 1000);

    // Dates around jan 1, 2005
    d1 = new Date();
    d2 = Date.parse(Date(2004,11,31,23,59,59,999));
    array[item++] = new TestCase(SECTION, "Date(2004,11,31,23,59,59,999)",  true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2005,0,1,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(2005,0,1,0,0,0,0)",  true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2005,0,1,0,0,0,1));
    array[item++] = new TestCase(SECTION, "Date(2005,0,1,0,0,0,1)",  true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2004,11,31,16,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(2004,11,31,16,0,0,0,0)",  true, d2 - d1 <= 1000);

    // Dates around jan 1, 2032
    d1 = new Date();
    d2 = Date.parse(Date(2031,11,31,23,59,59,999));
    array[item++] = new TestCase(SECTION, "Date(2031,11,31,23,59,59,999)",  true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2032,0,1,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(2032,0,1,0,0,0,0)",  true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2032,0,1,0,0,0,1));
    array[item++] = new TestCase(SECTION, "Date(2032,0,1,0,0,0,1)",  true, d2 - d1 <= 1000);

    d1 = new Date();
    d2 = Date.parse(Date(2031,11,31,16,0,0,0,0));
    array[item++] = new TestCase(SECTION, "Date(2031,11,31,16,0,0,0,0)",  true, d2 - d1 <= 1000);

    return ( array );
}
function test() {
    for ( tc=0; tc < testcases.length; tc++ ) {
        testcases[tc].passed = writeTestCaseResult(
                            testcases[tc].expect,
                            testcases[tc].actual,
                            testcases[tc].description +" = "+
                            testcases[tc].actual );

        testcases[tc].reason += ( testcases[tc].passed ) ? "" : "wrong value ";
    }
    stopTest();
    return ( testcases );
}