OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Flags: --allow-natives-syntax | 5 // Flags: --allow-natives-syntax |
6 | 6 |
7 var typedArrayConstructors = [ | 7 var typedArrayConstructors = [ |
8 Uint8Array, | 8 Uint8Array, |
9 Int8Array, | 9 Int8Array, |
10 Uint16Array, | 10 Uint16Array, |
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
141 | 141 |
142 // Shadowing length doesn't affect forEach, unlike Array.prototype.forEach | 142 // Shadowing length doesn't affect forEach, unlike Array.prototype.forEach |
143 a = new constructor([1, 2]); | 143 a = new constructor([1, 2]); |
144 Object.defineProperty(a, 'length', {value: 1}); | 144 Object.defineProperty(a, 'length', {value: 1}); |
145 var x = 0; | 145 var x = 0; |
146 assertEquals(a.forEach(function(elt) { x += elt; }), undefined); | 146 assertEquals(a.forEach(function(elt) { x += elt; }), undefined); |
147 assertEquals(x, 3); | 147 assertEquals(x, 3); |
148 assertEquals(Array.prototype.forEach.call(a, | 148 assertEquals(Array.prototype.forEach.call(a, |
149 function(elt) { x += elt; }), undefined); | 149 function(elt) { x += elt; }), undefined); |
150 assertEquals(x, 4); | 150 assertEquals(x, 4); |
151 | |
152 // Detached Operation | |
153 var array = new constructor([1, 2, 3, 4, 5, 6, 7, 8, 9, 10]); | |
154 %ArrayBufferNeuter(array.buffer); | |
155 assertThrows(() => array.forEach(() => true), TypeError); | |
156 } | 151 } |
157 | 152 |
158 for (i = 0; i < typedArrayConstructors.length; i++) { | 153 for (i = 0; i < typedArrayConstructors.length; i++) { |
159 TestTypedArrayForEach(typedArrayConstructors[i]); | 154 TestTypedArrayForEach(typedArrayConstructors[i]); |
160 } | 155 } |
OLD | NEW |