Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(14)

Side by Side Diff: test/mjsunit/harmony/typedarrays-foreach.js

Issue 1130413010: Test that TypedArray methods don't read length (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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: --harmony-arrays --allow-natives-syntax 5 // Flags: --harmony-arrays --allow-natives-syntax
6 6
7 var typedArrayConstructors = [ 7 var typedArrayConstructors = [
8 Uint8Array, 8 Uint8Array,
9 Int8Array, 9 Int8Array,
10 Uint16Array, 10 Uint16Array,
(...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after
131 assertThrows(function () { constructor.prototype.forEach.call({}, function (x) {}) }, TypeError); 131 assertThrows(function () { constructor.prototype.forEach.call({}, function (x) {}) }, TypeError);
132 assertThrows(function () { constructor.prototype.forEach.call(0, function (x) {}) }, TypeError); 132 assertThrows(function () { constructor.prototype.forEach.call(0, function (x) {}) }, TypeError);
133 133
134 // Method must be useable on instances of other typed arrays. 134 // Method must be useable on instances of other typed arrays.
135 for (var i = 0; i < typedArrayConstructors.length; i++) { 135 for (var i = 0; i < typedArrayConstructors.length; i++) {
136 count = 0; 136 count = 0;
137 a = new typedArrayConstructors[i](4); 137 a = new typedArrayConstructors[i](4);
138 constructor.prototype.forEach.call(a, function (x) { count++ }); 138 constructor.prototype.forEach.call(a, function (x) { count++ });
139 assertEquals(a.length, count); 139 assertEquals(a.length, count);
140 } 140 }
141
142 // Shadowing length doesn't affect forEach, unlike Array.prototype.forEach
143 a = new constructor([1, 2]);
144 Object.defineProperty(a, 'length', {value: 1});
145 var x = 0;
146 assertEquals(a.forEach(function(elt) { x += elt; }), undefined);
147 assertEquals(x, 3);
148 assertEquals(Array.prototype.forEach.call(a,
149 function(elt) { x += elt; }), undefined);
150 assertEquals(x, 4);
141 } 151 }
142 152
143 for (i = 0; i < typedArrayConstructors.length; i++) { 153 for (i = 0; i < typedArrayConstructors.length; i++) {
144 TestTypedArrayForEach(typedArrayConstructors[i]); 154 TestTypedArrayForEach(typedArrayConstructors[i]);
145 } 155 }
OLDNEW
« test/mjsunit/harmony/typedarray-fill.js ('K') | « test/mjsunit/harmony/typedarrays-every.js ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698