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
|
// |reftest| shell-option(--enable-arraybuffer-resizable) shell-option(--enable-float16array) skip-if(!ArrayBuffer.prototype.resize||!xulRuntime.shell) -- resizable-arraybuffer is not enabled unconditionally, requires shell-options
// Copyright (C) 2021 the V8 project authors. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
esid: sec-get-%typedarray%.prototype.byteoffset
description: |
reset to 0 if the underlying ArrayBuffer is resized beyond the boundary of
the dynamically-sized TypedArray instance
includes: [testTypedArray.js]
features: [TypedArray, resizable-arraybuffer]
---*/
// If the host chooses to throw as allowed by the specification, the observed
// behavior will be identical to the case where `ArrayBuffer.prototype.resize`
// has not been implemented. The following assertion prevents this test from
// passing in runtimes which have not implemented the method.
assert.sameValue(typeof ArrayBuffer.prototype.resize, "function");
testWithTypedArrayConstructors(function(TA) {
var BPE = TA.BYTES_PER_ELEMENT;
var ab = new ArrayBuffer(BPE * 4, {maxByteLength: BPE * 5});
var array = new TA(ab, BPE);
assert.sameValue(array.byteOffset, BPE);
try {
ab.resize(BPE * 5);
} catch (_) {}
assert.sameValue(array.byteOffset, BPE, "following grow");
try {
ab.resize(BPE * 3);
} catch (_) {}
assert.sameValue(array.byteOffset, BPE, "following shrink (within bounds)");
try {
ab.resize(BPE);
} catch (_) {}
assert.sameValue(array.byteOffset, BPE, "following shrink (on boundary)");
var expected = BPE;
try {
ab.resize(0);
expected = 0;
} catch (_) {}
assert.sameValue(array.byteOffset, expected, "following shrink (out of bounds)");
});
reportCompare(0, 0);
|