-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest.js
More file actions
121 lines (103 loc) · 5.52 KB
/
test.js
File metadata and controls
121 lines (103 loc) · 5.52 KB
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
const ModbusRTU = require('./build/Release/modbus.node');
async function testModbus() {
try {
// Create Modbus device instance
// Parameters: serial port, baud rate, DE pin, RE pin
const device = ModbusRTU.NewModbusDevice("/dev/serial0", 9600, 17, 27);
if (!device) {
throw new Error("Failed to create Modbus device");
}
console.log("Connected to Modbus device");
try {
// ===== COILS TEST =====
console.log("\n=== Testing Coils ===");
// Test reading coils
console.log("\nReading coils (0-3):");
const coils = ModbusRTU.ReadCoils(device, 21, 0, 4);
console.log("Raw data:", coils);
if (typeof coils === 'string' && coils.startsWith("Error:")) {
throw new Error(coils.substring(6));
}
console.log("Coils:", JSON.parse(coils));
// Test writing single coil
console.log("\nWriting coil 0:");
const writeCoilResult = ModbusRTU.WriteCoil(device, 21, 0, true);
if (typeof writeCoilResult === 'string' && writeCoilResult.startsWith("Error:")) {
throw new Error(writeCoilResult.substring(6));
}
console.log("Coil 0 written");
// Read coils state after write
console.log("\nChecking coils state after write:");
const coilsAfterWrite = ModbusRTU.ReadCoils(device, 21, 0, 4);
console.log("Raw data:", coilsAfterWrite);
if (typeof coilsAfterWrite === 'string' && coilsAfterWrite.startsWith("Error:")) {
throw new Error(coilsAfterWrite.substring(6));
}
console.log("Coils after write:", JSON.parse(coilsAfterWrite));
// Test writing multiple coils
console.log("\nWriting multiple coils (0-3):");
const writeCoilsResult = ModbusRTU.WriteMultipleCoils(device, 21, 0, [true, false, true, false]);
if (typeof writeCoilsResult === 'string' && writeCoilsResult.startsWith("Error:")) {
throw new Error(writeCoilsResult.substring(6));
}
console.log("Multiple coils written");
// Read coils state after multiple write
console.log("\nChecking coils state after multiple write:");
const coilsAfterMultiWrite = ModbusRTU.ReadCoils(device, 21, 0, 4);
console.log("Raw data:", coilsAfterMultiWrite);
if (typeof coilsAfterMultiWrite === 'string' && coilsAfterMultiWrite.startsWith("Error:")) {
throw new Error(coilsAfterMultiWrite.substring(6));
}
console.log("Coils after multiple write:", JSON.parse(coilsAfterMultiWrite));
// ===== REGISTERS TEST =====
console.log("\n=== Testing Registers ===");
// Test reading registers
console.log("\nReading registers (0-3):");
const registers = ModbusRTU.ReadHoldingRegisters(device, 21, 0, 4);
console.log("Raw data:", registers);
if (typeof registers === 'string' && registers.startsWith("Error:")) {
throw new Error(registers.substring(6));
}
console.log("Registers:", JSON.parse(registers));
// Test writing single register
console.log("\nWriting register 0 (value 123):");
const writeRegisterResult = ModbusRTU.WriteRegister(device, 21, 0, 123);
if (typeof writeRegisterResult === 'string' && writeRegisterResult.startsWith("Error:")) {
throw new Error(writeRegisterResult.substring(6));
}
console.log("Register 0 written");
// Read registers state after write
console.log("\nChecking registers state after write:");
const registersAfterWrite = ModbusRTU.ReadHoldingRegisters(device, 21, 0, 4);
console.log("Raw data:", registersAfterWrite);
if (typeof registersAfterWrite === 'string' && registersAfterWrite.startsWith("Error:")) {
throw new Error(registersAfterWrite.substring(6));
}
console.log("Registers after write:", JSON.parse(registersAfterWrite));
// Test writing multiple registers
console.log("\nWriting multiple registers (0-3):");
const writeRegistersResult = ModbusRTU.WriteMultipleRegisters(device, 21, 0, [50, 100, 150, 200]);
if (typeof writeRegistersResult === 'string' && writeRegistersResult.startsWith("Error:")) {
throw new Error(writeRegistersResult.substring(6));
}
console.log("Multiple registers written");
// Read registers state after multiple write
console.log("\nChecking registers state after multiple write:");
const registersAfterMultiWrite = ModbusRTU.ReadHoldingRegisters(device, 21, 0, 4);
console.log("Raw data:", registersAfterMultiWrite);
if (typeof registersAfterMultiWrite === 'string' && registersAfterMultiWrite.startsWith("Error:")) {
throw new Error(registersAfterMultiWrite.substring(6));
}
console.log("Registers after multiple write:", JSON.parse(registersAfterMultiWrite));
} finally {
// Close connection
if (device) {
ModbusRTU.Close(device);
console.log("\nConnection closed");
}
}
} catch (error) {
console.error("Error:", error);
}
}
testModbus();