summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/serial/serialPort_readable_parityError.https.any.js
blob: 7afd494dc50dbb174510fdb2db70f37338fe9184 (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
49
50
51
52
// META: script=/resources/test-only-api.js
// META: script=/serial/resources/common.js
// META: script=resources/automation.js

// ParityError is not (as of 2020/03/23) a valid DOMException, so cannot use
// promise_rejects_dom for it.
async function promise_rejects_with_parity_error(t, promise) {
  return promise
      .then(() => {
        assert_false('Should have rejected');
      })
      .catch(e => {
        assert_equals(e.constructor, DOMException);
        assert_equals(e.name, 'ParityError');
      });
}

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});

  let readable = port.readable;
  let reader = readable.getReader();

  await fakePort.writable();
  const data = new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8]);
  fakePort.write(data);
  fakePort.simulateParityError();

  let {value, done} = await reader.read();
  assert_false(done);
  compareArrays(data, value);

  await promise_rejects_with_parity_error(t, reader.read());
  assert_not_equals(port.readable, readable);

  readable = port.readable;
  assert_true(readable instanceof ReadableStream);
  reader = port.readable.getReader();

  await fakePort.writable();
  fakePort.write(data);

  ({value, done} = await reader.read());
  assert_false(done);
  compareArrays(data, value);
  reader.releaseLock();

  await port.close();
  assert_equals(port.readable, null);
}, 'Parity error closes readable and replaces it with a new stream');