zigbee-herdsman 6.0.1 → 6.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (260) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/adapter/ezsp/driver/uart.js +1 -1
  3. package/dist/adapter/ezsp/driver/uart.js.map +1 -1
  4. package/dist/adapter/z-stack/adapter/zStackAdapter.js +4 -4
  5. package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +1 -1
  6. package/dist/adapter/zigate/adapter/zigateAdapter.js +4 -4
  7. package/dist/adapter/zigate/adapter/zigateAdapter.js.map +1 -1
  8. package/dist/controller/model/device.d.ts.map +1 -1
  9. package/dist/controller/model/device.js +1 -0
  10. package/dist/controller/model/device.js.map +1 -1
  11. package/package.json +14 -6
  12. package/.github/ISSUE_TEMPLATE/config.yml +0 -5
  13. package/.github/dependabot.yml +0 -22
  14. package/.github/workflows/ci.yml +0 -64
  15. package/.github/workflows/release-please.yml +0 -18
  16. package/.github/workflows/stale.yml +0 -20
  17. package/.github/workflows/typedoc.yaml +0 -47
  18. package/.release-please-manifest.json +0 -3
  19. package/.vscode/extensions.json +0 -3
  20. package/.vscode/settings.json +0 -11
  21. package/biome.json +0 -98
  22. package/examples/join-and-log.js +0 -24
  23. package/release-please-config.json +0 -9
  24. package/src/adapter/adapter.ts +0 -189
  25. package/src/adapter/adapterDiscovery.ts +0 -666
  26. package/src/adapter/const.ts +0 -12
  27. package/src/adapter/deconz/adapter/deconzAdapter.ts +0 -877
  28. package/src/adapter/deconz/driver/constants.ts +0 -246
  29. package/src/adapter/deconz/driver/driver.ts +0 -1540
  30. package/src/adapter/deconz/driver/frame.ts +0 -11
  31. package/src/adapter/deconz/driver/frameParser.ts +0 -753
  32. package/src/adapter/deconz/driver/parser.ts +0 -45
  33. package/src/adapter/deconz/driver/writer.ts +0 -22
  34. package/src/adapter/deconz/types.d.ts +0 -13
  35. package/src/adapter/ember/adapter/emberAdapter.ts +0 -2265
  36. package/src/adapter/ember/adapter/endpoints.ts +0 -86
  37. package/src/adapter/ember/adapter/oneWaitress.ts +0 -324
  38. package/src/adapter/ember/adapter/tokensManager.ts +0 -782
  39. package/src/adapter/ember/consts.ts +0 -178
  40. package/src/adapter/ember/enums.ts +0 -1746
  41. package/src/adapter/ember/ezsp/buffalo.ts +0 -1392
  42. package/src/adapter/ember/ezsp/consts.ts +0 -148
  43. package/src/adapter/ember/ezsp/enums.ts +0 -1114
  44. package/src/adapter/ember/ezsp/ezsp.ts +0 -9061
  45. package/src/adapter/ember/ezspError.ts +0 -10
  46. package/src/adapter/ember/types.ts +0 -866
  47. package/src/adapter/ember/uart/ash.ts +0 -1960
  48. package/src/adapter/ember/uart/consts.ts +0 -109
  49. package/src/adapter/ember/uart/enums.ts +0 -192
  50. package/src/adapter/ember/uart/parser.ts +0 -48
  51. package/src/adapter/ember/uart/queues.ts +0 -247
  52. package/src/adapter/ember/uart/writer.ts +0 -53
  53. package/src/adapter/ember/utils/initters.ts +0 -58
  54. package/src/adapter/ember/utils/math.ts +0 -73
  55. package/src/adapter/events.ts +0 -21
  56. package/src/adapter/ezsp/adapter/backup.ts +0 -109
  57. package/src/adapter/ezsp/adapter/ezspAdapter.ts +0 -614
  58. package/src/adapter/ezsp/driver/commands.ts +0 -2497
  59. package/src/adapter/ezsp/driver/consts.ts +0 -11
  60. package/src/adapter/ezsp/driver/driver.ts +0 -1002
  61. package/src/adapter/ezsp/driver/ezsp.ts +0 -802
  62. package/src/adapter/ezsp/driver/frame.ts +0 -101
  63. package/src/adapter/ezsp/driver/index.ts +0 -4
  64. package/src/adapter/ezsp/driver/multicast.ts +0 -78
  65. package/src/adapter/ezsp/driver/parser.ts +0 -81
  66. package/src/adapter/ezsp/driver/types/basic.ts +0 -201
  67. package/src/adapter/ezsp/driver/types/index.ts +0 -239
  68. package/src/adapter/ezsp/driver/types/named.ts +0 -2330
  69. package/src/adapter/ezsp/driver/types/struct.ts +0 -844
  70. package/src/adapter/ezsp/driver/uart.ts +0 -460
  71. package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +0 -44
  72. package/src/adapter/ezsp/driver/utils/index.ts +0 -32
  73. package/src/adapter/ezsp/driver/writer.ts +0 -64
  74. package/src/adapter/index.ts +0 -3
  75. package/src/adapter/serialPort.ts +0 -58
  76. package/src/adapter/socketPortUtils.ts +0 -16
  77. package/src/adapter/tstype.ts +0 -78
  78. package/src/adapter/z-stack/adapter/adapter-backup.ts +0 -519
  79. package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +0 -457
  80. package/src/adapter/z-stack/adapter/endpoints.ts +0 -57
  81. package/src/adapter/z-stack/adapter/manager.ts +0 -543
  82. package/src/adapter/z-stack/adapter/tstype.ts +0 -6
  83. package/src/adapter/z-stack/adapter/zStackAdapter.ts +0 -1190
  84. package/src/adapter/z-stack/constants/af.ts +0 -27
  85. package/src/adapter/z-stack/constants/common.ts +0 -285
  86. package/src/adapter/z-stack/constants/dbg.ts +0 -23
  87. package/src/adapter/z-stack/constants/index.ts +0 -11
  88. package/src/adapter/z-stack/constants/mac.ts +0 -128
  89. package/src/adapter/z-stack/constants/sapi.ts +0 -25
  90. package/src/adapter/z-stack/constants/sys.ts +0 -72
  91. package/src/adapter/z-stack/constants/util.ts +0 -82
  92. package/src/adapter/z-stack/constants/utils.ts +0 -14
  93. package/src/adapter/z-stack/constants/zdo.ts +0 -103
  94. package/src/adapter/z-stack/models/startup-options.ts +0 -13
  95. package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +0 -44
  96. package/src/adapter/z-stack/structs/entries/address-manager-table.ts +0 -19
  97. package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +0 -12
  98. package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +0 -21
  99. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +0 -19
  100. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +0 -21
  101. package/src/adapter/z-stack/structs/entries/channel-list.ts +0 -8
  102. package/src/adapter/z-stack/structs/entries/has-configured.ts +0 -16
  103. package/src/adapter/z-stack/structs/entries/index.ts +0 -16
  104. package/src/adapter/z-stack/structs/entries/nib.ts +0 -66
  105. package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +0 -15
  106. package/src/adapter/z-stack/structs/entries/nwk-key.ts +0 -13
  107. package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +0 -8
  108. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +0 -20
  109. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +0 -19
  110. package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +0 -33
  111. package/src/adapter/z-stack/structs/entries/security-manager-table.ts +0 -22
  112. package/src/adapter/z-stack/structs/index.ts +0 -4
  113. package/src/adapter/z-stack/structs/serializable-memory-object.ts +0 -14
  114. package/src/adapter/z-stack/structs/struct.ts +0 -367
  115. package/src/adapter/z-stack/structs/table.ts +0 -198
  116. package/src/adapter/z-stack/unpi/constants.ts +0 -33
  117. package/src/adapter/z-stack/unpi/frame.ts +0 -62
  118. package/src/adapter/z-stack/unpi/index.ts +0 -4
  119. package/src/adapter/z-stack/unpi/parser.ts +0 -56
  120. package/src/adapter/z-stack/unpi/writer.ts +0 -21
  121. package/src/adapter/z-stack/utils/channel-list.ts +0 -40
  122. package/src/adapter/z-stack/utils/index.ts +0 -2
  123. package/src/adapter/z-stack/utils/network-options.ts +0 -26
  124. package/src/adapter/z-stack/znp/buffaloZnp.ts +0 -175
  125. package/src/adapter/z-stack/znp/definition.ts +0 -2713
  126. package/src/adapter/z-stack/znp/index.ts +0 -2
  127. package/src/adapter/z-stack/znp/parameterType.ts +0 -22
  128. package/src/adapter/z-stack/znp/tstype.ts +0 -44
  129. package/src/adapter/z-stack/znp/utils.ts +0 -10
  130. package/src/adapter/z-stack/znp/znp.ts +0 -342
  131. package/src/adapter/z-stack/znp/zpiObject.ts +0 -148
  132. package/src/adapter/zboss/adapter/zbossAdapter.ts +0 -526
  133. package/src/adapter/zboss/commands.ts +0 -1184
  134. package/src/adapter/zboss/consts.ts +0 -9
  135. package/src/adapter/zboss/driver.ts +0 -422
  136. package/src/adapter/zboss/enums.ts +0 -360
  137. package/src/adapter/zboss/frame.ts +0 -227
  138. package/src/adapter/zboss/reader.ts +0 -65
  139. package/src/adapter/zboss/types.ts +0 -0
  140. package/src/adapter/zboss/uart.ts +0 -428
  141. package/src/adapter/zboss/utils.ts +0 -58
  142. package/src/adapter/zboss/writer.ts +0 -49
  143. package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +0 -27
  144. package/src/adapter/zigate/adapter/zigateAdapter.ts +0 -618
  145. package/src/adapter/zigate/driver/LICENSE +0 -17
  146. package/src/adapter/zigate/driver/buffaloZiGate.ts +0 -212
  147. package/src/adapter/zigate/driver/commandType.ts +0 -418
  148. package/src/adapter/zigate/driver/constants.ts +0 -150
  149. package/src/adapter/zigate/driver/frame.ts +0 -197
  150. package/src/adapter/zigate/driver/messageType.ts +0 -287
  151. package/src/adapter/zigate/driver/parameterType.ts +0 -32
  152. package/src/adapter/zigate/driver/ziGateObject.ts +0 -146
  153. package/src/adapter/zigate/driver/zigate.ts +0 -423
  154. package/src/adapter/zoh/adapter/utils.ts +0 -27
  155. package/src/adapter/zoh/adapter/zohAdapter.ts +0 -838
  156. package/src/buffalo/buffalo.ts +0 -342
  157. package/src/buffalo/index.ts +0 -1
  158. package/src/controller/controller.ts +0 -1022
  159. package/src/controller/database.ts +0 -124
  160. package/src/controller/events.ts +0 -52
  161. package/src/controller/greenPower.ts +0 -603
  162. package/src/controller/helpers/index.ts +0 -1
  163. package/src/controller/helpers/installCodes.ts +0 -107
  164. package/src/controller/helpers/request.ts +0 -96
  165. package/src/controller/helpers/requestQueue.ts +0 -125
  166. package/src/controller/helpers/zclFrameConverter.ts +0 -47
  167. package/src/controller/helpers/zclTransactionSequenceNumber.ts +0 -19
  168. package/src/controller/index.ts +0 -6
  169. package/src/controller/model/device.ts +0 -1248
  170. package/src/controller/model/endpoint.ts +0 -1105
  171. package/src/controller/model/entity.ts +0 -23
  172. package/src/controller/model/group.ts +0 -424
  173. package/src/controller/model/index.ts +0 -5
  174. package/src/controller/model/zigbeeEntity.ts +0 -30
  175. package/src/controller/touchlink.ts +0 -189
  176. package/src/controller/tstype.ts +0 -274
  177. package/src/index.ts +0 -12
  178. package/src/models/backup-storage-legacy.ts +0 -48
  179. package/src/models/backup-storage-unified.ts +0 -47
  180. package/src/models/backup.ts +0 -37
  181. package/src/models/index.ts +0 -5
  182. package/src/models/network-options.ts +0 -11
  183. package/src/utils/backup.ts +0 -152
  184. package/src/utils/index.ts +0 -5
  185. package/src/utils/logger.ts +0 -20
  186. package/src/utils/patchBigIntSerialization.ts +0 -8
  187. package/src/utils/queue.ts +0 -76
  188. package/src/utils/types.d.ts +0 -3
  189. package/src/utils/utils.ts +0 -19
  190. package/src/utils/wait.ts +0 -5
  191. package/src/utils/waitress.ts +0 -96
  192. package/src/zspec/consts.ts +0 -84
  193. package/src/zspec/enums.ts +0 -22
  194. package/src/zspec/index.ts +0 -3
  195. package/src/zspec/tstypes.ts +0 -18
  196. package/src/zspec/utils.ts +0 -247
  197. package/src/zspec/zcl/buffaloZcl.ts +0 -1220
  198. package/src/zspec/zcl/definition/cluster.ts +0 -5915
  199. package/src/zspec/zcl/definition/clusters-typegen.ts +0 -588
  200. package/src/zspec/zcl/definition/clusters-types.ts +0 -7331
  201. package/src/zspec/zcl/definition/consts.ts +0 -24
  202. package/src/zspec/zcl/definition/enums.ts +0 -203
  203. package/src/zspec/zcl/definition/foundation.ts +0 -329
  204. package/src/zspec/zcl/definition/manufacturerCode.ts +0 -729
  205. package/src/zspec/zcl/definition/status.ts +0 -69
  206. package/src/zspec/zcl/definition/tstype.ts +0 -377
  207. package/src/zspec/zcl/index.ts +0 -11
  208. package/src/zspec/zcl/utils.ts +0 -321
  209. package/src/zspec/zcl/zclFrame.ts +0 -356
  210. package/src/zspec/zcl/zclHeader.ts +0 -102
  211. package/src/zspec/zcl/zclStatusError.ts +0 -10
  212. package/src/zspec/zdo/buffaloZdo.ts +0 -2336
  213. package/src/zspec/zdo/definition/clusters.ts +0 -722
  214. package/src/zspec/zdo/definition/consts.ts +0 -16
  215. package/src/zspec/zdo/definition/enums.ts +0 -99
  216. package/src/zspec/zdo/definition/status.ts +0 -105
  217. package/src/zspec/zdo/definition/tstypes.ts +0 -1062
  218. package/src/zspec/zdo/index.ts +0 -7
  219. package/src/zspec/zdo/utils.ts +0 -76
  220. package/src/zspec/zdo/zdoStatusError.ts +0 -10
  221. package/test/adapter/adapter.test.ts +0 -1062
  222. package/test/adapter/ember/ash.test.ts +0 -337
  223. package/test/adapter/ember/consts.ts +0 -131
  224. package/test/adapter/ember/emberAdapter.test.ts +0 -3449
  225. package/test/adapter/ember/ezsp.test.ts +0 -385
  226. package/test/adapter/ember/ezspBuffalo.test.ts +0 -93
  227. package/test/adapter/ember/ezspError.test.ts +0 -12
  228. package/test/adapter/ember/math.test.ts +0 -206
  229. package/test/adapter/ezsp/frame.test.ts +0 -30
  230. package/test/adapter/ezsp/uart.test.ts +0 -181
  231. package/test/adapter/z-stack/adapter.test.ts +0 -3984
  232. package/test/adapter/z-stack/constants.test.ts +0 -33
  233. package/test/adapter/z-stack/structs.test.ts +0 -115
  234. package/test/adapter/z-stack/unpi.test.ts +0 -213
  235. package/test/adapter/z-stack/znp.test.ts +0 -1284
  236. package/test/adapter/zboss/fixZdoResponse.test.ts +0 -179
  237. package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +0 -81
  238. package/test/adapter/zigate/zdo.test.ts +0 -187
  239. package/test/adapter/zoh/utils.test.ts +0 -36
  240. package/test/adapter/zoh/zohAdapter.test.ts +0 -1307
  241. package/test/buffalo.test.ts +0 -431
  242. package/test/controller.bench.ts +0 -193
  243. package/test/controller.test.ts +0 -8702
  244. package/test/greenpower.test.ts +0 -1408
  245. package/test/mockAdapters.ts +0 -65
  246. package/test/mockDevices.ts +0 -598
  247. package/test/requests.bench.ts +0 -206
  248. package/test/testUtils.ts +0 -20
  249. package/test/tsconfig.json +0 -9
  250. package/test/utils/math.ts +0 -19
  251. package/test/utils.test.ts +0 -279
  252. package/test/vitest.config.mts +0 -27
  253. package/test/zcl.test.ts +0 -2831
  254. package/test/zspec/utils.test.ts +0 -68
  255. package/test/zspec/zcl/buffalo.test.ts +0 -1374
  256. package/test/zspec/zcl/frame.test.ts +0 -960
  257. package/test/zspec/zcl/utils.test.ts +0 -273
  258. package/test/zspec/zdo/buffalo.test.ts +0 -1850
  259. package/test/zspec/zdo/utils.test.ts +0 -241
  260. package/tsconfig.json +0 -24
@@ -1,1284 +0,0 @@
1
- import type {MockInstance} from "vitest";
2
- import {afterAll, afterEach, beforeAll, beforeEach, describe, expect, it, vi} from "vitest";
3
- import {SerialPort} from "../../../src/adapter/serialPort";
4
- import {Constants as UnpiConstants, Frame as UnpiFrame} from "../../../src/adapter/z-stack/unpi";
5
- import {Znp, ZpiObject} from "../../../src/adapter/z-stack/znp";
6
- import BuffaloZnp from "../../../src/adapter/z-stack/znp/buffaloZnp";
7
- import ParameterType from "../../../src/adapter/z-stack/znp/parameterType";
8
- import {logger} from "../../../src/utils/logger";
9
- import * as Zdo from "../../../src/zspec/zdo";
10
- import {duplicateArray, ieeeaAddr1, ieeeaAddr2} from "../../testUtils";
11
-
12
- const consoleLogger = logger;
13
- const mockSerialPortClose = vi.fn().mockImplementation((cb) => (cb ? cb() : null));
14
- const mockSerialPortFlush = vi.fn().mockImplementation((cb) => cb());
15
- const mockSerialPortAsyncFlushAndClose = vi.fn();
16
- const mockSerialPortPipe = vi.fn();
17
- const mockSerialPortList = vi.fn().mockReturnValue([]);
18
- const mockSerialPortOpen = vi.fn().mockImplementation((cb) => cb());
19
- const mockSerialPortAsyncOpen = vi.fn();
20
- const mockSerialPortConstructor = vi.fn();
21
- const mockSerialPortOnce = vi.fn();
22
- const mockSerialPortAsyncSet = vi.fn();
23
- const mockSerialPortWrite = vi.fn((_buffer, cb) => cb());
24
- let mockSerialPortIsOpen = false;
25
-
26
- vi.mock("../../../src/utils/wait", () => ({
27
- wait: vi.fn(() => {
28
- return new Promise<void>((resolve) => resolve());
29
- }),
30
- }));
31
-
32
- vi.mock("../../../src/adapter/serialPort", () => ({
33
- SerialPort: vi.fn(() => ({
34
- close: mockSerialPortClose,
35
- constructor: mockSerialPortConstructor,
36
- emit: () => {},
37
- on: () => {},
38
- once: mockSerialPortOnce,
39
- open: mockSerialPortOpen,
40
- pipe: mockSerialPortPipe,
41
- write: mockSerialPortWrite,
42
- flush: mockSerialPortFlush,
43
- isOpen: mockSerialPortIsOpen,
44
- asyncOpen: mockSerialPortAsyncOpen,
45
- asyncFlushAndClose: mockSerialPortAsyncFlushAndClose,
46
- asyncSet: mockSerialPortAsyncSet,
47
- })),
48
- }));
49
-
50
- const mockSocketSetNoDelay = vi.fn();
51
- const mockSocketSetKeepAlive = vi.fn();
52
- const mockSocketPipe = vi.fn();
53
- const mockSocketOnce = vi.fn();
54
- const mockSocketCallbacks = {};
55
- const mockSocketConnect = vi.fn(() => {
56
- mockSocketCallbacks.connect();
57
- mockSocketCallbacks.ready();
58
- });
59
- const mockSocketDestroy = vi.fn();
60
- let requestSpy: MockInstance;
61
-
62
- vi.mock("node:net", async () => ({
63
- Socket: vi.fn(() => ({
64
- setNoDelay: mockSocketSetNoDelay,
65
- pipe: mockSocketPipe,
66
- connect: mockSocketConnect,
67
- on: (event, cb) => {
68
- mockSocketCallbacks[event] = cb;
69
- },
70
- once: mockSocketOnce,
71
- destroy: mockSocketDestroy,
72
- setKeepAlive: mockSocketSetKeepAlive,
73
- })),
74
- }));
75
-
76
- SerialPort.list = mockSerialPortList;
77
-
78
- const mockUnpiParserOn = vi.fn();
79
-
80
- vi.mock("../../../src/adapter/z-stack/unpi/parser", () => ({
81
- Parser: vi.fn(() => ({
82
- on: mockUnpiParserOn,
83
- })),
84
- }));
85
-
86
- const mockUnpiWriterWriteFrame = vi.fn();
87
- const mockUnpiWriterWriteBuffer = vi.fn();
88
-
89
- vi.mock("../../../src/adapter/z-stack/unpi/writer", () => ({
90
- Writer: vi.fn(() => ({
91
- writeFrame: mockUnpiWriterWriteFrame,
92
- writeBuffer: mockUnpiWriterWriteBuffer,
93
- pipe: vi.fn(),
94
- })),
95
- }));
96
-
97
- const mocks = [
98
- mockSerialPortClose,
99
- mockSerialPortPipe,
100
- mockSerialPortConstructor,
101
- mockSerialPortOpen,
102
- mockSerialPortOnce,
103
- mockSerialPortWrite,
104
- SerialPort,
105
- mockUnpiParserOn,
106
- mockUnpiWriterWriteFrame,
107
- mockUnpiWriterWriteBuffer,
108
- mockSerialPortFlush,
109
- mockSerialPortAsyncFlushAndClose,
110
- mockSerialPortAsyncOpen,
111
- ];
112
-
113
- describe("ZNP", () => {
114
- let znp: Znp;
115
-
116
- beforeAll(() => {
117
- vi.useFakeTimers();
118
- });
119
-
120
- afterAll(() => {
121
- vi.useRealTimers();
122
- });
123
-
124
- beforeEach(() => {
125
- for (const mock of mocks) {
126
- // @ts-ignore
127
- mock.mockClear();
128
- }
129
-
130
- // @ts-ignore; make sure we always get a new instance
131
- znp = new Znp("/dev/ttyACM0", 100, true);
132
- requestSpy = vi.spyOn(znp, "request").mockImplementation(() => {});
133
- });
134
-
135
- afterEach(() => {
136
- requestSpy.mockRestore();
137
- });
138
-
139
- it("Open", async () => {
140
- await znp.open();
141
-
142
- expect(SerialPort).toHaveBeenCalledTimes(1);
143
- expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 100, rtscts: true});
144
-
145
- expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
146
- expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
147
- expect(mockSerialPortOnce).toHaveBeenCalledTimes(2);
148
- expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(0);
149
- });
150
-
151
- it("Open - first ping fails should send reset bootloader", async () => {
152
- requestSpy.mockImplementation(() => {
153
- throw new Error("failed");
154
- });
155
- await znp.open();
156
-
157
- expect(SerialPort).toHaveBeenCalledTimes(1);
158
- expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 100, rtscts: true});
159
-
160
- expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
161
- expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
162
- expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(1);
163
- expect(mockSerialPortOnce).toHaveBeenCalledTimes(2);
164
- });
165
-
166
- it("Open with defaults", async () => {
167
- znp = new Znp("/dev/ttyACM0", undefined, undefined);
168
- requestSpy = vi.spyOn(znp, "request").mockImplementation(() => {});
169
- await znp.open();
170
-
171
- expect(SerialPort).toHaveBeenCalledTimes(1);
172
- expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 115200, rtscts: false});
173
-
174
- expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
175
- expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
176
- expect(mockSerialPortOnce).toHaveBeenCalledTimes(2);
177
- });
178
-
179
- it("Open and close tcp port", async () => {
180
- znp = new Znp("tcp://localhost:8080", 100, false);
181
- await znp.open();
182
- expect(mockSocketConnect).toBeCalledTimes(1);
183
- expect(mockSocketConnect).toBeCalledWith(8080, "localhost");
184
- expect(znp.isInitialized()).toBeTruthy();
185
- expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(1);
186
-
187
- await znp.close();
188
- expect(mockSocketDestroy).toHaveBeenCalledTimes(1);
189
- });
190
-
191
- it("Open tcp port with socket error", async () => {
192
- mockSocketConnect.mockImplementationOnce(() => {
193
- mockSocketCallbacks.error();
194
- });
195
-
196
- znp = new Znp("tcp://localhost:666", 100, false);
197
-
198
- let error = false;
199
- try {
200
- await znp.open();
201
- } catch (e) {
202
- error = e;
203
- }
204
-
205
- expect(error).toStrictEqual(new Error("Error while opening socket"));
206
- expect(znp.isInitialized()).toBeFalsy();
207
- });
208
-
209
- it("Open with error", async () => {
210
- mockSerialPortAsyncOpen.mockImplementationOnce(() => {
211
- return new Promise((_resolve, reject) => {
212
- reject("failed!");
213
- });
214
- });
215
- mockSerialPortIsOpen = true;
216
-
217
- let error = false;
218
-
219
- try {
220
- await znp.open();
221
- } catch (e) {
222
- error = e;
223
- }
224
-
225
- expect(SerialPort).toHaveBeenCalledTimes(1);
226
- expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 100, rtscts: true});
227
-
228
- expect(error).toEqual("failed!");
229
- expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
230
- expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
231
- expect(mockSerialPortClose).toHaveBeenCalledTimes(1);
232
- expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(0);
233
- expect(mockSerialPortOnce).toHaveBeenCalledTimes(0);
234
- });
235
-
236
- it("Open with error when serialport is not open", async () => {
237
- mockSerialPortAsyncOpen.mockImplementationOnce(() => {
238
- return new Promise((_resolve, reject) => {
239
- reject("failed!");
240
- });
241
- });
242
- mockSerialPortIsOpen = false;
243
-
244
- let error = false;
245
-
246
- try {
247
- await znp.open();
248
- } catch (e) {
249
- error = e;
250
- }
251
-
252
- expect(SerialPort).toHaveBeenCalledTimes(1);
253
- expect(SerialPort).toHaveBeenCalledWith({path: "/dev/ttyACM0", autoOpen: false, baudRate: 100, rtscts: true});
254
-
255
- expect(error).toEqual("failed!");
256
- expect(mockSerialPortPipe).toHaveBeenCalledTimes(1);
257
- expect(mockSerialPortAsyncOpen).toHaveBeenCalledTimes(1);
258
- expect(mockSerialPortClose).toHaveBeenCalledTimes(0);
259
- expect(mockUnpiWriterWriteBuffer).toHaveBeenCalledTimes(0);
260
- expect(mockSerialPortOnce).toHaveBeenCalledTimes(0);
261
- });
262
-
263
- it("Open and close", async () => {
264
- const close = vi.fn();
265
- znp.on("close", close);
266
- expect(znp.isInitialized()).toBeFalsy();
267
- await znp.open();
268
- expect(znp.isInitialized()).toBeTruthy();
269
- await znp.close();
270
- expect(znp.isInitialized()).toBeFalsy();
271
-
272
- expect(mockSerialPortAsyncFlushAndClose).toHaveBeenCalledTimes(1);
273
- expect(close).toHaveBeenCalledTimes(1);
274
- });
275
-
276
- it("Open and close error", async () => {
277
- const close = vi.fn();
278
- znp.on("close", close);
279
- mockSerialPortAsyncFlushAndClose.mockImplementationOnce(() => {
280
- return new Promise((_resolve, reject) => {
281
- reject("failed!");
282
- });
283
- });
284
- await znp.open();
285
-
286
- let error;
287
- try {
288
- await znp.close();
289
- } catch (e) {
290
- error = e;
291
- }
292
-
293
- expect(mockSerialPortAsyncFlushAndClose).toHaveBeenCalledTimes(1);
294
- expect(error).toEqual("failed!");
295
- expect(close).toHaveBeenCalledTimes(1);
296
- });
297
-
298
- it("Close without initialization", async () => {
299
- const close = vi.fn();
300
- znp.on("close", close);
301
- mockSerialPortAsyncFlushAndClose.mockImplementationOnce(() => {
302
- return new Promise((_resolve, reject) => {
303
- reject("failed!");
304
- });
305
- });
306
- await znp.close();
307
-
308
- expect(mockSerialPortAsyncFlushAndClose).toHaveBeenCalledTimes(0);
309
- expect(close).toHaveBeenCalledTimes(1);
310
- });
311
-
312
- it("Open and close by serialport event", async () => {
313
- let closeCb;
314
-
315
- mockSerialPortOnce.mockImplementation((event, cb) => {
316
- if (event === "close") {
317
- closeCb = cb;
318
- }
319
- });
320
-
321
- const close = vi.fn();
322
- znp.on("close", close);
323
- await znp.open();
324
- closeCb();
325
-
326
- expect(close).toHaveBeenCalledTimes(1);
327
- });
328
-
329
- it("Serialport error (do nothing)", async () => {
330
- let errorCb;
331
-
332
- mockSerialPortOnce.mockImplementation((event, cb) => {
333
- if (event === "error") {
334
- errorCb = cb;
335
- }
336
- });
337
-
338
- await znp.open();
339
- errorCb();
340
- });
341
-
342
- it("znp receive", () => {
343
- let parsedCb;
344
- const received = vi.fn();
345
-
346
- znp.on("received", received);
347
-
348
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
349
- if (event === "parsed") {
350
- parsedCb = cb;
351
- }
352
- });
353
-
354
- znp.open();
355
- parsedCb(
356
- new UnpiFrame(
357
- UnpiConstants.Type.SRSP,
358
- UnpiConstants.Subsystem.SYS,
359
- 0x02,
360
- Buffer.from([0x01, 0x02, 0x03, 0x04, 0x05, 0x01, 0x01, 0x01, 0x01]),
361
- ),
362
- );
363
-
364
- expect(received).toHaveBeenCalledTimes(1);
365
-
366
- const obj = received.mock.calls[0][0];
367
- expect(obj.command.name).toBe("version");
368
- expect(obj.command.ID).toBe(2);
369
- expect(obj.payload).toStrictEqual({maintrel: 5, majorrel: 3, minorrel: 4, product: 2, revision: 16843009, transportrev: 1});
370
- expect(obj.subsystem).toBe(UnpiConstants.Subsystem.SYS);
371
- expect(obj.type).toBe(UnpiConstants.Type.SRSP);
372
- });
373
-
374
- it("znp receive malformed", () => {
375
- let parsedCb;
376
- const received = vi.fn();
377
-
378
- znp.on("received", received);
379
-
380
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
381
- if (event === "parsed") {
382
- parsedCb = cb;
383
- }
384
- });
385
-
386
- znp.open();
387
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x02, Buffer.from([0x01, 0x02, 0x03, 0x04])));
388
-
389
- expect(received).toHaveBeenCalledTimes(0);
390
- });
391
-
392
- it("znp request SREQ", async () => {
393
- let parsedCb;
394
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
395
- if (event === "parsed") {
396
- parsedCb = cb;
397
- }
398
- });
399
-
400
- mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
401
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
402
- });
403
-
404
- await znp.open();
405
- requestSpy.mockRestore();
406
-
407
- const result = await znp.requestWithReply(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
408
-
409
- const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
410
- expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
411
- expect(frame.commandID).toBe(8);
412
- expect(frame.subsystem).toBe(UnpiConstants.Subsystem.SYS);
413
- expect(frame.type).toBe(UnpiConstants.Type.SREQ);
414
- expect(frame.data).toStrictEqual(Buffer.from([0x01, 0x00, 0x02]));
415
-
416
- expect(result.command.name).toBe("osalNvRead");
417
- expect(result.command.ID).toBe(0x08);
418
- expect(result.payload).toStrictEqual({status: 0, len: 2, value: Buffer.from([0x01, 0x02])});
419
- expect(result.subsystem).toBe(UnpiConstants.Subsystem.SYS);
420
- expect(result.type).toBe(UnpiConstants.Type.SRSP);
421
- });
422
-
423
- it("znp request SREQ failed", async () => {
424
- let parsedCb;
425
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
426
- if (event === "parsed") {
427
- parsedCb = cb;
428
- }
429
- });
430
-
431
- mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
432
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x01, 0x02, 0x01, 0x02])));
433
- });
434
-
435
- await znp.open();
436
- requestSpy.mockRestore();
437
-
438
- expect(znp.waitress.waiters.size).toBe(0);
439
-
440
- let error;
441
- try {
442
- await znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
443
- } catch (e) {
444
- expect(znp.waitress.waiters.size).toBe(0);
445
- error = e;
446
- }
447
-
448
- expect(error).toStrictEqual(
449
- new Error("--> 'SREQ: SYS - osalNvRead - {\"id\":1,\"offset\":2}' failed with status '(0x01: FAILURE)' (expected '(0x00: SUCCESS)')"),
450
- );
451
- });
452
-
453
- it("znp request SREQ failed should cancel waiter when provided", async () => {
454
- let parsedCb;
455
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
456
- if (event === "parsed") {
457
- parsedCb = cb;
458
- }
459
- });
460
-
461
- mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
462
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x01, 0x02, 0x01, 0x02])));
463
- });
464
-
465
- await znp.open();
466
- requestSpy.mockRestore();
467
-
468
- expect(znp.waitress.waiters.size).toBe(0);
469
- const waiter = znp.waitFor(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, "osalNvRead");
470
- expect(znp.waitress.waiters.size).toBe(1);
471
-
472
- let error;
473
- try {
474
- await znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2}, waiter.ID);
475
- } catch (e) {
476
- expect(znp.waitress.waiters.size).toBe(0);
477
- error = e;
478
- }
479
-
480
- expect(error).toStrictEqual(
481
- new Error("--> 'SREQ: SYS - osalNvRead - {\"id\":1,\"offset\":2}' failed with status '(0x01: FAILURE)' (expected '(0x00: SUCCESS)')"),
482
- );
483
- });
484
-
485
- it("znp request SREQ with parsed in between", async () => {
486
- let parsedCb;
487
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
488
- if (event === "parsed") {
489
- parsedCb = cb;
490
- }
491
- });
492
-
493
- mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
494
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.AF, 0x00, Buffer.from([0x00])));
495
-
496
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
497
- });
498
-
499
- await znp.open();
500
- requestSpy.mockRestore();
501
-
502
- const result = await znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
503
-
504
- const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
505
- expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
506
- expect(frame.commandID).toBe(8);
507
- expect(frame.subsystem).toBe(UnpiConstants.Subsystem.SYS);
508
- expect(frame.type).toBe(UnpiConstants.Type.SREQ);
509
- expect(frame.data).toStrictEqual(Buffer.from([0x01, 0x00, 0x02]));
510
-
511
- expect(result.command.name).toBe("osalNvRead");
512
- expect(result.command.ID).toBe(0x08);
513
- expect(result.payload).toStrictEqual({status: 0, len: 2, value: Buffer.from([0x01, 0x02])});
514
- expect(result.subsystem).toBe(UnpiConstants.Subsystem.SYS);
515
- expect(result.type).toBe(UnpiConstants.Type.SRSP);
516
- });
517
-
518
- it("znp request AREQ reset", async () => {
519
- let parsedCb;
520
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
521
- if (event === "parsed") {
522
- parsedCb = cb;
523
- }
524
- });
525
-
526
- mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
527
- parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.SYS, 0x80, Buffer.from([0x01, 0x02, 0x03, 0x04, 0x05, 0x06])));
528
- });
529
-
530
- await znp.open();
531
- requestSpy.mockRestore();
532
-
533
- const result = await znp.request(UnpiConstants.Subsystem.SYS, "resetReq", {type: 1});
534
-
535
- const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
536
- expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
537
- expect(frame.commandID).toBe(0);
538
- expect(frame.subsystem).toBe(UnpiConstants.Subsystem.SYS);
539
- expect(frame.type).toBe(UnpiConstants.Type.AREQ);
540
- expect(frame.data).toStrictEqual(Buffer.from([1]));
541
-
542
- expect(result.command.name).toBe("resetInd");
543
- expect(result.command.ID).toBe(0x80);
544
- expect(result.payload).toStrictEqual({reason: 1, transportrev: 2, productid: 3, majorrel: 4, minorrel: 5, hwrev: 6});
545
- expect(result.subsystem).toBe(UnpiConstants.Subsystem.SYS);
546
- expect(result.type).toBe(UnpiConstants.Type.AREQ);
547
- });
548
-
549
- it("znp request AREQ", async () => {
550
- await znp.open();
551
- requestSpy.mockRestore();
552
-
553
- const result = await znp.request(UnpiConstants.Subsystem.SAPI, "startConfirm", {status: 1});
554
-
555
- const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
556
- expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
557
- expect(frame.commandID).toBe(128);
558
- expect(frame.subsystem).toBe(UnpiConstants.Subsystem.SAPI);
559
- expect(frame.type).toBe(UnpiConstants.Type.AREQ);
560
- expect(frame.data).toStrictEqual(Buffer.from([1]));
561
-
562
- expect(result).toBe(undefined);
563
- });
564
-
565
- it("znp request without init", async () => {
566
- let error;
567
- requestSpy.mockRestore();
568
-
569
- try {
570
- await znp.request(UnpiConstants.Subsystem.SAPI, "startConfirm", {status: 1});
571
- } catch (e) {
572
- error = e;
573
- }
574
-
575
- expect(error).toEqual(new Error("Cannot request when znp has not been initialized yet"));
576
- });
577
-
578
- it("znp request with non-existing subsystem", async () => {
579
- await znp.open();
580
- requestSpy.mockRestore();
581
- let error;
582
-
583
- try {
584
- await znp.request(999, "startConfirm", {status: 1});
585
- } catch (e) {
586
- error = e;
587
- }
588
-
589
- expect(error).toEqual(new Error("Subsystem '999' does not exist"));
590
- });
591
-
592
- it("znp request with non-existing cmd", async () => {
593
- await znp.open();
594
- requestSpy.mockRestore();
595
- let error;
596
-
597
- try {
598
- await znp.request(UnpiConstants.Subsystem.SAPI, "nonExisting", {status: 1});
599
- } catch (e) {
600
- error = e;
601
- }
602
-
603
- expect(error).toEqual(new Error("Command request 'nonExisting' from subsystem '6' not found"));
604
- });
605
-
606
- it("znp request timeout", async () => {
607
- await znp.open();
608
- requestSpy.mockRestore();
609
-
610
- const result = znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
611
- vi.runAllTimers();
612
-
613
- let error;
614
- try {
615
- await result;
616
- } catch (e) {
617
- error = e;
618
- }
619
-
620
- expect(error).toStrictEqual(new Error("SRSP - SYS - osalNvRead after 6000ms"));
621
- });
622
-
623
- it("znp request timeout for startupFromApp is longer", async () => {
624
- await znp.open();
625
- requestSpy.mockRestore();
626
-
627
- const result = znp.request(UnpiConstants.Subsystem.ZDO, "startupFromApp", {startdelay: 100});
628
- vi.advanceTimersByTime(30000);
629
-
630
- let error;
631
- try {
632
- vi.advanceTimersByTime(15000);
633
- await result;
634
- } catch (e) {
635
- error = e;
636
- }
637
-
638
- expect(error).toStrictEqual(new Error("SRSP - ZDO - startupFromApp after 40000ms"));
639
- });
640
-
641
- it("znp request, responses comes after timeout", async () => {
642
- let parsedCb;
643
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
644
- if (event === "parsed") {
645
- parsedCb = cb;
646
- }
647
- });
648
-
649
- await znp.open();
650
- requestSpy.mockRestore();
651
-
652
- let result = znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
653
- vi.runAllTimers();
654
-
655
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
656
-
657
- let error;
658
- try {
659
- result = await result;
660
- } catch (e) {
661
- error = e;
662
- }
663
-
664
- expect(error).toStrictEqual(new Error("SRSP - SYS - osalNvRead after 6000ms"));
665
- });
666
-
667
- it("znp request, waitFor", async () => {
668
- let parsedCb;
669
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
670
- if (event === "parsed") {
671
- parsedCb = cb;
672
- }
673
- });
674
-
675
- await znp.open();
676
- requestSpy.mockRestore();
677
-
678
- const waiter = znp.waitFor(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, "osalNvRead");
679
- znp.request(UnpiConstants.Subsystem.SYS, "osalNvRead", {id: 1, offset: 2});
680
-
681
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
682
-
683
- const object = await waiter.start().promise;
684
- expect(object.payload).toStrictEqual({len: 2, status: 0, value: Buffer.from([1, 2])});
685
- });
686
-
687
- it("znp request ZDO", async () => {
688
- let parsedCb;
689
-
690
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
691
- if (event === "parsed") {
692
- parsedCb = cb;
693
- }
694
- });
695
- mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
696
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, 2, Buffer.from([0x00])));
697
- });
698
-
699
- await znp.open();
700
-
701
- const zdoPayload = Buffer.from([2 & 0xff, (2 >> 8) & 0xff, ...Zdo.Buffalo.buildRequest(false, Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, 2)]);
702
- const result = await znp.requestZdo(Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, zdoPayload, 1);
703
-
704
- const frame = mockUnpiWriterWriteFrame.mock.calls[0][0];
705
- expect(mockUnpiWriterWriteFrame).toHaveBeenCalledTimes(1);
706
- expect(frame.commandID).toBe(2);
707
- expect(frame.subsystem).toBe(UnpiConstants.Subsystem.ZDO);
708
- expect(frame.type).toBe(UnpiConstants.Type.SREQ);
709
- expect(frame.data).toStrictEqual(zdoPayload);
710
-
711
- expect(result).toBe(undefined);
712
- });
713
-
714
- it("znp request ZDO SUCCESS", async () => {
715
- let parsedCb;
716
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
717
- if (event === "parsed") {
718
- parsedCb = cb;
719
- }
720
- });
721
-
722
- await znp.open();
723
-
724
- const waiter = znp.waitFor(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, "nodeDescReq");
725
- const zdoPayload = Buffer.from([2 & 0xff, (2 >> 8) & 0xff, ...Zdo.Buffalo.buildRequest(false, Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, 2)]);
726
- znp.requestZdo(Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, zdoPayload, 1);
727
-
728
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, 2, Buffer.from([0x00])));
729
-
730
- const object = await waiter.start().promise;
731
- expect(object.payload).toStrictEqual({status: 0x00});
732
- });
733
-
734
- it("znp request ZDO FAILURE", async () => {
735
- let parsedCb;
736
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
737
- if (event === "parsed") {
738
- parsedCb = cb;
739
- }
740
- });
741
-
742
- mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
743
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, 2, Buffer.from([0x01])));
744
- });
745
-
746
- await znp.open();
747
-
748
- const zdoPayload = Buffer.from([2 & 0xff, (2 >> 8) & 0xff, ...Zdo.Buffalo.buildRequest(false, Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, 2)]);
749
- let error;
750
- try {
751
- await znp.requestZdo(Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, zdoPayload, undefined);
752
- } catch (e) {
753
- error = e;
754
- }
755
-
756
- expect(error).toStrictEqual(
757
- new Error(`--> 'SREQ: ZDO - NODE_DESCRIPTOR_REQUEST - ${zdoPayload.toString("hex")}' failed with status '(0x01: FAILURE)'`),
758
- );
759
- });
760
-
761
- it("znp request ZDO failed should cancel waiter when provided", async () => {
762
- let parsedCb;
763
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
764
- if (event === "parsed") {
765
- parsedCb = cb;
766
- }
767
- });
768
-
769
- mockUnpiWriterWriteFrame.mockImplementationOnce(() => {
770
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.ZDO, 2, Buffer.from([0x01])));
771
- });
772
-
773
- await znp.open();
774
-
775
- expect(znp.waitress.waiters.size).toBe(0);
776
- const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "nodeDescRsp");
777
- expect(znp.waitress.waiters.size).toBe(1);
778
-
779
- const zdoPayload = Buffer.from([2 & 0xff, (2 >> 8) & 0xff, ...Zdo.Buffalo.buildRequest(false, Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, 2)]);
780
- let error;
781
- try {
782
- await znp.requestZdo(Zdo.ClusterId.NODE_DESCRIPTOR_REQUEST, zdoPayload, waiter.ID);
783
- } catch (e) {
784
- expect(znp.waitress.waiters.size).toBe(0);
785
- error = e;
786
- }
787
-
788
- expect(error).toStrictEqual(
789
- new Error(`--> 'SREQ: ZDO - NODE_DESCRIPTOR_REQUEST - ${zdoPayload.toString("hex")}' failed with status '(0x01: FAILURE)'`),
790
- );
791
- });
792
-
793
- it("znp waitFor with transid", async () => {
794
- let parsedCb;
795
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
796
- if (event === "parsed") {
797
- parsedCb = cb;
798
- }
799
- });
800
-
801
- await znp.open();
802
- requestSpy.mockRestore();
803
-
804
- const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.AF, "dataConfirm", undefined, 123);
805
-
806
- parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.AF, 128, Buffer.from([0, 1, 123])));
807
-
808
- const object = await waiter.start().promise;
809
- expect(object.payload).toStrictEqual({status: 0, endpoint: 1, transid: 123});
810
- });
811
-
812
- it("znp waitFor with target as network address", async () => {
813
- let parsedCb;
814
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
815
- if (event === "parsed") {
816
- parsedCb = cb;
817
- }
818
- });
819
-
820
- await znp.open();
821
- requestSpy.mockRestore();
822
-
823
- const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "activeEpRsp", 0x1234);
824
-
825
- parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 133, Buffer.from([0x34, 0x12, 0x00, 0x34, 0x12, 0x00])));
826
-
827
- const object = await waiter.start().promise;
828
- expect(object.payload.zdo).toStrictEqual([
829
- Zdo.Status.SUCCESS,
830
- {
831
- nwkAddress: 0x1234,
832
- endpointList: [],
833
- },
834
- ]);
835
- });
836
-
837
- it("znp waitFor with target as IEEE", async () => {
838
- let parsedCb;
839
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
840
- if (event === "parsed") {
841
- parsedCb = cb;
842
- }
843
- });
844
-
845
- await znp.open();
846
- requestSpy.mockRestore();
847
-
848
- const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "nwkAddrRsp", "0x0807060504030201");
849
-
850
- parsedCb(
851
- new UnpiFrame(
852
- UnpiConstants.Type.AREQ,
853
- UnpiConstants.Subsystem.ZDO,
854
- 128,
855
- Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x01, 0x01, 0x00, 0x02, 0x10, 0x10, 0x11, 0x11]),
856
- ),
857
- );
858
-
859
- const object = await waiter.start().promise;
860
- expect(object.payload.zdo).toStrictEqual([
861
- Zdo.Status.SUCCESS,
862
- {
863
- assocDevList: [4112, 4369],
864
- eui64: "0x0807060504030201",
865
- // numassocdev: 2,
866
- nwkAddress: 257,
867
- startIndex: 0,
868
- },
869
- ]);
870
- });
871
-
872
- it("znp waitFor with target as IEEE forced to timeout because invalid ZDO status (no payload to match against)", async () => {
873
- let parsedCb;
874
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
875
- if (event === "parsed") {
876
- parsedCb = cb;
877
- }
878
- });
879
-
880
- await znp.open();
881
- requestSpy.mockRestore();
882
-
883
- const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "nwkAddrRsp", "0x0807060504030201").start();
884
-
885
- parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 128, Buffer.from([Zdo.Status.INVALID_INDEX])));
886
-
887
- vi.advanceTimersByTime(11000);
888
- await expect(waiter.promise).rejects.toThrow("AREQ - ZDO - nwkAddrRsp after 10000ms");
889
- });
890
-
891
- it("znp waitFor with state", async () => {
892
- let parsedCb;
893
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
894
- if (event === "parsed") {
895
- parsedCb = cb;
896
- }
897
- });
898
-
899
- await znp.open();
900
- requestSpy.mockRestore();
901
-
902
- const waiter = znp.waitFor(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, "stateChangeInd", undefined, undefined, 9);
903
-
904
- parsedCb(new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 192, Buffer.from([9])));
905
-
906
- const object = await waiter.start().promise;
907
- expect(object.payload).toStrictEqual({state: 9});
908
- });
909
-
910
- it("znp waitFor with payload mismatch", async () => {
911
- let parsedCb;
912
- mockUnpiParserOn.mockImplementationOnce((event, cb) => {
913
- if (event === "parsed") {
914
- parsedCb = cb;
915
- }
916
- });
917
-
918
- await znp.open();
919
- requestSpy.mockRestore();
920
-
921
- const waiter = znp.waitFor(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, "osalNvRead", "abcd").start();
922
-
923
- parsedCb(new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.SYS, 0x08, Buffer.from([0x00, 0x02, 0x01, 0x02])));
924
-
925
- vi.advanceTimersByTime(11000);
926
- await expect(waiter.promise).rejects.toThrow("SRSP - SYS - osalNvRead after 10000ms");
927
- });
928
-
929
- it("znp requestWithReply should throw error when request as no reply", async () => {
930
- await znp.open();
931
-
932
- try {
933
- await znp.requestWithReply(UnpiConstants.Subsystem.ZDO, "autoFindDestination", {});
934
- fail("Should throw error");
935
- } catch (error) {
936
- expect(error).toStrictEqual(new Error("Command autoFindDestination has no reply"));
937
- }
938
- });
939
-
940
- it("ZpiObject throw error on missing write parser", () => {
941
- // @ts-ignore; make sure we always get a new instance
942
- const obj = new ZpiObject(0, 0, "dummy", 0, {}, [{name: "nonExisting", parameterType: 9999999}]);
943
- expect(() => {
944
- obj.createPayloadBuffer();
945
- }).toThrow();
946
- });
947
-
948
- it("ZpiObject throw error on unknown command", () => {
949
- const frame = new UnpiFrame(UnpiConstants.Type.SREQ, UnpiConstants.Subsystem.AF, 99999, Buffer.alloc(0));
950
- expect(() => {
951
- ZpiObject.fromUnpiFrame(frame);
952
- }).toThrow();
953
- });
954
-
955
- it("ZpiObject throw error on unknown parameters", () => {
956
- const frame = new UnpiFrame(UnpiConstants.Type.SRSP, UnpiConstants.Subsystem.AF, 128, Buffer.alloc(0));
957
- expect(() => {
958
- ZpiObject.fromUnpiFrame(frame);
959
- }).toThrow();
960
- });
961
-
962
- it("ZpiObject with cmd and non sapi is not reset command", () => {
963
- // @ts-ignore; make sure we always get a new instance
964
- const obj = new ZpiObject(UnpiConstants.Type.SREQ, UnpiConstants.Subsystem.AF, "systemReset", 0, {}, []);
965
- expect(obj.isResetCommand()).toBeFalsy();
966
- });
967
-
968
- it("ZpiObject parse payload for endDeviceAnnceInd", () => {
969
- const buffer = Buffer.from([0, 0, 0, 1, 1, 2, 3, 4, 5, 6, 7, 8, 5]);
970
- const frame = new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 193, buffer);
971
- const obj = ZpiObject.fromUnpiFrame(frame);
972
- expect(obj.payload.zdo).toStrictEqual([
973
- Zdo.Status.SUCCESS,
974
- {
975
- capabilities: {
976
- allocateAddress: 0,
977
- alternatePANCoordinator: 1,
978
- deviceType: 0,
979
- powerSource: 1,
980
- reserved1: 0,
981
- reserved2: 0,
982
- rxOnWhenIdle: 0,
983
- securityCapability: 0,
984
- },
985
- eui64: "0x0807060504030201",
986
- nwkAddress: 256,
987
- },
988
- ]);
989
- });
990
-
991
- it("ZpiObject parse payload for nwkAddrRsp", () => {
992
- const buffer = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x01, 0x01, 0x00, 0x02, 0x10, 0x10, 0x11, 0x11]);
993
- const frame = new UnpiFrame(UnpiConstants.Type.AREQ, UnpiConstants.Subsystem.ZDO, 128, buffer);
994
- const obj = ZpiObject.fromUnpiFrame(frame);
995
- expect(obj.payload.zdo).toStrictEqual([
996
- Zdo.Status.SUCCESS,
997
- {
998
- assocDevList: [4112, 4369],
999
- eui64: "0x0807060504030201",
1000
- // numassocdev: 2,
1001
- nwkAddress: 257,
1002
- startIndex: 0,
1003
- },
1004
- ]);
1005
- });
1006
-
1007
- it("Cant read unsupported type", () => {
1008
- expect(() => {
1009
- const buffalo = new BuffaloZnp(Buffer.alloc(0));
1010
- // @ts-expect-error invalid typing
1011
- buffalo.read(9999, {});
1012
- }).toThrow(new Error("Read for '9999' not available"));
1013
- });
1014
-
1015
- it("UINT8 write", () => {
1016
- const buffalo = new BuffaloZnp(Buffer.alloc(3), 1);
1017
- buffalo.write(ParameterType.UINT8, 240, {});
1018
- expect(buffalo.getPosition()).toEqual(2);
1019
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0xf0, 0x00]));
1020
- });
1021
-
1022
- it("UINT8 read", () => {
1023
- const buffalo = new BuffaloZnp(Buffer.from([0x00, 0x03, 0x00, 0x00]), 1);
1024
- const value = buffalo.read(ParameterType.UINT8, {});
1025
- expect(buffalo.getPosition()).toEqual(2);
1026
- expect(value).toStrictEqual(3);
1027
- });
1028
-
1029
- it("INT8 write", () => {
1030
- const buffalo = new BuffaloZnp(Buffer.alloc(3), 1);
1031
- buffalo.write(ParameterType.INT8, 127, {});
1032
- expect(buffalo.getPosition()).toEqual(2);
1033
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0x7f, 0x00]));
1034
- });
1035
-
1036
- it("INT8 read", () => {
1037
- const buffalo = new BuffaloZnp(Buffer.from([0x00, 0xf0, 0x00, 0x00]), 1);
1038
- const value = buffalo.read(ParameterType.INT8, {});
1039
- expect(buffalo.getPosition()).toEqual(2);
1040
- expect(value).toStrictEqual(-16);
1041
- });
1042
-
1043
- it("UINT16 write", () => {
1044
- const buffalo = new BuffaloZnp(Buffer.alloc(3), 1);
1045
- buffalo.write(ParameterType.UINT16, 1020, {});
1046
- expect(buffalo.getPosition()).toEqual(3);
1047
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0xfc, 0x03]));
1048
- });
1049
-
1050
- it("UINT16 read", () => {
1051
- const buffalo = new BuffaloZnp(Buffer.from([0x00, 0x03, 0xff, 0x00]), 1);
1052
- const value = buffalo.read(ParameterType.UINT16, {});
1053
- expect(buffalo.getPosition()).toEqual(3);
1054
- expect(value).toStrictEqual(65283);
1055
- });
1056
-
1057
- it("UINT32 write", () => {
1058
- const buffalo = new BuffaloZnp(Buffer.alloc(6), 2);
1059
- buffalo.write(ParameterType.UINT32, 1065283, {});
1060
- expect(buffalo.getPosition()).toEqual(6);
1061
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0x00, 0x43, 0x41, 0x10, 0x00]));
1062
- });
1063
-
1064
- it("UINT32 read", () => {
1065
- const buffalo = new BuffaloZnp(Buffer.from([0x01, 0x03, 0xff, 0xff]));
1066
- const value = buffalo.read(ParameterType.UINT32, {});
1067
- expect(buffalo.getPosition()).toEqual(4);
1068
- expect(value).toStrictEqual(4294902529);
1069
- });
1070
-
1071
- it("LIST_UINT8 write", () => {
1072
- const buffalo = new BuffaloZnp(Buffer.alloc(4), 1);
1073
- const payload = [200, 100];
1074
- buffalo.write(ParameterType.LIST_UINT8, payload, {});
1075
- expect(buffalo.getPosition()).toStrictEqual(3);
1076
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0xc8, 0x64, 0x00]));
1077
- });
1078
-
1079
- it("LIST_UINT8 read", () => {
1080
- const buffalo = new BuffaloZnp(Buffer.from([0x00, 0x00, 0x04, 0x08]), 2);
1081
- const value = buffalo.read(ParameterType.LIST_UINT8, {length: 2});
1082
- expect(buffalo.getPosition()).toStrictEqual(4);
1083
- expect(value).toStrictEqual([4, 8]);
1084
- });
1085
-
1086
- it("LIST_UINT16 write", () => {
1087
- const buffalo = new BuffaloZnp(Buffer.alloc(5), 1);
1088
- const payload = [1024, 2048];
1089
- buffalo.write(ParameterType.LIST_UINT16, payload, {});
1090
- expect(buffalo.getPosition()).toStrictEqual(5);
1091
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, 0x00, 0x04, 0x00, 0x08]));
1092
- });
1093
-
1094
- it("LIST_UINT16 read", () => {
1095
- const buffalo = new BuffaloZnp(Buffer.from([0x00, 0x00, 0x04, 0x00, 0x08]), 1);
1096
- const value = buffalo.read(ParameterType.LIST_UINT16, {length: 2});
1097
- expect(buffalo.getPosition()).toStrictEqual(5);
1098
- expect(value).toStrictEqual([1024, 2048]);
1099
- });
1100
-
1101
- it("LIST_NETWORK write", () => {
1102
- expect(() => {
1103
- const buffalo = new BuffaloZnp(Buffer.alloc(10));
1104
- buffalo.write(ParameterType.LIST_NETWORK, [], {});
1105
- }).toThrow();
1106
- });
1107
-
1108
- it("LIST_NETWORK read", () => {
1109
- const buffer = Buffer.from([0x05, 0x10, 0x10, 0x09, 0x31, 0x13, 0x01, 0x10, 0x10, 0x09, 0x31, 0x13, 0x00, 0x01]);
1110
-
1111
- const buffalo = new BuffaloZnp(buffer, 1);
1112
- const value = buffalo.read(ParameterType.LIST_NETWORK, {length: 2});
1113
- expect(buffalo.getPosition()).toStrictEqual(13);
1114
- expect(value).toStrictEqual([
1115
- {
1116
- beaconOrder: 3,
1117
- logicalChannel: 9,
1118
- neightborPanId: 4112,
1119
- permitJoin: 1,
1120
- stackProfile: 1,
1121
- superFrameOrder: 1,
1122
- zigbeeVersion: 3,
1123
- },
1124
- {
1125
- beaconOrder: 3,
1126
- logicalChannel: 9,
1127
- neightborPanId: 4112,
1128
- permitJoin: 0,
1129
- stackProfile: 1,
1130
- superFrameOrder: 1,
1131
- zigbeeVersion: 3,
1132
- },
1133
- ]);
1134
- });
1135
-
1136
- it("BUFFER8 write", () => {
1137
- const buffalo = new BuffaloZnp(Buffer.alloc(9), 1);
1138
- const payload = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07]);
1139
- buffalo.write(ParameterType.BUFFER8, payload, {});
1140
- expect(buffalo.getPosition()).toStrictEqual(9);
1141
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload]));
1142
- });
1143
-
1144
- it("BUFFER8 write length consistent", () => {
1145
- const buffalo = new BuffaloZnp(Buffer.alloc(9));
1146
- const payload = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08]);
1147
- expect(() => {
1148
- buffalo.write(ParameterType.BUFFER8, payload, {});
1149
- }).toThrow();
1150
- });
1151
-
1152
- it("BUFFER8 read", () => {
1153
- const buffer = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09]);
1154
- const buffalo = new BuffaloZnp(buffer, 2);
1155
- const value = buffalo.read(ParameterType.BUFFER8, {});
1156
- expect(buffalo.getPosition()).toEqual(10);
1157
- expect(value).toStrictEqual(buffer.subarray(2, 11));
1158
- });
1159
-
1160
- it("BUFFER16 write", () => {
1161
- const buffalo = new BuffaloZnp(Buffer.alloc(20), 1);
1162
- const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1163
- buffalo.write(ParameterType.BUFFER16, Buffer.from([...payload, ...payload]), {});
1164
- expect(buffalo.getPosition()).toStrictEqual(17);
1165
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload, ...payload, 0x00, 0x00, 0x00]));
1166
- });
1167
-
1168
- it("BUFFER16 read", () => {
1169
- const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1170
- const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload, ...payload]), 1);
1171
- const value = buffalo.read(ParameterType.BUFFER16, {});
1172
- expect(buffalo.getPosition()).toEqual(17);
1173
- expect(value).toStrictEqual(Buffer.from([...payload, ...payload]));
1174
- });
1175
-
1176
- it("BUFFER18 write", () => {
1177
- const buffalo = new BuffaloZnp(Buffer.alloc(20), 1);
1178
- const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08];
1179
- buffalo.write(ParameterType.BUFFER18, Buffer.from([...payload, ...payload]), {});
1180
- expect(buffalo.getPosition()).toStrictEqual(19);
1181
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload, ...payload, 0x00]));
1182
- });
1183
-
1184
- it("BUFFER18 read", () => {
1185
- const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08];
1186
- const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload, ...payload]), 1);
1187
- const value = buffalo.read(ParameterType.BUFFER18, {});
1188
- expect(buffalo.getPosition()).toStrictEqual(19);
1189
- expect(value).toStrictEqual(Buffer.from([...payload, ...payload]));
1190
- });
1191
-
1192
- it("BUFFER32 write", () => {
1193
- const buffalo = new BuffaloZnp(Buffer.alloc(34), 1);
1194
- const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1195
- buffalo.write(ParameterType.BUFFER32, Buffer.from([...payload, ...payload, ...payload, ...payload]), {});
1196
- expect(buffalo.getPosition()).toStrictEqual(33);
1197
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload, ...payload, ...payload, ...payload, 0x00]));
1198
- });
1199
-
1200
- it("BUFFER32 read", () => {
1201
- const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1202
- const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload, ...payload, ...payload, ...payload]), 1);
1203
- const value = buffalo.read(ParameterType.BUFFER32, {});
1204
- expect(buffalo.getPosition()).toStrictEqual(33);
1205
- expect(value).toStrictEqual(Buffer.from([...payload, ...payload, ...payload, ...payload]));
1206
- });
1207
-
1208
- it("BUFFER42 write", () => {
1209
- const buffalo = new BuffaloZnp(Buffer.alloc(44), 1);
1210
- const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1211
- buffalo.write(ParameterType.BUFFER42, Buffer.from([...payload, ...payload, ...payload, ...payload, ...payload, 0x01, 0xff]), {});
1212
- expect(buffalo.getPosition()).toStrictEqual(43);
1213
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload, ...payload, ...payload, ...payload, ...payload, 0x01, 0xff, 0x00]));
1214
- });
1215
-
1216
- it("BUFFER42 read", () => {
1217
- const payload = [0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07];
1218
- const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload, ...payload, ...payload, ...payload, ...payload, 0x08, 0x09]), 1);
1219
- const value = buffalo.read(ParameterType.BUFFER42, {});
1220
- expect(buffalo.getPosition()).toStrictEqual(43);
1221
- expect(value).toStrictEqual(Buffer.from([...payload, ...payload, ...payload, ...payload, ...payload, 0x08, 0x09]));
1222
- });
1223
-
1224
- it("BUFFER100 write", () => {
1225
- const buffalo = new BuffaloZnp(Buffer.alloc(100), 0);
1226
- const payload = duplicateArray(20, [0x00, 0x01, 0x02, 0x03, 0x04]);
1227
- buffalo.write(ParameterType.BUFFER100, Buffer.from(payload), {});
1228
- expect(buffalo.getPosition()).toStrictEqual(100);
1229
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from(payload));
1230
- });
1231
-
1232
- it("BUFFER100 read", () => {
1233
- const payload = duplicateArray(20, [0x00, 0x01, 0x02, 0x03, 0x04]);
1234
- const buffalo = new BuffaloZnp(Buffer.from([0x00, ...payload]), 1);
1235
- const value = buffalo.read(ParameterType.BUFFER100, {});
1236
- expect(buffalo.getPosition()).toStrictEqual(101);
1237
- expect(value).toStrictEqual(Buffer.from(payload));
1238
- });
1239
-
1240
- it("BUFFER write", () => {
1241
- const buffalo = new BuffaloZnp(Buffer.alloc(9), 1);
1242
- const payload = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07]);
1243
- buffalo.write(ParameterType.BUFFER, payload, {});
1244
- expect(buffalo.getPosition()).toStrictEqual(9);
1245
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from([0x00, ...payload]));
1246
- });
1247
-
1248
- it("BUFFER read", () => {
1249
- const buffer = Buffer.from([0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09]);
1250
- const buffalo = new BuffaloZnp(buffer, 2);
1251
- const value = buffalo.read(ParameterType.BUFFER, {length: 1});
1252
- expect(buffalo.getPosition()).toEqual(3);
1253
- expect(value).toStrictEqual(buffer.subarray(2, 3));
1254
- });
1255
-
1256
- it("IEEEADDR write", () => {
1257
- const buffalo = new BuffaloZnp(Buffer.alloc(8));
1258
- buffalo.write(ParameterType.IEEEADDR, ieeeaAddr1.string, {});
1259
- expect(buffalo.getPosition()).toEqual(8);
1260
- expect(buffalo.getBuffer()).toStrictEqual(Buffer.from(ieeeaAddr1.hex));
1261
- });
1262
-
1263
- it("IEEEADDR read", () => {
1264
- const buffalo = new BuffaloZnp(Buffer.from(ieeeaAddr2.hex));
1265
- const value = buffalo.read(ParameterType.IEEEADDR, {});
1266
- expect(buffalo.getPosition()).toEqual(8);
1267
- expect(value).toStrictEqual(ieeeaAddr2.string);
1268
- });
1269
-
1270
- it.each([ParameterType.BUFFER, ParameterType.LIST_UINT8, ParameterType.LIST_UINT16, ParameterType.LIST_NETWORK])(
1271
- "Throws when read is missing required length option - param %s",
1272
- (type) => {
1273
- expect(() => {
1274
- const buffalo = new BuffaloZnp(Buffer.alloc(1));
1275
- buffalo.read(type, {});
1276
- }).toThrow(`Cannot read ${ParameterType[type]} without length option specified`);
1277
- },
1278
- );
1279
-
1280
- it("Coverage logger", () => {
1281
- consoleLogger.warning(() => "Test warning", "TestNS");
1282
- consoleLogger.error(() => "Test error", "TestNS");
1283
- });
1284
- });