summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/built-ins/DataView/prototype/byteOffset/resizable-array-buffer-fixed.js
blob: 5790d1689fe18606f10df748a5dcd8d348b30534 (plain)
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
// |reftest| shell-option(--enable-arraybuffer-resizable) 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-dataview.prototype.byteoffset
description: |
  throws a TypeError if the underlying ArrayBuffer is resized beyond the
  boundary of the fixed-sized DataView instance
features: [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");

var ab = new ArrayBuffer(4, {maxByteLength: 5});
var dataView = new DataView(ab, 1, 2);

assert.sameValue(dataView.byteOffset, 1);

try {
  ab.resize(5);
} catch (_) {}

assert.sameValue(dataView.byteOffset, 1, "following grow");

try {
  ab.resize(BPE * 3);
} catch (_) {}

assert.sameValue(dataView.byteOffset, 1, "following shrink (within bounds)");

var expectedError;
try {
  ab.resize(2);
  expectedError = TypeError;
} catch (_) {
  expectedError = Test262Error;
}

assert.throws(expectedError, function() {
  dataView.byteOffset;
  throw new Test262Error('the operation completed successfully');
});

reportCompare(0, 0);