Merge pull request #16175 from Snuffleupagus/LoopbackPort-transfer

Fix the `transfer` parameter, for `structuredClone`, in the `LoopbackPort`
This commit is contained in:
Jonas Jenwald 2023-03-20 14:22:09 +01:00 committed by GitHub
commit b1e0253f29
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 15 additions and 25 deletions

View File

@ -1943,9 +1943,9 @@ class LoopbackPort {
#deferred = Promise.resolve();
postMessage(obj, transfers) {
postMessage(obj, transfer) {
const event = {
data: structuredClone(obj, transfers),
data: structuredClone(obj, transfer ? { transfer } : null),
};
this.#deferred.then(() => {

View File

@ -208,10 +208,8 @@ describe("api", function () {
expect(data[0] instanceof PDFDocumentProxy).toEqual(true);
expect(data[1].loaded / data[1].total).toEqual(1);
if (!isNodeJS) {
// Check that the TypedArray was transferred.
expect(typedArrayPdf.length).toEqual(0);
}
await loadingTask.destroy();
});
@ -240,10 +238,8 @@ describe("api", function () {
expect(data[0] instanceof PDFDocumentProxy).toEqual(true);
expect(data[1].loaded / data[1].total).toEqual(1);
if (!isNodeJS) {
// Check that the ArrayBuffer was transferred.
expect(arrayBufferPdf.byteLength).toEqual(0);
}
await loadingTask.destroy();
});
@ -3368,12 +3364,10 @@ Caron Broadcasting, Inc., an Ohio corporation (“Lessee”).`)
expect(pdfPage.rotate).toEqual(0);
expect(fetches).toBeGreaterThan(2);
if (!isNodeJS) {
// Check that the TypedArrays were transferred.
for (const array of subArrays) {
expect(array.length).toEqual(0);
}
}
await loadingTask.destroy();
});
@ -3417,12 +3411,10 @@ Caron Broadcasting, Inc., an Ohio corporation (“Lessee”).`)
waitSome(resolve);
});
if (!isNodeJS) {
// Check that the TypedArrays were transferred.
for (const array of subArrays) {
expect(array.length).toEqual(0);
}
}
await loadingTask.destroy();
});
@ -3458,12 +3450,10 @@ Caron Broadcasting, Inc., an Ohio corporation (“Lessee”).`)
expect(pdfPage.rotate).toEqual(0);
expect(fetches).toEqual(0);
if (!isNodeJS) {
// Check that the TypedArrays were transferred.
for (const array of subArrays) {
expect(array.length).toEqual(0);
}
}
await loadingTask.destroy();
}