Index: test/mjsunit/regress/regress-1344252.js |
=================================================================== |
--- test/mjsunit/regress/regress-1344252.js (revision 1547) |
+++ test/mjsunit/regress/regress-1344252.js (working copy) |
@@ -1,76 +0,0 @@ |
-// Copyright 2008 the V8 project authors. All rights reserved. |
-// Redistribution and use in source and binary forms, with or without |
-// modification, are permitted provided that the following conditions are |
-// met: |
-// |
-// * Redistributions of source code must retain the above copyright |
-// notice, this list of conditions and the following disclaimer. |
-// * Redistributions in binary form must reproduce the above |
-// copyright notice, this list of conditions and the following |
-// disclaimer in the documentation and/or other materials provided |
-// with the distribution. |
-// * Neither the name of Google Inc. nor the names of its |
-// contributors may be used to endorse or promote products derived |
-// from this software without specific prior written permission. |
-// |
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
- |
-// Test that setter accessors added to the prototype chain are called |
-// when setting properties. |
- |
-// Test that accessors added to the prototype chain are called |
-// eventhough there are inline caches for setting the property |
- |
-function F() { |
- this.x = 42; |
- this.y = 87; |
-} |
- |
-// Force the inline caches to monomorphic state. |
-new F(); new F(); |
- |
-// Add a setter for x to Object.prototype and make sure it gets |
-// called. |
-var result_x; |
-Object.prototype.__defineSetter__('x', function(value) { result_x = value; }); |
-var f = new F(); |
-assertEquals(42, result_x); |
-assertTrue(typeof f.x == 'undefined'); |
- |
-// Add a setter for y by changing the prototype of f and make sure |
-// that gets called too. |
-var result_y; |
-var proto = new Object(); |
-proto.__defineSetter__('y', function (value) { result_y = value; }); |
-var f = { }; |
-f.__proto__ = proto; |
-F.call(f); |
-assertEquals(87, result_y); |
-assertTrue(typeof f.y == 'undefined'); |
- |
-// Test the same issue in the runtime system. Make sure that |
-// accessors added to the prototype chain are called instead of |
-// following map transitions. |
-// |
-// Create two objects. |
-var result_z; |
-var o1 = new Object(); |
-var o2 = new Object(); |
-// Add a z property to o1 to create a map transition. |
-o1.z = 32; |
-// Add a z accessor in the prototype chain for o1 and o2. |
-Object.prototype.__defineSetter__('z', function(value) { result_z = value; }); |
-// The accessor should be called for o2. |
-o2.z = 27; |
-assertEquals(27, result_z); |
-assertTrue(typeof o2.z == 'undefined'); |