// 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');