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.
- package/CHANGELOG.md +7 -0
- package/package.json +12 -3
- package/.github/ISSUE_TEMPLATE/config.yml +0 -5
- package/.github/dependabot.yml +0 -22
- package/.github/workflows/ci.yml +0 -69
- package/.github/workflows/release-please.yml +0 -18
- package/.github/workflows/stale.yml +0 -20
- package/.github/workflows/typedoc.yaml +0 -47
- package/.release-please-manifest.json +0 -3
- package/.vscode/extensions.json +0 -3
- package/.vscode/settings.json +0 -11
- package/biome.json +0 -98
- package/examples/join-and-log.js +0 -24
- package/release-please-config.json +0 -9
- package/src/adapter/adapter.ts +0 -189
- package/src/adapter/adapterDiscovery.ts +0 -666
- package/src/adapter/const.ts +0 -12
- package/src/adapter/deconz/adapter/deconzAdapter.ts +0 -877
- package/src/adapter/deconz/driver/constants.ts +0 -246
- package/src/adapter/deconz/driver/driver.ts +0 -1540
- package/src/adapter/deconz/driver/frame.ts +0 -11
- package/src/adapter/deconz/driver/frameParser.ts +0 -753
- package/src/adapter/deconz/driver/parser.ts +0 -45
- package/src/adapter/deconz/driver/writer.ts +0 -22
- package/src/adapter/deconz/types.d.ts +0 -13
- package/src/adapter/ember/adapter/emberAdapter.ts +0 -2265
- package/src/adapter/ember/adapter/endpoints.ts +0 -86
- package/src/adapter/ember/adapter/oneWaitress.ts +0 -324
- package/src/adapter/ember/adapter/tokensManager.ts +0 -782
- package/src/adapter/ember/consts.ts +0 -178
- package/src/adapter/ember/enums.ts +0 -1746
- package/src/adapter/ember/ezsp/buffalo.ts +0 -1392
- package/src/adapter/ember/ezsp/consts.ts +0 -148
- package/src/adapter/ember/ezsp/enums.ts +0 -1114
- package/src/adapter/ember/ezsp/ezsp.ts +0 -9061
- package/src/adapter/ember/ezspError.ts +0 -10
- package/src/adapter/ember/types.ts +0 -866
- package/src/adapter/ember/uart/ash.ts +0 -1960
- package/src/adapter/ember/uart/consts.ts +0 -109
- package/src/adapter/ember/uart/enums.ts +0 -192
- package/src/adapter/ember/uart/parser.ts +0 -48
- package/src/adapter/ember/uart/queues.ts +0 -247
- package/src/adapter/ember/uart/writer.ts +0 -53
- package/src/adapter/ember/utils/initters.ts +0 -58
- package/src/adapter/ember/utils/math.ts +0 -73
- package/src/adapter/events.ts +0 -21
- package/src/adapter/ezsp/adapter/backup.ts +0 -109
- package/src/adapter/ezsp/adapter/ezspAdapter.ts +0 -614
- package/src/adapter/ezsp/driver/commands.ts +0 -2497
- package/src/adapter/ezsp/driver/consts.ts +0 -11
- package/src/adapter/ezsp/driver/driver.ts +0 -1002
- package/src/adapter/ezsp/driver/ezsp.ts +0 -802
- package/src/adapter/ezsp/driver/frame.ts +0 -101
- package/src/adapter/ezsp/driver/index.ts +0 -4
- package/src/adapter/ezsp/driver/multicast.ts +0 -78
- package/src/adapter/ezsp/driver/parser.ts +0 -81
- package/src/adapter/ezsp/driver/types/basic.ts +0 -201
- package/src/adapter/ezsp/driver/types/index.ts +0 -239
- package/src/adapter/ezsp/driver/types/named.ts +0 -2330
- package/src/adapter/ezsp/driver/types/struct.ts +0 -844
- package/src/adapter/ezsp/driver/uart.ts +0 -460
- package/src/adapter/ezsp/driver/utils/crc16ccitt.ts +0 -44
- package/src/adapter/ezsp/driver/utils/index.ts +0 -32
- package/src/adapter/ezsp/driver/writer.ts +0 -64
- package/src/adapter/index.ts +0 -3
- package/src/adapter/serialPort.ts +0 -58
- package/src/adapter/socketPortUtils.ts +0 -16
- package/src/adapter/tstype.ts +0 -78
- package/src/adapter/z-stack/adapter/adapter-backup.ts +0 -519
- package/src/adapter/z-stack/adapter/adapter-nv-memory.ts +0 -457
- package/src/adapter/z-stack/adapter/endpoints.ts +0 -57
- package/src/adapter/z-stack/adapter/manager.ts +0 -543
- package/src/adapter/z-stack/adapter/tstype.ts +0 -6
- package/src/adapter/z-stack/adapter/zStackAdapter.ts +0 -1190
- package/src/adapter/z-stack/constants/af.ts +0 -27
- package/src/adapter/z-stack/constants/common.ts +0 -285
- package/src/adapter/z-stack/constants/dbg.ts +0 -23
- package/src/adapter/z-stack/constants/index.ts +0 -11
- package/src/adapter/z-stack/constants/mac.ts +0 -128
- package/src/adapter/z-stack/constants/sapi.ts +0 -25
- package/src/adapter/z-stack/constants/sys.ts +0 -72
- package/src/adapter/z-stack/constants/util.ts +0 -82
- package/src/adapter/z-stack/constants/utils.ts +0 -14
- package/src/adapter/z-stack/constants/zdo.ts +0 -103
- package/src/adapter/z-stack/models/startup-options.ts +0 -13
- package/src/adapter/z-stack/structs/entries/address-manager-entry.ts +0 -44
- package/src/adapter/z-stack/structs/entries/address-manager-table.ts +0 -19
- package/src/adapter/z-stack/structs/entries/aps-link-key-data-entry.ts +0 -12
- package/src/adapter/z-stack/structs/entries/aps-link-key-data-table.ts +0 -21
- package/src/adapter/z-stack/structs/entries/aps-tc-link-key-entry.ts +0 -19
- package/src/adapter/z-stack/structs/entries/aps-tc-link-key-table.ts +0 -21
- package/src/adapter/z-stack/structs/entries/channel-list.ts +0 -8
- package/src/adapter/z-stack/structs/entries/has-configured.ts +0 -16
- package/src/adapter/z-stack/structs/entries/index.ts +0 -16
- package/src/adapter/z-stack/structs/entries/nib.ts +0 -66
- package/src/adapter/z-stack/structs/entries/nwk-key-descriptor.ts +0 -15
- package/src/adapter/z-stack/structs/entries/nwk-key.ts +0 -13
- package/src/adapter/z-stack/structs/entries/nwk-pan-id.ts +0 -8
- package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-entry.ts +0 -20
- package/src/adapter/z-stack/structs/entries/nwk-sec-material-descriptor-table.ts +0 -19
- package/src/adapter/z-stack/structs/entries/security-manager-entry.ts +0 -33
- package/src/adapter/z-stack/structs/entries/security-manager-table.ts +0 -22
- package/src/adapter/z-stack/structs/index.ts +0 -4
- package/src/adapter/z-stack/structs/serializable-memory-object.ts +0 -14
- package/src/adapter/z-stack/structs/struct.ts +0 -367
- package/src/adapter/z-stack/structs/table.ts +0 -198
- package/src/adapter/z-stack/unpi/constants.ts +0 -33
- package/src/adapter/z-stack/unpi/frame.ts +0 -62
- package/src/adapter/z-stack/unpi/index.ts +0 -4
- package/src/adapter/z-stack/unpi/parser.ts +0 -56
- package/src/adapter/z-stack/unpi/writer.ts +0 -21
- package/src/adapter/z-stack/utils/channel-list.ts +0 -40
- package/src/adapter/z-stack/utils/index.ts +0 -2
- package/src/adapter/z-stack/utils/network-options.ts +0 -26
- package/src/adapter/z-stack/znp/buffaloZnp.ts +0 -175
- package/src/adapter/z-stack/znp/definition.ts +0 -2713
- package/src/adapter/z-stack/znp/index.ts +0 -2
- package/src/adapter/z-stack/znp/parameterType.ts +0 -22
- package/src/adapter/z-stack/znp/tstype.ts +0 -44
- package/src/adapter/z-stack/znp/utils.ts +0 -10
- package/src/adapter/z-stack/znp/znp.ts +0 -342
- package/src/adapter/z-stack/znp/zpiObject.ts +0 -148
- package/src/adapter/zboss/adapter/zbossAdapter.ts +0 -526
- package/src/adapter/zboss/commands.ts +0 -1184
- package/src/adapter/zboss/consts.ts +0 -9
- package/src/adapter/zboss/driver.ts +0 -422
- package/src/adapter/zboss/enums.ts +0 -360
- package/src/adapter/zboss/frame.ts +0 -227
- package/src/adapter/zboss/reader.ts +0 -65
- package/src/adapter/zboss/types.ts +0 -0
- package/src/adapter/zboss/uart.ts +0 -428
- package/src/adapter/zboss/utils.ts +0 -58
- package/src/adapter/zboss/writer.ts +0 -49
- package/src/adapter/zigate/adapter/patchZdoBuffaloBE.ts +0 -27
- package/src/adapter/zigate/adapter/zigateAdapter.ts +0 -618
- package/src/adapter/zigate/driver/LICENSE +0 -17
- package/src/adapter/zigate/driver/buffaloZiGate.ts +0 -212
- package/src/adapter/zigate/driver/commandType.ts +0 -418
- package/src/adapter/zigate/driver/constants.ts +0 -150
- package/src/adapter/zigate/driver/frame.ts +0 -197
- package/src/adapter/zigate/driver/messageType.ts +0 -287
- package/src/adapter/zigate/driver/parameterType.ts +0 -32
- package/src/adapter/zigate/driver/ziGateObject.ts +0 -146
- package/src/adapter/zigate/driver/zigate.ts +0 -423
- package/src/adapter/zoh/adapter/utils.ts +0 -27
- package/src/adapter/zoh/adapter/zohAdapter.ts +0 -838
- package/src/buffalo/buffalo.ts +0 -342
- package/src/buffalo/index.ts +0 -1
- package/src/controller/controller.ts +0 -1022
- package/src/controller/database.ts +0 -124
- package/src/controller/events.ts +0 -52
- package/src/controller/greenPower.ts +0 -603
- package/src/controller/helpers/index.ts +0 -1
- package/src/controller/helpers/installCodes.ts +0 -107
- package/src/controller/helpers/request.ts +0 -96
- package/src/controller/helpers/requestQueue.ts +0 -125
- package/src/controller/helpers/zclFrameConverter.ts +0 -47
- package/src/controller/helpers/zclTransactionSequenceNumber.ts +0 -19
- package/src/controller/index.ts +0 -6
- package/src/controller/model/device.ts +0 -1249
- package/src/controller/model/endpoint.ts +0 -1105
- package/src/controller/model/entity.ts +0 -23
- package/src/controller/model/group.ts +0 -424
- package/src/controller/model/index.ts +0 -5
- package/src/controller/model/zigbeeEntity.ts +0 -30
- package/src/controller/touchlink.ts +0 -189
- package/src/controller/tstype.ts +0 -274
- package/src/index.ts +0 -12
- package/src/models/backup-storage-legacy.ts +0 -48
- package/src/models/backup-storage-unified.ts +0 -47
- package/src/models/backup.ts +0 -37
- package/src/models/index.ts +0 -5
- package/src/models/network-options.ts +0 -11
- package/src/utils/backup.ts +0 -152
- package/src/utils/index.ts +0 -5
- package/src/utils/logger.ts +0 -20
- package/src/utils/patchBigIntSerialization.ts +0 -8
- package/src/utils/queue.ts +0 -76
- package/src/utils/types.d.ts +0 -3
- package/src/utils/utils.ts +0 -19
- package/src/utils/wait.ts +0 -5
- package/src/utils/waitress.ts +0 -96
- package/src/zspec/consts.ts +0 -84
- package/src/zspec/enums.ts +0 -22
- package/src/zspec/index.ts +0 -3
- package/src/zspec/tstypes.ts +0 -18
- package/src/zspec/utils.ts +0 -247
- package/src/zspec/zcl/buffaloZcl.ts +0 -1220
- package/src/zspec/zcl/definition/cluster.ts +0 -5915
- package/src/zspec/zcl/definition/clusters-typegen.ts +0 -588
- package/src/zspec/zcl/definition/clusters-types.ts +0 -7331
- package/src/zspec/zcl/definition/consts.ts +0 -24
- package/src/zspec/zcl/definition/enums.ts +0 -203
- package/src/zspec/zcl/definition/foundation.ts +0 -329
- package/src/zspec/zcl/definition/manufacturerCode.ts +0 -729
- package/src/zspec/zcl/definition/status.ts +0 -69
- package/src/zspec/zcl/definition/tstype.ts +0 -377
- package/src/zspec/zcl/index.ts +0 -11
- package/src/zspec/zcl/utils.ts +0 -321
- package/src/zspec/zcl/zclFrame.ts +0 -356
- package/src/zspec/zcl/zclHeader.ts +0 -102
- package/src/zspec/zcl/zclStatusError.ts +0 -10
- package/src/zspec/zdo/buffaloZdo.ts +0 -2336
- package/src/zspec/zdo/definition/clusters.ts +0 -722
- package/src/zspec/zdo/definition/consts.ts +0 -16
- package/src/zspec/zdo/definition/enums.ts +0 -99
- package/src/zspec/zdo/definition/status.ts +0 -105
- package/src/zspec/zdo/definition/tstypes.ts +0 -1062
- package/src/zspec/zdo/index.ts +0 -7
- package/src/zspec/zdo/utils.ts +0 -76
- package/src/zspec/zdo/zdoStatusError.ts +0 -10
- package/test/adapter/adapter.test.ts +0 -1062
- package/test/adapter/ember/ash.test.ts +0 -337
- package/test/adapter/ember/consts.ts +0 -131
- package/test/adapter/ember/emberAdapter.test.ts +0 -3449
- package/test/adapter/ember/ezsp.test.ts +0 -385
- package/test/adapter/ember/ezspBuffalo.test.ts +0 -93
- package/test/adapter/ember/ezspError.test.ts +0 -12
- package/test/adapter/ember/math.test.ts +0 -206
- package/test/adapter/ezsp/frame.test.ts +0 -30
- package/test/adapter/ezsp/uart.test.ts +0 -181
- package/test/adapter/z-stack/adapter.test.ts +0 -3984
- package/test/adapter/z-stack/constants.test.ts +0 -33
- package/test/adapter/z-stack/structs.test.ts +0 -115
- package/test/adapter/z-stack/unpi.test.ts +0 -213
- package/test/adapter/z-stack/znp.test.ts +0 -1284
- package/test/adapter/zboss/fixZdoResponse.test.ts +0 -179
- package/test/adapter/zigate/patchZdoBuffaloBE.test.ts +0 -81
- package/test/adapter/zigate/zdo.test.ts +0 -187
- package/test/adapter/zoh/utils.test.ts +0 -36
- package/test/adapter/zoh/zohAdapter.test.ts +0 -1307
- package/test/benchOptions.ts +0 -14
- package/test/buffalo.test.ts +0 -431
- package/test/controller.bench.ts +0 -214
- package/test/controller.test.ts +0 -8702
- package/test/greenpower.test.ts +0 -1408
- package/test/mockAdapters.ts +0 -65
- package/test/mockDevices.ts +0 -598
- package/test/requests.bench.ts +0 -229
- package/test/testUtils.ts +0 -20
- package/test/tsconfig.json +0 -9
- package/test/utils/math.ts +0 -19
- package/test/utils.test.ts +0 -279
- package/test/vitest.config.mts +0 -26
- package/test/zcl.test.ts +0 -2831
- package/test/zspec/utils.test.ts +0 -68
- package/test/zspec/zcl/buffalo.test.ts +0 -1374
- package/test/zspec/zcl/frame.test.ts +0 -960
- package/test/zspec/zcl/utils.test.ts +0 -273
- package/test/zspec/zdo/buffalo.test.ts +0 -1850
- package/test/zspec/zdo/utils.test.ts +0 -241
- 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
|
-
});
|