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 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
// META: script=/resources/test-only-api.js
// META: script=/serial/resources/common.js
// META: script=resources/automation.js
serial_test(async (t, fake) => {
const {port, fakePort} = await getFakeSerialPort(fake);
await port.open({baudRate: 9600});
return promise_rejects_dom(
t, 'InvalidStateError', port.open({baudRate: 9600}));
}, 'A SerialPort cannot be opened if it is already open.');
serial_test(async (t, fake) => {
const {port, fakePort} = await getFakeSerialPort(fake);
const firstRequest = port.open({baudRate: 9600});
await promise_rejects_dom(
t, 'InvalidStateError', port.open({baudRate: 9600}));
await firstRequest;
}, 'Simultaneous calls to open() are disallowed.');
serial_test(async (t, fake) => {
const {port, fakePort} = await getFakeSerialPort(fake);
await promise_rejects_js(t, TypeError, port.open({}));
await Promise.all([-1, 0].map(
baudRate => {
return promise_rejects_js(t, TypeError, port.open({baudRate}))}));
}, 'Baud rate is required and must be greater than zero.');
serial_test(async (t, fake) => {
const {port, fakePort} = await getFakeSerialPort(fake);
await Promise.all([-1, 0, 6, 9].map(dataBits => {
return promise_rejects_js(
t, TypeError, port.open({baudRate: 9600, dataBits}));
}));
await[undefined, 7, 8].reduce(async (previousTest, dataBits) => {
await previousTest;
await port.open({baudRate: 9600, dataBits});
await port.close();
}, Promise.resolve());
}, 'Data bits must be 7 or 8');
serial_test(async (t, fake) => {
const {port, fakePort} = await getFakeSerialPort(fake);
await Promise.all([0, null, 'cats'].map(parity => {
return promise_rejects_js(
t, TypeError, port.open({baudRate: 9600, parity}),
`Should reject parity option "${parity}"`);
}));
await[undefined, 'none', 'even', 'odd'].reduce(
async (previousTest, parity) => {
await previousTest;
await port.open({baudRate: 9600, parity});
await port.close();
},
Promise.resolve());
}, 'Parity must be "none", "even" or "odd"');
serial_test(async (t, fake) => {
const {port, fakePort} = await getFakeSerialPort(fake);
await Promise.all([-1, 0, 3, 4].map(stopBits => {
return promise_rejects_js(
t, TypeError, port.open({baudRate: 9600, stopBits}));
}));
await[undefined, 1, 2].reduce(async (previousTest, stopBits) => {
await previousTest;
await port.open({baudRate: 9600, stopBits});
await port.close();
}, Promise.resolve());
}, 'Stop bits must be 1 or 2');
serial_test(async (t, fake) => {
const {port, fakePort} = await getFakeSerialPort(fake);
await promise_rejects_js(
t, TypeError, port.open({baudRate: 9600, bufferSize: -1}));
await promise_rejects_js(
t, TypeError, port.open({baudRate: 9600, bufferSize: 0}));
}, 'Buffer size must be greater than zero.');
serial_test(async (t, fake) => {
const {port, fakePort} = await getFakeSerialPort(fake);
const bufferSize = 1 * 1024 * 1024 * 1024 /* 1 GiB */;
return promise_rejects_js(
t, TypeError, port.open({baudRate: 9600, bufferSize}));
}, 'Unreasonably large buffer sizes are rejected.');
|