michael@0: /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ michael@0: /* This Source Code Form is subject to the terms of the Mozilla Public michael@0: * License, v. 2.0. If a copy of the MPL was not distributed with this michael@0: * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ michael@0: michael@0: /* michael@0: * michael@0: * Date: 10 Apr 2002 michael@0: * Revised: 14 July 2002 michael@0: * michael@0: * SUMMARY: JS should NOT error on |for(i in undefined)|, |for(i in null)| michael@0: * michael@0: * ECMA-262 3rd Edition Final spec says such statements SHOULD error. See: michael@0: * michael@0: * Section 12.6.4 The for-in Statement michael@0: * Section 9.9 ToObject michael@0: * michael@0: * michael@0: * But SpiderMonkey has decided NOT to follow this; it's a bug in the spec. michael@0: * See http://bugzilla.mozilla.org/show_bug.cgi?id=131348 michael@0: * michael@0: * Update: Rhino has also decided not to follow the spec on this michael@0: * See http://bugzilla.mozilla.org/show_bug.cgi?id=136893 michael@0: */ michael@0: //----------------------------------------------------------------------------- michael@0: var UBound = 0; michael@0: var BUGNUMBER = 131348; michael@0: var summary = 'JS should not error on |for(i in undefined)|, |for(i in null)|'; michael@0: var TEST_PASSED = 'No error'; michael@0: var TEST_FAILED = 'An error was generated!!!'; michael@0: var status = ''; michael@0: var statusitems = []; michael@0: var actual = ''; michael@0: var actualvalues = []; michael@0: var expect= ''; michael@0: var expectedvalues = []; michael@0: michael@0: michael@0: michael@0: status = inSection(1); michael@0: expect = TEST_PASSED; michael@0: actual = TEST_PASSED; michael@0: try michael@0: { michael@0: for (var i in undefined) michael@0: { michael@0: print(i); michael@0: } michael@0: } michael@0: catch(e) michael@0: { michael@0: actual = TEST_FAILED; michael@0: } michael@0: addThis(); michael@0: michael@0: michael@0: michael@0: status = inSection(2); michael@0: expect = TEST_PASSED; michael@0: actual = TEST_PASSED; michael@0: try michael@0: { michael@0: for (var i in null) michael@0: { michael@0: print(i); michael@0: } michael@0: } michael@0: catch(e) michael@0: { michael@0: actual = TEST_FAILED; michael@0: } michael@0: addThis(); michael@0: michael@0: michael@0: michael@0: status = inSection(3); michael@0: expect = TEST_PASSED; michael@0: actual = TEST_PASSED; michael@0: /* michael@0: * Variable names that cannot be looked up generate ReferenceErrors; however, michael@0: * property names like obj.ZZZ that cannot be looked up are set to |undefined| michael@0: * michael@0: * Therefore, this should indirectly test | for (var i in undefined) | michael@0: */ michael@0: try michael@0: { michael@0: for (var i in this.ZZZ) michael@0: { michael@0: print(i); michael@0: } michael@0: } michael@0: catch(e) michael@0: { michael@0: actual = TEST_FAILED; michael@0: } michael@0: addThis(); michael@0: michael@0: michael@0: michael@0: status = inSection(4); michael@0: expect = TEST_PASSED; michael@0: actual = TEST_PASSED; michael@0: /* michael@0: * The result of an unsuccessful regexp match is the null value michael@0: * Therefore, this should indirectly test | for (var i in null) | michael@0: */ michael@0: try michael@0: { michael@0: for (var i in 'bbb'.match(/aaa/)) michael@0: { michael@0: print(i); michael@0: } michael@0: } michael@0: catch(e) michael@0: { michael@0: actual = TEST_FAILED; michael@0: } michael@0: addThis(); michael@0: michael@0: michael@0: michael@0: michael@0: //----------------------------------------------------------------------------- michael@0: test(); michael@0: //----------------------------------------------------------------------------- michael@0: michael@0: michael@0: michael@0: function addThis() michael@0: { michael@0: statusitems[UBound] = status; michael@0: actualvalues[UBound] = actual; michael@0: expectedvalues[UBound] = expect; michael@0: UBound++; michael@0: } michael@0: michael@0: michael@0: function test() michael@0: { michael@0: enterFunc('test'); michael@0: printBugNumber(BUGNUMBER); michael@0: printStatus(summary); michael@0: michael@0: for (var i=0; i