-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmocking.js
47 lines (37 loc) · 1.58 KB
/
mocking.js
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
/* eslint-disable node/no-missing-require */
'use strict';
// Load Serialport with mock bindings
// const SerialPort = require('../test'); // from inside the serialport repo
const SerialPort = require('serialport/test'); // when installed as a package
const MockBinding = SerialPort.Binding;
const portPath = '/dev/rfcomm1';
// The mock bindings can pretend to be an arduino with the `arduinoEcho` program loaded.
// This will echo any byte written to the port and will emit "READY" data after opening.
// You enable this by passing `echo: true`
// Another additional option is `record`, if `record: true` is present all
// writes will be recorded into a single buffer for the lifetime of the port
// it can be read from `port.binding.recording`.
// Create a port
MockBinding.createPort(portPath, { echo: false, record: false });
const acc = (accumulator, currentValue) => accumulator + currentValue;
const port = new SerialPort(portPath);
port.on('open', () => {
console.log('Port opened:\t', port.path);
});
// Write data and confirm it was written
var pkg = [0xAA, 6, 0x03, 0, 0, 0xFF];
pkg[pkg.length-2] = pkg.reduce(acc);
port.write(pkg.join(""), () => {
console.log('Write:\t\t Complete!');
console.log('Last write:\t', port.binding.lastWrite.toString('utf8'));
});
// log received data
port.on('data', (data) => {
console.log('Received:\t', data.toString('utf8'));
});
port.on('open', () => {
// To pretend to receive data (only works on open ports)
// port.binding.emitData(Buffer.from('Hi from my test!'));
});
// When you're done you can destroy all ports with
MockBinding.reset();