zigbee-herdsman 6.0.2 → 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 (252) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/package.json +12 -3
  3. package/.github/ISSUE_TEMPLATE/config.yml +0 -5
  4. package/.github/dependabot.yml +0 -22
  5. package/.github/workflows/ci.yml +0 -69
  6. package/.github/workflows/release-please.yml +0 -18
  7. package/.github/workflows/stale.yml +0 -20
  8. package/.github/workflows/typedoc.yaml +0 -47
  9. package/.release-please-manifest.json +0 -3
  10. package/.vscode/extensions.json +0 -3
  11. package/.vscode/settings.json +0 -11
  12. package/biome.json +0 -98
  13. package/examples/join-and-log.js +0 -24
  14. package/release-please-config.json +0 -9
  15. package/src/adapter/adapter.ts +0 -189
  16. package/src/adapter/adapterDiscovery.ts +0 -666
  17. package/src/adapter/const.ts +0 -12
  18. package/src/adapter/deconz/adapter/deconzAdapter.ts +0 -877
  19. package/src/adapter/deconz/driver/constants.ts +0 -246
  20. package/src/adapter/deconz/driver/driver.ts +0 -1540
  21. package/src/adapter/deconz/driver/frame.ts +0 -11
  22. package/src/adapter/deconz/driver/frameParser.ts +0 -753
  23. package/src/adapter/deconz/driver/parser.ts +0 -45
  24. package/src/adapter/deconz/driver/writer.ts +0 -22
  25. package/src/adapter/deconz/types.d.ts +0 -13
  26. package/src/adapter/ember/adapter/emberAdapter.ts +0 -2265
  27. package/src/adapter/ember/adapter/endpoints.ts +0 -86
  28. package/src/adapter/ember/adapter/oneWaitress.ts +0 -324
  29. package/src/adapter/ember/adapter/tokensManager.ts +0 -782
  30. package/src/adapter/ember/consts.ts +0 -178
  31. package/src/adapter/ember/enums.ts +0 -1746
  32. package/src/adapter/ember/ezsp/buffalo.ts +0 -1392
  33. package/src/adapter/ember/ezsp/consts.ts +0 -148
  34. package/src/adapter/ember/ezsp/enums.ts +0 -1114
  35. package/src/adapter/ember/ezsp/ezsp.ts +0 -9061
  36. package/src/adapter/ember/ezspError.ts +0 -10
  37. package/src/adapter/ember/types.ts +0 -866
  38. package/src/adapter/ember/uart/ash.ts +0 -1960
  39. package/src/adapter/ember/uart/consts.ts +0 -109
  40. package/src/adapter/ember/uart/enums.ts +0 -192
  41. package/src/adapter/ember/uart/parser.ts +0 -48
  42. package/src/adapter/ember/uart/queues.ts +0 -247
  43. package/src/adapter/ember/uart/writer.ts +0 -53
  44. package/src/adapter/ember/utils/initters.ts +0 -58
  45. package/src/adapter/ember/utils/math.ts +0 -73
  46. package/src/adapter/events.ts +0 -21
  47. package/src/adapter/ezsp/adapter/backup.ts +0 -109
  48. package/src/adapter/ezsp/adapter/ezspAdapter.ts +0 -614
  49. package/src/adapter/ezsp/driver/commands.ts +0 -2497
  50. package/src/adapter/ezsp/driver/consts.ts +0 -11
  51. package/src/adapter/ezsp/driver/driver.ts +0 -1002
  52. package/src/adapter/ezsp/driver/ezsp.ts +0 -802
  53. package/src/adapter/ezsp/driver/frame.ts +0 -101
  54. package/src/adapter/ezsp/driver/index.ts +0 -4
  55. package/src/adapter/ezsp/driver/multicast.ts +0 -78
  56. package/src/adapter/ezsp/driver/parser.ts +0 -81
  57. package/src/adapter/ezsp/driver/types/basic.ts +0 -201
  58. package/src/adapter/ezsp/driver/types/index.ts +0 -239
  59. package/src/adapter/ezsp/driver/types/named.ts +0 -2330
  60. package/src/adapter/ezsp/driver/types/struct.ts +0 -844
  61. package/src/adapter/ezsp/driver/uart.ts +0 -460
  62. package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +0 -44
  63. package/src/adapter/ezsp/driver/utils/index.ts +0 -32
  64. package/src/adapter/ezsp/driver/writer.ts +0 -64
  65. package/src/adapter/index.ts +0 -3
  66. package/src/adapter/serialPort.ts +0 -58
  67. package/src/adapter/socketPortUtils.ts +0 -16
  68. package/src/adapter/tstype.ts +0 -78
  69. package/src/adapter/z-stack/adapter/adapter-backup.ts +0 -519
  70. package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +0 -457
  71. package/src/adapter/z-stack/adapter/endpoints.ts +0 -57
  72. package/src/adapter/z-stack/adapter/manager.ts +0 -543
  73. package/src/adapter/z-stack/adapter/tstype.ts +0 -6
  74. package/src/adapter/z-stack/adapter/zStackAdapter.ts +0 -1190
  75. package/src/adapter/z-stack/constants/af.ts +0 -27
  76. package/src/adapter/z-stack/constants/common.ts +0 -285
  77. package/src/adapter/z-stack/constants/dbg.ts +0 -23
  78. package/src/adapter/z-stack/constants/index.ts +0 -11
  79. package/src/adapter/z-stack/constants/mac.ts +0 -128
  80. package/src/adapter/z-stack/constants/sapi.ts +0 -25
  81. package/src/adapter/z-stack/constants/sys.ts +0 -72
  82. package/src/adapter/z-stack/constants/util.ts +0 -82
  83. package/src/adapter/z-stack/constants/utils.ts +0 -14
  84. package/src/adapter/z-stack/constants/zdo.ts +0 -103
  85. package/src/adapter/z-stack/models/startup-options.ts +0 -13
  86. package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +0 -44
  87. package/src/adapter/z-stack/structs/entries/address-manager-table.ts +0 -19
  88. package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +0 -12
  89. package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +0 -21
  90. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +0 -19
  91. package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +0 -21
  92. package/src/adapter/z-stack/structs/entries/channel-list.ts +0 -8
  93. package/src/adapter/z-stack/structs/entries/has-configured.ts +0 -16
  94. package/src/adapter/z-stack/structs/entries/index.ts +0 -16
  95. package/src/adapter/z-stack/structs/entries/nib.ts +0 -66
  96. package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +0 -15
  97. package/src/adapter/z-stack/structs/entries/nwk-key.ts +0 -13
  98. package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +0 -8
  99. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +0 -20
  100. package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +0 -19
  101. package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +0 -33
  102. package/src/adapter/z-stack/structs/entries/security-manager-table.ts +0 -22
  103. package/src/adapter/z-stack/structs/index.ts +0 -4
  104. package/src/adapter/z-stack/structs/serializable-memory-object.ts +0 -14
  105. package/src/adapter/z-stack/structs/struct.ts +0 -367
  106. package/src/adapter/z-stack/structs/table.ts +0 -198
  107. package/src/adapter/z-stack/unpi/constants.ts +0 -33
  108. package/src/adapter/z-stack/unpi/frame.ts +0 -62
  109. package/src/adapter/z-stack/unpi/index.ts +0 -4
  110. package/src/adapter/z-stack/unpi/parser.ts +0 -56
  111. package/src/adapter/z-stack/unpi/writer.ts +0 -21
  112. package/src/adapter/z-stack/utils/channel-list.ts +0 -40
  113. package/src/adapter/z-stack/utils/index.ts +0 -2
  114. package/src/adapter/z-stack/utils/network-options.ts +0 -26
  115. package/src/adapter/z-stack/znp/buffaloZnp.ts +0 -175
  116. package/src/adapter/z-stack/znp/definition.ts +0 -2713
  117. package/src/adapter/z-stack/znp/index.ts +0 -2
  118. package/src/adapter/z-stack/znp/parameterType.ts +0 -22
  119. package/src/adapter/z-stack/znp/tstype.ts +0 -44
  120. package/src/adapter/z-stack/znp/utils.ts +0 -10
  121. package/src/adapter/z-stack/znp/znp.ts +0 -342
  122. package/src/adapter/z-stack/znp/zpiObject.ts +0 -148
  123. package/src/adapter/zboss/adapter/zbossAdapter.ts +0 -526
  124. package/src/adapter/zboss/commands.ts +0 -1184
  125. package/src/adapter/zboss/consts.ts +0 -9
  126. package/src/adapter/zboss/driver.ts +0 -422
  127. package/src/adapter/zboss/enums.ts +0 -360
  128. package/src/adapter/zboss/frame.ts +0 -227
  129. package/src/adapter/zboss/reader.ts +0 -65
  130. package/src/adapter/zboss/types.ts +0 -0
  131. package/src/adapter/zboss/uart.ts +0 -428
  132. package/src/adapter/zboss/utils.ts +0 -58
  133. package/src/adapter/zboss/writer.ts +0 -49
  134. package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +0 -27
  135. package/src/adapter/zigate/adapter/zigateAdapter.ts +0 -618
  136. package/src/adapter/zigate/driver/LICENSE +0 -17
  137. package/src/adapter/zigate/driver/buffaloZiGate.ts +0 -212
  138. package/src/adapter/zigate/driver/commandType.ts +0 -418
  139. package/src/adapter/zigate/driver/constants.ts +0 -150
  140. package/src/adapter/zigate/driver/frame.ts +0 -197
  141. package/src/adapter/zigate/driver/messageType.ts +0 -287
  142. package/src/adapter/zigate/driver/parameterType.ts +0 -32
  143. package/src/adapter/zigate/driver/ziGateObject.ts +0 -146
  144. package/src/adapter/zigate/driver/zigate.ts +0 -423
  145. package/src/adapter/zoh/adapter/utils.ts +0 -27
  146. package/src/adapter/zoh/adapter/zohAdapter.ts +0 -838
  147. package/src/buffalo/buffalo.ts +0 -342
  148. package/src/buffalo/index.ts +0 -1
  149. package/src/controller/controller.ts +0 -1022
  150. package/src/controller/database.ts +0 -124
  151. package/src/controller/events.ts +0 -52
  152. package/src/controller/greenPower.ts +0 -603
  153. package/src/controller/helpers/index.ts +0 -1
  154. package/src/controller/helpers/installCodes.ts +0 -107
  155. package/src/controller/helpers/request.ts +0 -96
  156. package/src/controller/helpers/requestQueue.ts +0 -125
  157. package/src/controller/helpers/zclFrameConverter.ts +0 -47
  158. package/src/controller/helpers/zclTransactionSequenceNumber.ts +0 -19
  159. package/src/controller/index.ts +0 -6
  160. package/src/controller/model/device.ts +0 -1249
  161. package/src/controller/model/endpoint.ts +0 -1105
  162. package/src/controller/model/entity.ts +0 -23
  163. package/src/controller/model/group.ts +0 -424
  164. package/src/controller/model/index.ts +0 -5
  165. package/src/controller/model/zigbeeEntity.ts +0 -30
  166. package/src/controller/touchlink.ts +0 -189
  167. package/src/controller/tstype.ts +0 -274
  168. package/src/index.ts +0 -12
  169. package/src/models/backup-storage-legacy.ts +0 -48
  170. package/src/models/backup-storage-unified.ts +0 -47
  171. package/src/models/backup.ts +0 -37
  172. package/src/models/index.ts +0 -5
  173. package/src/models/network-options.ts +0 -11
  174. package/src/utils/backup.ts +0 -152
  175. package/src/utils/index.ts +0 -5
  176. package/src/utils/logger.ts +0 -20
  177. package/src/utils/patchBigIntSerialization.ts +0 -8
  178. package/src/utils/queue.ts +0 -76
  179. package/src/utils/types.d.ts +0 -3
  180. package/src/utils/utils.ts +0 -19
  181. package/src/utils/wait.ts +0 -5
  182. package/src/utils/waitress.ts +0 -96
  183. package/src/zspec/consts.ts +0 -84
  184. package/src/zspec/enums.ts +0 -22
  185. package/src/zspec/index.ts +0 -3
  186. package/src/zspec/tstypes.ts +0 -18
  187. package/src/zspec/utils.ts +0 -247
  188. package/src/zspec/zcl/buffaloZcl.ts +0 -1220
  189. package/src/zspec/zcl/definition/cluster.ts +0 -5915
  190. package/src/zspec/zcl/definition/clusters-typegen.ts +0 -588
  191. package/src/zspec/zcl/definition/clusters-types.ts +0 -7331
  192. package/src/zspec/zcl/definition/consts.ts +0 -24
  193. package/src/zspec/zcl/definition/enums.ts +0 -203
  194. package/src/zspec/zcl/definition/foundation.ts +0 -329
  195. package/src/zspec/zcl/definition/manufacturerCode.ts +0 -729
  196. package/src/zspec/zcl/definition/status.ts +0 -69
  197. package/src/zspec/zcl/definition/tstype.ts +0 -377
  198. package/src/zspec/zcl/index.ts +0 -11
  199. package/src/zspec/zcl/utils.ts +0 -321
  200. package/src/zspec/zcl/zclFrame.ts +0 -356
  201. package/src/zspec/zcl/zclHeader.ts +0 -102
  202. package/src/zspec/zcl/zclStatusError.ts +0 -10
  203. package/src/zspec/zdo/buffaloZdo.ts +0 -2336
  204. package/src/zspec/zdo/definition/clusters.ts +0 -722
  205. package/src/zspec/zdo/definition/consts.ts +0 -16
  206. package/src/zspec/zdo/definition/enums.ts +0 -99
  207. package/src/zspec/zdo/definition/status.ts +0 -105
  208. package/src/zspec/zdo/definition/tstypes.ts +0 -1062
  209. package/src/zspec/zdo/index.ts +0 -7
  210. package/src/zspec/zdo/utils.ts +0 -76
  211. package/src/zspec/zdo/zdoStatusError.ts +0 -10
  212. package/test/adapter/adapter.test.ts +0 -1062
  213. package/test/adapter/ember/ash.test.ts +0 -337
  214. package/test/adapter/ember/consts.ts +0 -131
  215. package/test/adapter/ember/emberAdapter.test.ts +0 -3449
  216. package/test/adapter/ember/ezsp.test.ts +0 -385
  217. package/test/adapter/ember/ezspBuffalo.test.ts +0 -93
  218. package/test/adapter/ember/ezspError.test.ts +0 -12
  219. package/test/adapter/ember/math.test.ts +0 -206
  220. package/test/adapter/ezsp/frame.test.ts +0 -30
  221. package/test/adapter/ezsp/uart.test.ts +0 -181
  222. package/test/adapter/z-stack/adapter.test.ts +0 -3984
  223. package/test/adapter/z-stack/constants.test.ts +0 -33
  224. package/test/adapter/z-stack/structs.test.ts +0 -115
  225. package/test/adapter/z-stack/unpi.test.ts +0 -213
  226. package/test/adapter/z-stack/znp.test.ts +0 -1284
  227. package/test/adapter/zboss/fixZdoResponse.test.ts +0 -179
  228. package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +0 -81
  229. package/test/adapter/zigate/zdo.test.ts +0 -187
  230. package/test/adapter/zoh/utils.test.ts +0 -36
  231. package/test/adapter/zoh/zohAdapter.test.ts +0 -1307
  232. package/test/benchOptions.ts +0 -14
  233. package/test/buffalo.test.ts +0 -431
  234. package/test/controller.bench.ts +0 -214
  235. package/test/controller.test.ts +0 -8702
  236. package/test/greenpower.test.ts +0 -1408
  237. package/test/mockAdapters.ts +0 -65
  238. package/test/mockDevices.ts +0 -598
  239. package/test/requests.bench.ts +0 -229
  240. package/test/testUtils.ts +0 -20
  241. package/test/tsconfig.json +0 -9
  242. package/test/utils/math.ts +0 -19
  243. package/test/utils.test.ts +0 -279
  244. package/test/vitest.config.mts +0 -26
  245. package/test/zcl.test.ts +0 -2831
  246. package/test/zspec/utils.test.ts +0 -68
  247. package/test/zspec/zcl/buffalo.test.ts +0 -1374
  248. package/test/zspec/zcl/frame.test.ts +0 -960
  249. package/test/zspec/zcl/utils.test.ts +0 -273
  250. package/test/zspec/zdo/buffalo.test.ts +0 -1850
  251. package/test/zspec/zdo/utils.test.ts +0 -241
  252. 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-expect-error
127
- mock.mockClear();
128
- }
129
-
130
- // @ts-expect-error; 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-expect-error; 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-expect-error; 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
- });