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

Side by Side Diff: test/mjsunit/es6/typedarray-slice.js

Issue 2793233003: Revert of [typedarrays] Check detached buffer at start of typed array methods (Closed)
Patch Set: Created 3 years, 8 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
« no previous file with comments | « test/mjsunit/es6/typedarray-reverse.js ('k') | test/mjsunit/es6/typedarray-sort.js » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 the V8 project authors. All rights reserved. 1 // Copyright 2015 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
6
7 var typedArrayConstructors = [ 5 var typedArrayConstructors = [
8 Uint8Array, 6 Uint8Array,
9 Int8Array, 7 Int8Array,
10 Uint16Array, 8 Uint16Array,
11 Int16Array, 9 Int16Array,
12 Uint32Array, 10 Uint32Array,
13 Int32Array, 11 Int32Array,
14 Uint8ClampedArray, 12 Uint8ClampedArray,
15 Float32Array, 13 Float32Array,
16 Float64Array 14 Float64Array
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after
64 }, TypeError); 62 }, TypeError);
65 63
66 // Check that elements are copied properly in slice 64 // Check that elements are copied properly in slice
67 array = new constructor([1, 2, 3, 4]); 65 array = new constructor([1, 2, 3, 4]);
68 var slice = array.slice(1, 3); 66 var slice = array.slice(1, 3);
69 assertEquals(2, slice.length); 67 assertEquals(2, slice.length);
70 assertEquals(2, slice[0]); 68 assertEquals(2, slice[0]);
71 assertEquals(3, slice[1]); 69 assertEquals(3, slice[1]);
72 assertTrue(slice instanceof constructor); 70 assertTrue(slice instanceof constructor);
73 71
74 // Detached Operation
75 var tmp = {
76 [Symbol.toPrimitive]() {
77 assertUnreachable("Parameter should not be processed when " +
78 "array.[[ViewedArrayBuffer]] is neutered.");
79 return 0;
80 }
81 };
82
83 var array = new constructor([1, 2, 3, 4, 5, 6, 7, 8, 9, 10]);
84 %ArrayBufferNeuter(array.buffer);
85 assertThrows(() => array.slice(tmp, tmp), TypeError);
86
87 // Check that the species array must be a typed array 72 // Check that the species array must be a typed array
88 class MyTypedArray extends constructor { 73 class MyTypedArray extends constructor {
89 static get[Symbol.species]() { 74 static get[Symbol.species]() {
90 return Array; 75 return Array;
91 } 76 }
92 } 77 }
93 var arr = new MyTypedArray([-1.0, 0, 1.1, 255, 256]); 78 var arr = new MyTypedArray([-1.0, 0, 1.1, 255, 256]);
94 assertThrows(() => arr.slice(), TypeError); 79 assertThrows(() => arr.slice(), TypeError);
95 } 80 }
96 81
97 // Check that the result array is properly created by checking species 82 // Check that the result array is properly created by checking species
98 for (var constructor1 of typedArrayConstructors) { 83 for (var constructor1 of typedArrayConstructors) {
99 for (var constructor2 of typedArrayConstructors) { 84 for (var constructor2 of typedArrayConstructors) {
100 class MyTypedArray2 extends constructor1 { 85 class MyTypedArray2 extends constructor1 {
101 static get[Symbol.species]() { 86 static get[Symbol.species]() {
102 return constructor2; 87 return constructor2;
103 } 88 }
104 } 89 }
105 var arr = new MyTypedArray2([-1.0, 0, 1.1, 255, 256]); 90 var arr = new MyTypedArray2([-1.0, 0, 1.1, 255, 256]);
106 var arr2 = new constructor1([-1.0, 0, 1.1, 255, 256]); 91 var arr2 = new constructor1([-1.0, 0, 1.1, 255, 256]);
107 assertEquals(new constructor2(arr2), arr.slice(), 92 assertEquals(new constructor2(arr2), arr.slice(),
108 constructor1.name + ' -> ' + constructor2.name); 93 constructor1.name + ' -> ' + constructor2.name);
109 } 94 }
110 } 95 }
OLDNEW
« no previous file with comments | « test/mjsunit/es6/typedarray-reverse.js ('k') | test/mjsunit/es6/typedarray-sort.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698