summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/serial/serialPort_writable_detachBuffer.https.any.js
blob: 828e877726b1c63dba14efc36324d9a16aa4e62f (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
// META: script=/resources/test-only-api.js
// META: script=/serial/resources/common.js
// META: script=resources/automation.js

function detachBuffer(buffer) {
  const channel = new MessageChannel();
  channel.port1.postMessage('', [buffer]);
}

serial_test(async (t, fake) => {
  const {port, fakePort} = await getFakeSerialPort(fake);
  await port.open({baudRate: 9600, bufferSize: 64});

  const writer = port.writable.getWriter();
  const data = new Uint8Array(64);
  detachBuffer(data.buffer);

  // Writing a detached buffer is equivalent to writing an empty buffer so this
  // should trivially succeed.
  await writer.write(data);
  writer.releaseLock();

  await port.close();
}, 'Writing a detached buffer is safe');

serial_test(async (t, fake) => {
  const {port, fakePort} = await getFakeSerialPort(fake);
  // Select a buffer size smaller than the amount of data transferred.
  await port.open({baudRate: 9600, bufferSize: 64});

  // Start writing a buffer much larger than bufferSize above so that it can't
  // all be transfered in a single operation.
  const writer = port.writable.getWriter();
  const data = new Uint8Array(1024);
  const promise = writer.write(data);
  writer.releaseLock();

  // Read half of the written data and then detach the buffer.
  await fakePort.readable();
  await fakePort.readWithLength(data.byteLength / 2);
  detachBuffer(data.buffer);

  // When the buffer is detached its length becomes zero and so the write should
  // succeed but it is undefined how much data was written before that happened.
  await promise;

  await port.close();
}, 'Detaching a buffer while writing is safe');