mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-11-12 14:20:14 +02:00
Automatic update from web-platform-tests TextDecoderStream: Permit detached buffers Since https://github.com/heycam/webidl/pull/605 converting a chunk to a BufferSource no longer throws if the chunk is detached. Update the TextDecoderStream implementation and tests to match the new behaviour. Change-Id: I26230d9cbfce871b3dae75e612539564d4578977 Reviewed-on: https://chromium-review.googlesource.com/c/1404906 Reviewed-by: Joshua Bell <jsbell@chromium.org> Commit-Queue: Adam Rice <ricea@chromium.org> Cr-Commit-Position: refs/heads/master@{#621897} -- wpt-commits: 35d1ca9cb52f755566ba6681fe555626379b9e2c wpt-pr: 14794
61 lines
2.7 KiB
JavaScript
61 lines
2.7 KiB
JavaScript
// META: global=worker
|
|
// META: script=resources/readable-stream-from-array.js
|
|
// META: script=resources/readable-stream-to-array.js
|
|
|
|
'use strict';
|
|
|
|
const emptyChunk = new Uint8Array([]);
|
|
const inputChunk = new Uint8Array([73, 32, 240, 159, 146, 153, 32, 115, 116,
|
|
114, 101, 97, 109, 115]);
|
|
const expectedOutputString = 'I \u{1F499} streams';
|
|
|
|
promise_test(async () => {
|
|
const input = readableStreamFromArray([inputChunk]);
|
|
const output = input.pipeThrough(new TextDecoderStream());
|
|
const array = await readableStreamToArray(output);
|
|
assert_array_equals(array, [expectedOutputString],
|
|
'the output should be in one chunk');
|
|
}, 'decoding one UTF-8 chunk should give one output string');
|
|
|
|
promise_test(async () => {
|
|
const input = readableStreamFromArray([emptyChunk]);
|
|
const output = input.pipeThrough(new TextDecoderStream());
|
|
const array = await readableStreamToArray(output);
|
|
assert_array_equals(array, [], 'no chunks should be output');
|
|
}, 'decoding an empty chunk should give no output chunks');
|
|
|
|
promise_test(async () => {
|
|
const input = readableStreamFromArray([emptyChunk, inputChunk]);
|
|
const output = input.pipeThrough(new TextDecoderStream());
|
|
const array = await readableStreamToArray(output);
|
|
assert_array_equals(array, [expectedOutputString],
|
|
'the output should be in one chunk');
|
|
}, 'an initial empty chunk should be ignored');
|
|
|
|
promise_test(async () => {
|
|
const input = readableStreamFromArray([inputChunk, emptyChunk]);
|
|
const output = input.pipeThrough(new TextDecoderStream());
|
|
const array = await readableStreamToArray(output);
|
|
assert_array_equals(array, [expectedOutputString],
|
|
'the output should be in one chunk');
|
|
}, 'a trailing empty chunk should be ignored');
|
|
|
|
promise_test(async () => {
|
|
const buffer = new ArrayBuffer(3);
|
|
const view = new Uint8Array(buffer, 1, 1);
|
|
view[0] = 65;
|
|
new MessageChannel().port1.postMessage(buffer, [buffer]);
|
|
const input = readableStreamFromArray([view]);
|
|
const output = input.pipeThrough(new TextDecoderStream());
|
|
const array = await readableStreamToArray(output);
|
|
assert_array_equals(array, [], 'no chunks should be output');
|
|
}, 'decoding a transferred Uint8Array chunk should give no output');
|
|
|
|
promise_test(async () => {
|
|
const buffer = new ArrayBuffer(1);
|
|
new MessageChannel().port1.postMessage(buffer, [buffer]);
|
|
const input = readableStreamFromArray([buffer]);
|
|
const output = input.pipeThrough(new TextDecoderStream());
|
|
const array = await readableStreamToArray(output);
|
|
assert_array_equals(array, [], 'no chunks should be output');
|
|
}, 'decoding a transferred ArrayBuffer chunk should give no output');
|