zigbee-herdsman 6.0.2 → 6.0.4
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 +14 -0
- package/package.json +9 -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,33 +0,0 @@
|
|
|
1
|
-
import {describe, expect, it} from "vitest";
|
|
2
|
-
import * as Constants from "../../../src/adapter/z-stack/constants";
|
|
3
|
-
|
|
4
|
-
describe("zstack-constants", () => {
|
|
5
|
-
it("Simple check", () => {
|
|
6
|
-
expect(Constants.AF.DEFAULT_RADIUS).toBe(30);
|
|
7
|
-
});
|
|
8
|
-
|
|
9
|
-
describe("utils", () => {
|
|
10
|
-
describe("getChannelMask", () => {
|
|
11
|
-
it("Get channel mask 11", () => {
|
|
12
|
-
expect(Constants.Utils.getChannelMask([11])).toStrictEqual([0, 8, 0, 0]);
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it("Get channel mask 25", () => {
|
|
16
|
-
expect(Constants.Utils.getChannelMask([25])).toStrictEqual([0, 0, 0, 2]);
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
it("Get channel mask 11 and 25", () => {
|
|
20
|
-
expect(Constants.Utils.getChannelMask([11, 25])).toStrictEqual([0, 8, 0, 2]);
|
|
21
|
-
});
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
describe("statusDescription", () => {
|
|
25
|
-
it("formats known status", () => {
|
|
26
|
-
expect(Constants.Utils.statusDescription(0x10)).toBe("(0x10: MEM_ERROR)");
|
|
27
|
-
});
|
|
28
|
-
it("formats unknown status", () => {
|
|
29
|
-
expect(Constants.Utils.statusDescription(0x08)).toBe("(0x08: UNKNOWN)");
|
|
30
|
-
});
|
|
31
|
-
});
|
|
32
|
-
});
|
|
33
|
-
});
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
import {describe, expect, it} from "vitest";
|
|
2
|
-
import * as Structs from "../../../src/adapter/z-stack/structs";
|
|
3
|
-
|
|
4
|
-
describe("Z-Stack Structs", () => {
|
|
5
|
-
it("should export js object from structure", () => {
|
|
6
|
-
const nib = Structs.nib();
|
|
7
|
-
nib.extendedPANID = Buffer.alloc(8, 0x01);
|
|
8
|
-
nib.nwkLogicalChannel = 21;
|
|
9
|
-
|
|
10
|
-
const obj = nib.toJSON();
|
|
11
|
-
expect(obj.extendedPANID.toString("hex")).toBe(Buffer.alloc(8, 0x01).toString("hex"));
|
|
12
|
-
expect(obj.nwkLogicalChannel).toBe(21);
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it("should properly serialize structure in different alignment modes", () => {
|
|
16
|
-
const nib = Structs.nib(
|
|
17
|
-
Buffer.from(
|
|
18
|
-
"fb050279147900640000000105018f000700020d1e000000150000000000000000000000ffff0800000020000f0f0400010000000100000000779fd609004b1200010000000000000000000000000000000000000000000000000000000000000000000000003c0c0001780a0100000006020000",
|
|
19
|
-
"hex",
|
|
20
|
-
),
|
|
21
|
-
);
|
|
22
|
-
expect(nib.serialize().toString("hex")).toBe(
|
|
23
|
-
"fb050279147900640000000105018f0700020d1e00001500000000000000000000ffff08000020000f0f0400010000000100000000779fd609004b1200010000000000000000000000000000000000000000000000000000000000000000000000003c0c0001780a010000060200",
|
|
24
|
-
);
|
|
25
|
-
expect(nib.serialize("unaligned", true, 0).toString("hex")).toBe(
|
|
26
|
-
"fb050279147900640000000105018f0700020d1e00001500000000000000000000ffff08000020000f0f0400010000000100000000779fd609004b1200010000000000000000000000000000000000000000000000000000000000000000000000003c0c0001780a010000060200",
|
|
27
|
-
);
|
|
28
|
-
expect(nib.serialize("aligned", true, 0).toString("hex")).toBe(
|
|
29
|
-
"fb050279147900640000000105018f000700020d1e000000150000000000000000000000ffff0800000020000f0f0400010000000100000000779fd609004b1200010000000000000000000000000000000000000000000000000000000000000000000000003c0c0001780a0100000006020000",
|
|
30
|
-
);
|
|
31
|
-
expect(nib.getLength("aligned")).toBe(116);
|
|
32
|
-
expect(nib.getLength("aligned", false)).toBe(115);
|
|
33
|
-
expect(nib.getLength("unaligned")).toBe(110);
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
it("should throw error on invalid uint8 array length", () => {
|
|
37
|
-
const nib = Structs.nib();
|
|
38
|
-
expect(() => {
|
|
39
|
-
nib.extendedPANID = Buffer.alloc(10, 0x01);
|
|
40
|
-
}).toThrowError("Invalid length for member extendedPANID (expected=8, got=10)");
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
it("should fail to initialize struct from invalid length source", () => {
|
|
44
|
-
expect(() => {
|
|
45
|
-
Structs.nib(Buffer.from("01020304", "hex"));
|
|
46
|
-
}).toThrowError("Struct length mismatch (expected=110/116, got=4");
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it("should fail if table entries are not the same length", () => {
|
|
50
|
-
expect(() => {
|
|
51
|
-
Structs.securityManagerTable([Buffer.alloc(12, 0x00), Buffer.alloc(17, 0x00)], "unaligned");
|
|
52
|
-
}).toThrowError("All table entries need to be the same length");
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
it("should fail if table initialization buffer is indivisible by entry length", () => {
|
|
56
|
-
expect(() => {
|
|
57
|
-
Structs.securityManagerTable(Buffer.alloc(91, 0x00));
|
|
58
|
-
}).toThrowError("Table length not divisible by entry length (alignment=unaligned, data_length=91, entry_length=5)");
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
it("should fail if table initialization source is unsupported", () => {
|
|
62
|
-
expect(() => {
|
|
63
|
-
// biome-ignore lint/suspicious/noExplicitAny: API
|
|
64
|
-
Structs.securityManagerTable("das_garbage" as any);
|
|
65
|
-
}).toThrowError("Unsupported table data source");
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it("should properly return table capacity metrics", () => {
|
|
69
|
-
const table = Structs.securityManagerTable(8);
|
|
70
|
-
expect(table.used.length).toBe(0);
|
|
71
|
-
expect(table.free.length).toBe(8);
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
it("should properly serialize unaligned and aligned table - with inline occupancy", () => {
|
|
75
|
-
const table = Structs.securityManagerTable(8);
|
|
76
|
-
expect(table.serialize().toString("hex")).toBe("0000feff000000feff000000feff000000feff000000feff000000feff000000feff000000feff000000");
|
|
77
|
-
expect(table.serialize("unaligned").toString("hex")).toBe(
|
|
78
|
-
"0000feff000000feff000000feff000000feff000000feff000000feff000000feff000000feff000000",
|
|
79
|
-
);
|
|
80
|
-
expect(table.serialize("aligned").toString("hex")).toBe(
|
|
81
|
-
"0000feff00000000feff00000000feff00000000feff00000000feff00000000feff00000000feff00000000feff00000000",
|
|
82
|
-
);
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
it("should properly evaluate security manager table occupancy", () => {
|
|
86
|
-
const table = Structs.securityManagerTable(8);
|
|
87
|
-
table.free[6].ami = 0xfffe;
|
|
88
|
-
table.free[6].authenticationOption = 0x00;
|
|
89
|
-
table.free[7].ami = 0x0000;
|
|
90
|
-
table.free[7].authenticationOption = 0x00;
|
|
91
|
-
expect(table.freeCount).toBe(8);
|
|
92
|
-
expect(table.usedCount).toBe(0);
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
it("should properly serialize unaligned and aligned table - without inline occupancy", () => {
|
|
96
|
-
const table = Structs.nwkSecMaterialDescriptorTable(8);
|
|
97
|
-
expect(table.serialize().toString("hex")).toBe(
|
|
98
|
-
"000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
|
|
99
|
-
);
|
|
100
|
-
expect(table.serialize("unaligned").toString("hex")).toBe(
|
|
101
|
-
"000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
|
|
102
|
-
);
|
|
103
|
-
expect(table.serialize("aligned").toString("hex")).toBe(
|
|
104
|
-
"000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
|
|
105
|
-
);
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
it("should evaluate table struct", () => {
|
|
109
|
-
const table = Structs.nwkSecMaterialDescriptorTable(8);
|
|
110
|
-
expect(table.capacity).toBe(8);
|
|
111
|
-
expect(table.entries.length).toBe(8);
|
|
112
|
-
expect(table.freeCount).toBe(8);
|
|
113
|
-
expect(table.usedCount).toBe(0);
|
|
114
|
-
});
|
|
115
|
-
});
|
|
@@ -1,213 +0,0 @@
|
|
|
1
|
-
import {beforeEach, describe, expect, it, vi} from "vitest";
|
|
2
|
-
import {Constants, Frame, Parser, Writer} from "../../../src/adapter/z-stack/unpi";
|
|
3
|
-
|
|
4
|
-
describe("Parser", () => {
|
|
5
|
-
let parser;
|
|
6
|
-
let parsed = [];
|
|
7
|
-
|
|
8
|
-
beforeEach(() => {
|
|
9
|
-
parser = new Parser();
|
|
10
|
-
parser.on("parsed", (result) => parsed.push(result));
|
|
11
|
-
parsed = [];
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
it("Parse simple message", () => {
|
|
15
|
-
const buffer = Buffer.from([
|
|
16
|
-
0xfe, 0x0e, 0x61, 0x02, 0x02, 0x00, 0x02, 0x06, 0x03, 0xd9, 0x14, 0x34, 0x01, 0x02, 0x00, 0x00, 0x00, 0x00, 0x92,
|
|
17
|
-
]);
|
|
18
|
-
parser._transform(buffer, "", () => {});
|
|
19
|
-
expect(parsed.length).toBe(1);
|
|
20
|
-
expect(parsed[0].type).toBe(Constants.Type.SRSP);
|
|
21
|
-
expect(parsed[0].subsystem).toBe(Constants.Subsystem.SYS);
|
|
22
|
-
expect(parsed[0].commandID).toBe(2);
|
|
23
|
-
expect(parsed[0].data).toStrictEqual(Buffer.from([2, 0, 2, 6, 3, 217, 20, 52, 1, 2, 0, 0, 0, 0]));
|
|
24
|
-
expect(parsed[0].length).toBe(14);
|
|
25
|
-
expect(parsed[0].fcs).toBe(0x92);
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
it("Parse two messages", () => {
|
|
29
|
-
const buffer = Buffer.from([
|
|
30
|
-
0xfe, 0x0e, 0x61, 0x02, 0x02, 0x00, 0x02, 0x06, 0x03, 0xd9, 0x14, 0x34, 0x01, 0x02, 0x00, 0x00, 0x00, 0x00, 0x92, 0xfe, 0x03, 0x61, 0x08,
|
|
31
|
-
0x00, 0x01, 0x55, 0x3e,
|
|
32
|
-
]);
|
|
33
|
-
parser._transform(buffer, "", () => {});
|
|
34
|
-
expect(parsed.length).toBe(2);
|
|
35
|
-
expect(parsed[0].type).toBe(Constants.Type.SRSP);
|
|
36
|
-
expect(parsed[0].subsystem).toBe(Constants.Subsystem.SYS);
|
|
37
|
-
expect(parsed[0].commandID).toBe(2);
|
|
38
|
-
expect(parsed[0].data).toStrictEqual(Buffer.from([2, 0, 2, 6, 3, 217, 20, 52, 1, 2, 0, 0, 0, 0]));
|
|
39
|
-
expect(parsed[0].length).toBe(14);
|
|
40
|
-
expect(parsed[0].fcs).toBe(0x92);
|
|
41
|
-
expect(parsed[1].type).toBe(Constants.Type.SRSP);
|
|
42
|
-
expect(parsed[1].subsystem).toBe(Constants.Subsystem.SYS);
|
|
43
|
-
expect(parsed[1].commandID).toBe(8);
|
|
44
|
-
expect(parsed[1].data).toStrictEqual(Buffer.from([0, 1, 85]));
|
|
45
|
-
expect(parsed[1].length).toBe(3);
|
|
46
|
-
expect(parsed[1].fcs).toBe(0x3e);
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it("Dont throw error on fcs mismatch", () => {
|
|
50
|
-
const buffer = Buffer.from([0xfe, 0x03, 0x61, 0x08, 0x00, 0x01, 0x55, 0x3f]);
|
|
51
|
-
parser._transform(buffer, "", () => {});
|
|
52
|
-
expect(parsed.length).toBe(0);
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
it("Message in two chunks", () => {
|
|
56
|
-
let buffer = Buffer.from([0xfe, 0x03, 0x61, 0x08, 0x00, 0x01]);
|
|
57
|
-
parser._transform(buffer, "", () => {});
|
|
58
|
-
expect(parsed.length).toBe(0);
|
|
59
|
-
|
|
60
|
-
buffer = Buffer.from([0x55, 0x3e]);
|
|
61
|
-
parser._transform(buffer, "", () => {});
|
|
62
|
-
expect(parsed.length).toBe(1);
|
|
63
|
-
|
|
64
|
-
expect(parsed[0].type).toBe(Constants.Type.SRSP);
|
|
65
|
-
expect(parsed[0].subsystem).toBe(Constants.Subsystem.SYS);
|
|
66
|
-
expect(parsed[0].commandID).toBe(8);
|
|
67
|
-
expect(parsed[0].data).toStrictEqual(Buffer.from([0, 1, 85]));
|
|
68
|
-
expect(parsed[0].length).toBe(3);
|
|
69
|
-
expect(parsed[0].fcs).toBe(0x3e);
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
it("Message in two chunks, fcs as separate", () => {
|
|
73
|
-
let buffer = Buffer.from([0xfe, 0x03, 0x61, 0x08, 0x00, 0x01, 0x55]);
|
|
74
|
-
parser._transform(buffer, "", () => {});
|
|
75
|
-
expect(parsed.length).toBe(0);
|
|
76
|
-
|
|
77
|
-
buffer = Buffer.from([0x3e]);
|
|
78
|
-
parser._transform(buffer, "", () => {});
|
|
79
|
-
expect(parsed.length).toBe(1);
|
|
80
|
-
|
|
81
|
-
expect(parsed[0].type).toBe(Constants.Type.SRSP);
|
|
82
|
-
expect(parsed[0].subsystem).toBe(Constants.Subsystem.SYS);
|
|
83
|
-
expect(parsed[0].commandID).toBe(8);
|
|
84
|
-
expect(parsed[0].data).toStrictEqual(Buffer.from([0, 1, 85]));
|
|
85
|
-
expect(parsed[0].length).toBe(3);
|
|
86
|
-
expect(parsed[0].fcs).toBe(0x3e);
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it("Parse message when it doenst start with SOF and buffer is empty (throw away everything until SOF)", () => {
|
|
90
|
-
const buffer = Buffer.from([
|
|
91
|
-
95, 27, 37, 254, 3, 69, 196, 212, 23, 0, 65, 254, 27, 68, 129, 0, 0, 8, 0, 212, 23, 1, 1, 0, 55, 0, 153, 178, 219, 0, 0, 7, 8, 122, 10, 0,
|
|
92
|
-
0, 32, 243, 212, 23, 29, 160, 254, 7, 69, 196, 111, 244, 2, 122, 155, 246, 95, 87, 254, 27, 68, 129, 0, 0, 6, 0, 111, 244, 1, 1, 0, 118,
|
|
93
|
-
0, 245, 236, 220, 0, 0, 7, 8, 2, 10, 0, 0, 16, 0, 246, 95, 27, 85,
|
|
94
|
-
]);
|
|
95
|
-
parser._transform(buffer, "", () => {});
|
|
96
|
-
expect(parsed.length).toBe(4);
|
|
97
|
-
expect(parsed[0].type).toBe(Constants.Type.AREQ);
|
|
98
|
-
expect(parsed[0].subsystem).toBe(Constants.Subsystem.ZDO);
|
|
99
|
-
expect(parsed[0].commandID).toBe(196);
|
|
100
|
-
expect(parsed[0].data).toStrictEqual(Buffer.from([0xd4, 0x17, 0x00]));
|
|
101
|
-
expect(parsed[0].length).toBe(3);
|
|
102
|
-
expect(parsed[0].fcs).toBe(65);
|
|
103
|
-
expect(parsed[1].type).toBe(Constants.Type.AREQ);
|
|
104
|
-
expect(parsed[1].subsystem).toBe(Constants.Subsystem.AF);
|
|
105
|
-
expect(parsed[1].commandID).toBe(129);
|
|
106
|
-
expect(parsed[1].data).toStrictEqual(
|
|
107
|
-
Buffer.from([0, 0, 8, 0, 212, 23, 1, 1, 0, 55, 0, 153, 178, 219, 0, 0, 7, 8, 122, 10, 0, 0, 32, 243, 212, 23, 29]),
|
|
108
|
-
);
|
|
109
|
-
expect(parsed[1].length).toBe(27);
|
|
110
|
-
expect(parsed[1].fcs).toBe(160);
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
it("Continue parsing on fcs mismatch", () => {
|
|
114
|
-
const buffer1 = Buffer.from([
|
|
115
|
-
0x01,
|
|
116
|
-
0x02,
|
|
117
|
-
0xfe,
|
|
118
|
-
0x03,
|
|
119
|
-
0x61,
|
|
120
|
-
0x08,
|
|
121
|
-
0x00,
|
|
122
|
-
0x01,
|
|
123
|
-
0x55,
|
|
124
|
-
0x3f, // fcs mismatch
|
|
125
|
-
0x08,
|
|
126
|
-
0x09,
|
|
127
|
-
0x12, // Noise
|
|
128
|
-
]);
|
|
129
|
-
|
|
130
|
-
const buffer2 = Buffer.from([
|
|
131
|
-
0x08,
|
|
132
|
-
0x09,
|
|
133
|
-
0x12, // Noise
|
|
134
|
-
]);
|
|
135
|
-
|
|
136
|
-
const buffer3 = Buffer.from([
|
|
137
|
-
0x08,
|
|
138
|
-
0x09,
|
|
139
|
-
0x12, // Noise
|
|
140
|
-
0xfe,
|
|
141
|
-
0x0e,
|
|
142
|
-
0x61,
|
|
143
|
-
0x02, // Valid message part 1
|
|
144
|
-
]);
|
|
145
|
-
|
|
146
|
-
const buffer4 = Buffer.from([
|
|
147
|
-
0x02,
|
|
148
|
-
0x00,
|
|
149
|
-
0x02,
|
|
150
|
-
0x06,
|
|
151
|
-
0x03,
|
|
152
|
-
0xd9,
|
|
153
|
-
0x14,
|
|
154
|
-
0x34,
|
|
155
|
-
0x01,
|
|
156
|
-
0x02,
|
|
157
|
-
0x00,
|
|
158
|
-
0x00,
|
|
159
|
-
0x00,
|
|
160
|
-
0x00,
|
|
161
|
-
0x92, // Valid message part 2
|
|
162
|
-
]);
|
|
163
|
-
|
|
164
|
-
parser._transform(buffer1, "", () => {});
|
|
165
|
-
parser._transform(buffer2, "", () => {});
|
|
166
|
-
parser._transform(buffer3, "", () => {});
|
|
167
|
-
parser._transform(buffer4, "", () => {});
|
|
168
|
-
|
|
169
|
-
expect(parsed.length).toBe(1);
|
|
170
|
-
expect(parsed[0].type).toBe(Constants.Type.SRSP);
|
|
171
|
-
expect(parsed[0].subsystem).toBe(Constants.Subsystem.SYS);
|
|
172
|
-
expect(parsed[0].commandID).toBe(2);
|
|
173
|
-
expect(parsed[0].data).toStrictEqual(Buffer.from([2, 0, 2, 6, 3, 217, 20, 52, 1, 2, 0, 0, 0, 0]));
|
|
174
|
-
expect(parsed[0].length).toBe(14);
|
|
175
|
-
expect(parsed[0].fcs).toBe(0x92);
|
|
176
|
-
});
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
describe("Frame", () => {
|
|
180
|
-
it("To buffer", () => {
|
|
181
|
-
const frame = new Frame(Constants.Type.SRSP, Constants.Subsystem.SYS, 3, Buffer.from([0x06, 0x01]));
|
|
182
|
-
const buffer = frame.toBuffer();
|
|
183
|
-
expect(buffer).toStrictEqual(Buffer.from([0xfe, 0x02, 0x61, 0x03, 0x06, 0x01, 0x67]));
|
|
184
|
-
});
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
describe("Writer", () => {
|
|
188
|
-
let writer;
|
|
189
|
-
|
|
190
|
-
beforeEach(() => {
|
|
191
|
-
writer = new Writer();
|
|
192
|
-
});
|
|
193
|
-
|
|
194
|
-
it("Write frame", () => {
|
|
195
|
-
const frame = new Frame(Constants.Type.SRSP, Constants.Subsystem.SYS, 3, Buffer.from([0x06, 0x01]));
|
|
196
|
-
const push = vi.spyOn(writer, "push").mockReturnValue(undefined);
|
|
197
|
-
writer.writeFrame(frame);
|
|
198
|
-
expect(push).toHaveBeenCalledTimes(1);
|
|
199
|
-
expect(push.mock.calls[0][0]).toStrictEqual(frame.toBuffer());
|
|
200
|
-
});
|
|
201
|
-
|
|
202
|
-
it("Write buffer", () => {
|
|
203
|
-
const buffer = Buffer.from([0x01, 0x02]);
|
|
204
|
-
const push = vi.spyOn(writer, "push").mockReturnValue(undefined);
|
|
205
|
-
writer.writeBuffer(buffer);
|
|
206
|
-
expect(push).toHaveBeenCalledTimes(1);
|
|
207
|
-
expect(push.mock.calls[0][0]).toStrictEqual(buffer);
|
|
208
|
-
});
|
|
209
|
-
|
|
210
|
-
it("Read should do nothing (satisfy coverage)", () => {
|
|
211
|
-
writer.read();
|
|
212
|
-
});
|
|
213
|
-
});
|