/* ***** 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 mozilla.org code. * * The Initial Developer of the Original Code is * Netscape Communications Corporation. * Portions created by the Initial Developer are Copyright (C) 1998 * the Initial Developer. All Rights Reserved. * * Contributor(s): * pschwartau@netscape.com * * 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 ***** * * Date: 14 Mar 2001 * * SUMMARY: Testing the internal [[Class]] property of user-defined types. * See ECMA-262 Edition 3 13-Oct-1999, Section 8.6.2 re [[Class]] property. * * Same as class-001.js - but testing user-defined types here, not native types. * Therefore we expect the [[Class]] property to equal 'Object' in each case - * * The getJSClass() function we use is in a utility file, e.g. "shell.js" */ //------------------------------------------------------------------------------------------------- var i = 0; var UBound = 0; var bug = '(none)'; var summary = 'Testing the internal [[Class]] property of user-defined types'; var statprefix = 'Current user-defined type is: '; var status = ''; var statusList = [ ]; var actual = ''; var actualvalue = [ ]; var expect= ''; var expectedvalue = [ ]; Calf.prototype= new Cow(); /* * We set the expect variable each time only for readability. * We expect 'Object' every time; see discussion above - */ status = 'new Cow()'; actual = getJSClass(new Cow()); expect = 'Object'; addThis(); status = 'new Calf()'; actual = getJSClass(new Calf()); expect = 'Object'; addThis(); //--------------------------------------------------------------------------------- test(); //--------------------------------------------------------------------------------- function addThis() { statusList[UBound] = status; actualvalue[UBound] = actual; expectedvalue[UBound] = expect; UBound++; } function test() { enterFunc ('test'); printBugNumber (bug); printStatus (summary); for (i = 0; i < UBound; i++) { reportCompare(expectedvalue[i], actualvalue[i], getStatus(i)); } exitFunc ('test'); } function getStatus(i) { return statprefix + statusList[i]; } function Cow(name) { this.name=name; } function Calf(name) { this.name=name; }