1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
// |jit-test| --enable-arraybuffer-resizable; skip-if: !ArrayBuffer.prototype.resize
// Test TypedArray constructor when called with resizable ArrayBuffers.
function testArrayBuffer() {
function test() {
var ab = new ArrayBuffer(4 * Int32Array.BYTES_PER_ELEMENT, {maxByteLength: 5 * Int32Array.BYTES_PER_ELEMENT});
for (var i = 0; i < 200; ++i) {
var ta = new Int32Array(ab);
assertEq(ta.length, 4);
// Ensure auto-length tracking works correctly.
ab.resize(5 * Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 5);
ab.resize(2 * Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 2);
// Reset to original length.
ab.resize(4 * Int32Array.BYTES_PER_ELEMENT);
}
}
for (var i = 0; i < 2; ++i) {
test();
}
}
testArrayBuffer();
function testArrayBufferAndByteOffset() {
function test() {
var ab = new ArrayBuffer(4 * Int32Array.BYTES_PER_ELEMENT, {maxByteLength: 5 * Int32Array.BYTES_PER_ELEMENT});
for (var i = 0; i < 200; ++i) {
var ta = new Int32Array(ab, Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 3);
// Ensure auto-length tracking works correctly.
ab.resize(5 * Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 4);
ab.resize(2 * Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 1);
// Reset to original length.
ab.resize(4 * Int32Array.BYTES_PER_ELEMENT);
}
}
for (var i = 0; i < 2; ++i) {
test();
}
}
testArrayBufferAndByteOffset();
function testArrayBufferAndByteOffsetAndLength() {
function test() {
var ab = new ArrayBuffer(4 * Int32Array.BYTES_PER_ELEMENT, {maxByteLength: 5 * Int32Array.BYTES_PER_ELEMENT});
for (var i = 0; i < 200; ++i) {
var ta = new Int32Array(ab, Int32Array.BYTES_PER_ELEMENT, 2);
assertEq(ta.length, 2);
// Ensure length doesn't change when resizing the buffer.
ab.resize(5 * Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 2);
// Returns zero when the TypedArray get out-of-bounds.
ab.resize(2 * Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 0);
// Reset to original length.
ab.resize(4 * Int32Array.BYTES_PER_ELEMENT);
}
}
for (var i = 0; i < 2; ++i) {
test();
}
}
testArrayBufferAndByteOffsetAndLength();
function testWrappedArrayBuffer() {
var g = newGlobal();
function test() {
var ab = new g.ArrayBuffer(4 * Int32Array.BYTES_PER_ELEMENT, {maxByteLength: 5 * Int32Array.BYTES_PER_ELEMENT});
for (var i = 0; i < 200; ++i) {
var ta = new Int32Array(ab);
assertEq(ta.length, 4);
// Ensure auto-length tracking works correctly.
ab.resize(5 * Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 5);
ab.resize(2 * Int32Array.BYTES_PER_ELEMENT);
assertEq(ta.length, 2);
// Reset to original length.
ab.resize(4 * Int32Array.BYTES_PER_ELEMENT);
}
}
for (var i = 0; i < 2; ++i) {
test();
}
}
testWrappedArrayBuffer();
|