PR-URL: https://github.com/nodejs/node/pull/58070 Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com> Reviewed-By: Darshan Sen <raisinten@gmail.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com>
64 lines
2.1 KiB
JavaScript
64 lines
2.1 KiB
JavaScript
// Copyright 2025 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --allow-natives-syntax --js-staging
|
|
// Flags: --experimental-wasm-rab-integration
|
|
|
|
'use strict';
|
|
|
|
d8.file.execute('test/mjsunit/typedarray-helpers.js');
|
|
|
|
const kPageSize = 0x10000;
|
|
|
|
function Pad(a, v, start, ctor, pages) {
|
|
for (let i = start; i < (pages * kPageSize) / ctor.BYTES_PER_ELEMENT; ++i) {
|
|
a.push(v);
|
|
}
|
|
}
|
|
|
|
function ZeroPad(a, start, ctor, pages) {
|
|
Pad(a, 0, start, ctor, pages);
|
|
}
|
|
|
|
(function ArrayFlatParameterConversionGrows() {
|
|
const flatHelper = ArrayFlatHelper;
|
|
for (let ctor of ctors) {
|
|
const rab = CreateResizableArrayBufferViaWasm(1, 2);
|
|
const lengthTracking = new ctor(rab);
|
|
for (let i = 0; i < 4; ++i) {
|
|
WriteToTypedArray(lengthTracking, i, i + 1);
|
|
}
|
|
const evil = { valueOf: () => { rab.resize(2 * kPageSize);
|
|
return 0; }};
|
|
// The original length is used.
|
|
let expectedLengthTrackingFlat = [1, 2, 3, 4];
|
|
ZeroPad(expectedLengthTrackingFlat, 4, ctor, 1);
|
|
assertEquals(expectedLengthTrackingFlat, ToNumbers(flatHelper(lengthTracking, evil)));
|
|
assertEquals(2 * kPageSize, rab.byteLength);
|
|
}
|
|
})();
|
|
|
|
(function ArrayFlatParameterConversionDetaches() {
|
|
const flatHelper = ArrayFlatHelper;
|
|
for (let ctor of ctors) {
|
|
const rab = CreateResizableArrayBufferViaWasm(1, 2);
|
|
const fixedLength = new ctor(rab, 0, 4);
|
|
const evil = { valueOf: () => { %ArrayBufferDetachForceWasm(rab);
|
|
return 0; }};
|
|
assertEquals([], flatHelper(fixedLength, evil));
|
|
assertEquals(0, rab.byteLength);
|
|
}
|
|
for (let ctor of ctors) {
|
|
const rab = CreateResizableArrayBufferViaWasm(1, 2);
|
|
const lengthTracking = new ctor(rab);
|
|
for (let i = 0; i < 4; ++i) {
|
|
WriteToTypedArray(lengthTracking, i, i + 1);
|
|
}
|
|
const evil = { valueOf: () => { %ArrayBufferDetachForceWasm(rab);
|
|
return 0; }};
|
|
assertEquals([], ToNumbers(flatHelper(lengthTracking, evil)));
|
|
assertEquals(0, rab.byteLength);
|
|
}
|
|
})();
|