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
|
// |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-%typedarray%.prototype.join
description: Return abrupt when "this" value fails buffer boundary checks
includes: [testTypedArray.js]
features: [TypedArray, resizable-arraybuffer]
---*/
assert.sameValue(
typeof TypedArray.prototype.join,
'function',
'implements TypedArray.prototype.join'
);
assert.sameValue(
typeof ArrayBuffer.prototype.resize,
'function',
'implements ArrayBuffer.prototype.resize'
);
testWithTypedArrayConstructors(TA => {
var BPE = TA.BYTES_PER_ELEMENT;
var ab = new ArrayBuffer(BPE * 4, {maxByteLength: BPE * 5});
var array = new TA(ab, BPE, 2);
try {
ab.resize(BPE * 5);
} catch (_) {}
// no error following grow:
array.join(0);
try {
ab.resize(BPE * 3);
} catch (_) {}
// no error following shrink (within bounds):
array.join(0);
var expectedError;
try {
ab.resize(BPE * 2);
// If the preceding "resize" operation is successful, the typed array will
// be out out of bounds, so the subsequent prototype method should produce
// a TypeError due to the semantics of ValidateTypedArray.
expectedError = TypeError;
} catch (_) {
// The host is permitted to fail any "resize" operation at its own
// discretion. If that occurs, the join operation should complete
// successfully.
expectedError = Test262Error;
}
assert.throws(expectedError, () => {
array.join(0);
throw new Test262Error('join completed successfully');
});
});
reportCompare(0, 0);
|