zigbee-herdsman 6.0.1 → 6.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +16 -0
- package/dist/adapter/ezsp/driver/uart.js +1 -1
- package/dist/adapter/ezsp/driver/uart.js.map +1 -1
- package/dist/adapter/z-stack/adapter/zStackAdapter.js +4 -4
- package/dist/adapter/z-stack/adapter/zStackAdapter.js.map +1 -1
- package/dist/adapter/zigate/adapter/zigateAdapter.js +4 -4
- package/dist/adapter/zigate/adapter/zigateAdapter.js.map +1 -1
- package/dist/controller/model/device.d.ts.map +1 -1
- package/dist/controller/model/device.js +1 -0
- package/dist/controller/model/device.js.map +1 -1
- package/package.json +14 -6
- package/.github/ISSUE_TEMPLATE/config.yml +0 -5
- package/.github/dependabot.yml +0 -22
- package/.github/workflows/ci.yml +0 -64
- 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 -1248
- 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/buffalo.test.ts +0 -431
- package/test/controller.bench.ts +0 -193
- 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 -206
- 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 -27
- 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
package/test/requests.bench.ts
DELETED
|
@@ -1,206 +0,0 @@
|
|
|
1
|
-
import {bench, describe} from "vitest";
|
|
2
|
-
import type {Adapter} from "../src/adapter";
|
|
3
|
-
import type {ZclPayload} from "../src/adapter/events";
|
|
4
|
-
import Database from "../src/controller/database";
|
|
5
|
-
import {Device, Entity, Group} from "../src/controller/model";
|
|
6
|
-
import {InterviewState} from "../src/controller/model/device";
|
|
7
|
-
import {setLogger} from "../src/utils/logger";
|
|
8
|
-
import * as Zcl from "../src/zspec/zcl";
|
|
9
|
-
import * as Zdo from "../src/zspec/zdo";
|
|
10
|
-
import {uint16To8Array} from "./utils/math";
|
|
11
|
-
|
|
12
|
-
let sendZclFrameToEndpointResponse: ZclPayload | undefined;
|
|
13
|
-
let sendZdoResponse: unknown | undefined;
|
|
14
|
-
|
|
15
|
-
// no-op, makes up for too much of the perf loss (with console logging by default)
|
|
16
|
-
setLogger({
|
|
17
|
-
debug: () => {},
|
|
18
|
-
info: () => {},
|
|
19
|
-
warning: () => {},
|
|
20
|
-
error: () => {},
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
const database = Database.open("dummy");
|
|
24
|
-
// no-op
|
|
25
|
-
database.write = () => {};
|
|
26
|
-
|
|
27
|
-
const adapter = {
|
|
28
|
-
sendZclFrameToEndpoint: async () => Promise.resolve(sendZclFrameToEndpointResponse),
|
|
29
|
-
sendZclFrameToGroup: async () => Promise.resolve(),
|
|
30
|
-
sendZdo: async () => Promise.resolve(sendZdoResponse),
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
Entity.injectDatabase(database);
|
|
34
|
-
Entity.injectAdapter(adapter as unknown as Adapter);
|
|
35
|
-
|
|
36
|
-
const device = Device.create(
|
|
37
|
-
"Router",
|
|
38
|
-
"0xfe34ac2385ff8311",
|
|
39
|
-
0x0001,
|
|
40
|
-
0x0102,
|
|
41
|
-
"Herdsman",
|
|
42
|
-
"Mains (single phase)",
|
|
43
|
-
"Herd-01",
|
|
44
|
-
InterviewState.Successful,
|
|
45
|
-
undefined,
|
|
46
|
-
);
|
|
47
|
-
const endpoint = device.createEndpoint(1);
|
|
48
|
-
const group = Group.create(1);
|
|
49
|
-
|
|
50
|
-
group.addMember(endpoint);
|
|
51
|
-
|
|
52
|
-
const IEEE_ADDRESS1 = "0xfe34ac2385ff8311";
|
|
53
|
-
const IEEE_ADDRESS1_BYTES = [0x11, 0x83, 0xff, 0x85, 0x23, 0xac, 0x34, 0xfe];
|
|
54
|
-
const IEEE_ADDRESS2 = "0x28373fecd834ba37";
|
|
55
|
-
const IEEE_ADDRESS2_BYTES = [0x37, 0xba, 0x34, 0xd8, 0xec, 0x3f, 0x37, 0x28];
|
|
56
|
-
const NODE_ID1 = 0xfe32;
|
|
57
|
-
const NODE_ID1_BYTES = uint16To8Array(NODE_ID1);
|
|
58
|
-
const NODE_ID2 = 0xab39;
|
|
59
|
-
const NODE_ID2_BYTES = uint16To8Array(NODE_ID2);
|
|
60
|
-
const EXT_PAN_ID1 = [3, 43, 56, 23, 65, 23, 67, 23];
|
|
61
|
-
const EXT_PAN_ID2 = [253, 231, 21, 3, 0, 44, 24, 46];
|
|
62
|
-
const LQI_TABLE_RESPONSE = Buffer.from([
|
|
63
|
-
1,
|
|
64
|
-
Zdo.Status.SUCCESS,
|
|
65
|
-
2,
|
|
66
|
-
3,
|
|
67
|
-
2,
|
|
68
|
-
...EXT_PAN_ID2,
|
|
69
|
-
...IEEE_ADDRESS1_BYTES,
|
|
70
|
-
...NODE_ID2_BYTES,
|
|
71
|
-
0b00100101,
|
|
72
|
-
0b00000001,
|
|
73
|
-
1,
|
|
74
|
-
235,
|
|
75
|
-
...EXT_PAN_ID1,
|
|
76
|
-
...IEEE_ADDRESS2_BYTES,
|
|
77
|
-
...NODE_ID1_BYTES,
|
|
78
|
-
0b01000010,
|
|
79
|
-
0b00000000,
|
|
80
|
-
1,
|
|
81
|
-
179,
|
|
82
|
-
]);
|
|
83
|
-
|
|
84
|
-
const BASIC_RESP = Zcl.Frame.create(
|
|
85
|
-
0,
|
|
86
|
-
1,
|
|
87
|
-
true,
|
|
88
|
-
undefined,
|
|
89
|
-
10,
|
|
90
|
-
"readRsp",
|
|
91
|
-
0,
|
|
92
|
-
[
|
|
93
|
-
{
|
|
94
|
-
attrId: 5,
|
|
95
|
-
dataType: Zcl.DataType.CHAR_STR,
|
|
96
|
-
attrData: device.modelID,
|
|
97
|
-
status: 0,
|
|
98
|
-
},
|
|
99
|
-
{
|
|
100
|
-
attrId: 4,
|
|
101
|
-
dataType: Zcl.DataType.CHAR_STR,
|
|
102
|
-
attrData: device.manufacturerName,
|
|
103
|
-
status: 0,
|
|
104
|
-
},
|
|
105
|
-
],
|
|
106
|
-
{},
|
|
107
|
-
).toBuffer();
|
|
108
|
-
|
|
109
|
-
describe("Requests", () => {
|
|
110
|
-
beforeEach(() => {
|
|
111
|
-
sendZclFrameToEndpointResponse = undefined;
|
|
112
|
-
sendZdoResponse = undefined;
|
|
113
|
-
});
|
|
114
|
-
|
|
115
|
-
bench(
|
|
116
|
-
"device lqi",
|
|
117
|
-
async () => {
|
|
118
|
-
sendZdoResponse = Zdo.Buffalo.readResponse(true, Zdo.ClusterId.LQI_TABLE_RESPONSE, LQI_TABLE_RESPONSE);
|
|
119
|
-
const resp = await device.lqi();
|
|
120
|
-
|
|
121
|
-
if (resp.neighbors[0].ieeeAddr !== IEEE_ADDRESS1 || resp.neighbors[1].ieeeAddr !== IEEE_ADDRESS2) {
|
|
122
|
-
throw new Error("Invalid response");
|
|
123
|
-
}
|
|
124
|
-
},
|
|
125
|
-
{throws: true},
|
|
126
|
-
);
|
|
127
|
-
|
|
128
|
-
bench(
|
|
129
|
-
"device.endpoint write basic",
|
|
130
|
-
async () => {
|
|
131
|
-
await endpoint.write("genBasic", {modelId: "Herd-02", manufacturerName: "HerdsmanNew"}, {sendPolicy: "immediate"});
|
|
132
|
-
},
|
|
133
|
-
{throws: true},
|
|
134
|
-
);
|
|
135
|
-
|
|
136
|
-
bench(
|
|
137
|
-
"device.endpoint read basic",
|
|
138
|
-
async () => {
|
|
139
|
-
sendZclFrameToEndpointResponse = {
|
|
140
|
-
clusterID: Zcl.Clusters.genBasic.ID,
|
|
141
|
-
header: Zcl.Header.fromBuffer(BASIC_RESP),
|
|
142
|
-
address: 0x0001,
|
|
143
|
-
data: BASIC_RESP,
|
|
144
|
-
endpoint: 1,
|
|
145
|
-
linkquality: 200,
|
|
146
|
-
groupID: 0,
|
|
147
|
-
wasBroadcast: false,
|
|
148
|
-
destinationEndpoint: 1,
|
|
149
|
-
};
|
|
150
|
-
const resp = await endpoint.read("genBasic", ["modelId", "manufacturerName"], {sendPolicy: "immediate"});
|
|
151
|
-
|
|
152
|
-
if (resp.modelId !== device.modelID || resp.manufacturerName !== device.manufacturerName) {
|
|
153
|
-
throw new Error("Invalid response");
|
|
154
|
-
}
|
|
155
|
-
},
|
|
156
|
-
{throws: true},
|
|
157
|
-
);
|
|
158
|
-
|
|
159
|
-
bench(
|
|
160
|
-
"device.endpoint defaultRsp",
|
|
161
|
-
async () => {
|
|
162
|
-
await endpoint.defaultResponse(0, 0, 0, 1);
|
|
163
|
-
},
|
|
164
|
-
{throws: true},
|
|
165
|
-
);
|
|
166
|
-
|
|
167
|
-
bench(
|
|
168
|
-
"device.endpoint command",
|
|
169
|
-
async () => {
|
|
170
|
-
await endpoint.command("genOnOff", "offWithEffect", {effectid: 1, effectvariant: 2}, {sendPolicy: "immediate"});
|
|
171
|
-
},
|
|
172
|
-
{throws: true},
|
|
173
|
-
);
|
|
174
|
-
|
|
175
|
-
bench(
|
|
176
|
-
"device.endpoint commandResponse",
|
|
177
|
-
async () => {
|
|
178
|
-
await endpoint.commandResponse("genAlarms", "alarm", {alarmcode: 123, clusterid: 456}, {sendPolicy: "immediate"});
|
|
179
|
-
},
|
|
180
|
-
{throws: true},
|
|
181
|
-
);
|
|
182
|
-
|
|
183
|
-
bench(
|
|
184
|
-
"group write basic",
|
|
185
|
-
async () => {
|
|
186
|
-
await group.write("genBasic", {modelId: "Herd-02", manufacturerName: "HerdsmanNew"});
|
|
187
|
-
},
|
|
188
|
-
{throws: true},
|
|
189
|
-
);
|
|
190
|
-
|
|
191
|
-
bench(
|
|
192
|
-
"group read basic",
|
|
193
|
-
async () => {
|
|
194
|
-
await group.read("genBasic", ["modelId", "manufacturerName"]);
|
|
195
|
-
},
|
|
196
|
-
{throws: true},
|
|
197
|
-
);
|
|
198
|
-
|
|
199
|
-
bench(
|
|
200
|
-
"group command",
|
|
201
|
-
async () => {
|
|
202
|
-
await group.command("genRssiLocation", "getDevCfg", {targetaddr: IEEE_ADDRESS1}, {});
|
|
203
|
-
},
|
|
204
|
-
{throws: true},
|
|
205
|
-
);
|
|
206
|
-
});
|
package/test/testUtils.ts
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
function duplicateArray(amount, value) {
|
|
2
|
-
let result = [];
|
|
3
|
-
for (let i = 0; i < amount; i++) {
|
|
4
|
-
result = result.concat(value);
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
return result;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
const ieeeaAddr1 = {
|
|
11
|
-
string: "0xae440112004b1200",
|
|
12
|
-
hex: [0x00, 0x12, 0x4b, 0x00, 0x12, 0x01, 0x44, 0xae],
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
const ieeeaAddr2 = {
|
|
16
|
-
string: "0xaf440112005b1200",
|
|
17
|
-
hex: [0x00, 0x12, 0x5b, 0x00, 0x12, 0x01, 0x44, 0xaf],
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
export {duplicateArray, ieeeaAddr1, ieeeaAddr2};
|
package/test/tsconfig.json
DELETED
package/test/utils/math.ts
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
export const uint16To8Array = (n: number): number[] => {
|
|
2
|
-
return [n & 0xff, (n >> 8) & 0xff];
|
|
3
|
-
};
|
|
4
|
-
|
|
5
|
-
export const uint32To8Array = (n: number): number[] => {
|
|
6
|
-
return [n & 0xff, (n >> 8) & 0xff, (n >> 16) & 0xff, (n >> 24) & 0xff];
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export const uint56To8Array = (n: bigint): number[] => {
|
|
10
|
-
return [
|
|
11
|
-
Number(n & 0xffn),
|
|
12
|
-
Number(n >> 8n) & 0xff,
|
|
13
|
-
Number(n >> 16n) & 0xff,
|
|
14
|
-
Number(n >> 24n) & 0xff,
|
|
15
|
-
Number(n >> 32n) & 0xff,
|
|
16
|
-
Number(n >> 40n) & 0xff,
|
|
17
|
-
Number(n >> 48n) & 0xff,
|
|
18
|
-
];
|
|
19
|
-
};
|
package/test/utils.test.ts
DELETED
|
@@ -1,279 +0,0 @@
|
|
|
1
|
-
import {describe, expect, it, vi} from "vitest";
|
|
2
|
-
import {checkInstallCode} from "../src/controller/helpers/installCodes";
|
|
3
|
-
import {Queue, Utils, Waitress, wait} from "../src/utils";
|
|
4
|
-
import {logger, setLogger} from "../src/utils/logger";
|
|
5
|
-
|
|
6
|
-
const mockLogger = {
|
|
7
|
-
debug: vi.fn(),
|
|
8
|
-
info: vi.fn(),
|
|
9
|
-
warning: vi.fn(),
|
|
10
|
-
error: vi.fn(),
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
describe("Utils", () => {
|
|
14
|
-
it("Is Number Array", () => {
|
|
15
|
-
expect(Utils.isNumberArray([1, 2, 3])).toBeTruthy();
|
|
16
|
-
expect(Utils.isNumberArray([1, 2, "3"])).toBeFalsy();
|
|
17
|
-
expect(Utils.isNumberArray("nonarray")).toBeFalsy();
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
it("Is Number Array of length", () => {
|
|
21
|
-
expect(Utils.isNumberArrayOfLength([1, 2, 3], 3)).toBeTruthy();
|
|
22
|
-
expect(Utils.isNumberArrayOfLength([1, 2], 3)).toBeFalsy();
|
|
23
|
-
expect(Utils.isNumberArrayOfLength([1, 2, "3"], 3)).toBeFalsy();
|
|
24
|
-
expect(Utils.isNumberArrayOfLength("nonarray", 3)).toBeFalsy();
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
it("Is object empty", () => {
|
|
28
|
-
expect(Utils.isObjectEmpty({})).toBeTruthy();
|
|
29
|
-
expect(Utils.isObjectEmpty({a: 1})).toBeFalsy();
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
it("Assert string", () => {
|
|
33
|
-
expect(Utils.assertString("bla")).toBeUndefined();
|
|
34
|
-
|
|
35
|
-
expect(() => {
|
|
36
|
-
Utils.assertString(1);
|
|
37
|
-
}).toThrow("Input must be a string!");
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
it("Test wait", () => {
|
|
41
|
-
const setTimeoutSpy = vi.spyOn(globalThis, "setTimeout").mockImplementationOnce(
|
|
42
|
-
// @ts-expect-error mocked
|
|
43
|
-
() => {},
|
|
44
|
-
);
|
|
45
|
-
wait(1000).then(() => {});
|
|
46
|
-
expect(setTimeout).toHaveBeenCalledTimes(1);
|
|
47
|
-
expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), 1000);
|
|
48
|
-
setTimeoutSpy.mockRestore();
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it("Test waitress", async () => {
|
|
52
|
-
vi.useFakeTimers();
|
|
53
|
-
const validator = (payload: string, matcher: number): boolean => {
|
|
54
|
-
if (payload === "one" && matcher === 1) return true;
|
|
55
|
-
if (payload === "two" && matcher === 2) return true;
|
|
56
|
-
return false;
|
|
57
|
-
};
|
|
58
|
-
const waitress = new Waitress<string, number>(validator, (_, timeout) => `Timedout '${timeout}'`);
|
|
59
|
-
|
|
60
|
-
const wait1 = waitress.waitFor(1, 10000).start();
|
|
61
|
-
waitress.resolve("one");
|
|
62
|
-
expect(await wait1.promise).toBe("one");
|
|
63
|
-
|
|
64
|
-
const wait2_1 = waitress.waitFor(2, 10000).start();
|
|
65
|
-
const wait2_2 = waitress.waitFor(2, 10000).start();
|
|
66
|
-
const wait2_3 = waitress.waitFor(2, 10000).start();
|
|
67
|
-
const wait2_4 = waitress.waitFor(2, 5000).start();
|
|
68
|
-
const wait2_5 = waitress.waitFor(2, 5000).start();
|
|
69
|
-
|
|
70
|
-
waitress.remove(wait2_3.ID);
|
|
71
|
-
vi.advanceTimersByTime(6000);
|
|
72
|
-
waitress.remove(wait2_5.ID);
|
|
73
|
-
waitress.resolve("two");
|
|
74
|
-
expect(await wait2_1.promise).toBe("two");
|
|
75
|
-
expect(await wait2_2.promise).toBe("two");
|
|
76
|
-
|
|
77
|
-
let error2;
|
|
78
|
-
try {
|
|
79
|
-
await wait2_4.promise;
|
|
80
|
-
} catch (e) {
|
|
81
|
-
error2 = e;
|
|
82
|
-
}
|
|
83
|
-
expect(error2).toStrictEqual(new Error("Timedout '5000'"));
|
|
84
|
-
|
|
85
|
-
let error3;
|
|
86
|
-
try {
|
|
87
|
-
await wait2_5.promise;
|
|
88
|
-
} catch (e) {
|
|
89
|
-
error3 = e;
|
|
90
|
-
}
|
|
91
|
-
expect(error3).toStrictEqual(new Error("Timedout '5000'"));
|
|
92
|
-
|
|
93
|
-
vi.useRealTimers();
|
|
94
|
-
|
|
95
|
-
// reject test
|
|
96
|
-
const wait1b = waitress.waitFor(1, 5000).start();
|
|
97
|
-
let error1_;
|
|
98
|
-
wait(1000).then(() => {
|
|
99
|
-
waitress.reject("one", "drop");
|
|
100
|
-
});
|
|
101
|
-
try {
|
|
102
|
-
await wait1b.promise;
|
|
103
|
-
} catch (e) {
|
|
104
|
-
error1_ = e;
|
|
105
|
-
}
|
|
106
|
-
expect(error1_).toStrictEqual(new Error("drop"));
|
|
107
|
-
|
|
108
|
-
vi.useFakeTimers();
|
|
109
|
-
const wait2 = waitress.waitFor(2, 5000).start();
|
|
110
|
-
const handled1 = waitress.reject("tree", "drop");
|
|
111
|
-
expect(handled1).toBe(false);
|
|
112
|
-
let error2_;
|
|
113
|
-
vi.advanceTimersByTime(6000);
|
|
114
|
-
try {
|
|
115
|
-
await wait2.promise;
|
|
116
|
-
} catch (e) {
|
|
117
|
-
error2_ = e;
|
|
118
|
-
}
|
|
119
|
-
expect(error2_).toStrictEqual(new Error("Timedout '5000'"));
|
|
120
|
-
const handled2 = waitress.reject("two", "drop");
|
|
121
|
-
expect(handled2).toBe(false);
|
|
122
|
-
|
|
123
|
-
waitress.waitFor(2, 10000).start().promise;
|
|
124
|
-
waitress.waitFor(2, 10000).start().promise;
|
|
125
|
-
|
|
126
|
-
await vi.advanceTimersByTimeAsync(2000);
|
|
127
|
-
waitress.clear();
|
|
128
|
-
await vi.advanceTimersByTimeAsync(12000);
|
|
129
|
-
|
|
130
|
-
// @ts-expect-error private
|
|
131
|
-
expect(waitress.waiters.size).toStrictEqual(0);
|
|
132
|
-
|
|
133
|
-
vi.useRealTimers();
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
it("Test queue", async () => {
|
|
137
|
-
const queue = new Queue(4);
|
|
138
|
-
const finished: number[] = [];
|
|
139
|
-
|
|
140
|
-
let job1Promise: (() => void) | undefined;
|
|
141
|
-
let job2Promise: (() => void) | undefined;
|
|
142
|
-
const job1 = new Promise<void>((resolve) => {
|
|
143
|
-
job1Promise = resolve;
|
|
144
|
-
});
|
|
145
|
-
const job2 = new Promise<void>((resolve) => {
|
|
146
|
-
job2Promise = resolve;
|
|
147
|
-
});
|
|
148
|
-
const job5 = new Promise((_resolve) => {});
|
|
149
|
-
const job6 = new Promise((_resolve) => {});
|
|
150
|
-
const job7 = new Promise((_resolve) => {});
|
|
151
|
-
|
|
152
|
-
const job1Result = queue.execute<string>(async () => {
|
|
153
|
-
await job1;
|
|
154
|
-
finished.push(1);
|
|
155
|
-
return "finished";
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
const job2Result = queue.execute<void>(async () => {
|
|
159
|
-
await job2;
|
|
160
|
-
finished.push(2);
|
|
161
|
-
}, "mykey");
|
|
162
|
-
|
|
163
|
-
queue.execute<void>(async () => {
|
|
164
|
-
finished.push(3);
|
|
165
|
-
await Promise.resolve();
|
|
166
|
-
}, "mykey");
|
|
167
|
-
|
|
168
|
-
queue.execute<void>(async () => {
|
|
169
|
-
finished.push(4);
|
|
170
|
-
await Promise.resolve();
|
|
171
|
-
}, "mykey2");
|
|
172
|
-
|
|
173
|
-
queue.execute<void>(async () => {
|
|
174
|
-
await job5;
|
|
175
|
-
finished.push(5);
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
queue.execute<void>(async () => {
|
|
179
|
-
await job6;
|
|
180
|
-
finished.push(6);
|
|
181
|
-
});
|
|
182
|
-
|
|
183
|
-
queue.execute<void>(async () => {
|
|
184
|
-
await job7;
|
|
185
|
-
finished.push(7);
|
|
186
|
-
});
|
|
187
|
-
|
|
188
|
-
queue.execute<void>(async () => {
|
|
189
|
-
finished.push(8);
|
|
190
|
-
await Promise.resolve();
|
|
191
|
-
});
|
|
192
|
-
|
|
193
|
-
expect(finished).toEqual([4]);
|
|
194
|
-
job1Promise?.();
|
|
195
|
-
expect(await job1Result).toBe("finished");
|
|
196
|
-
await job1Result;
|
|
197
|
-
expect(finished).toEqual([4, 1]);
|
|
198
|
-
job2Promise?.();
|
|
199
|
-
await job2Result;
|
|
200
|
-
expect(finished).toEqual([4, 1, 2, 3]);
|
|
201
|
-
expect(queue.count()).toBe(5);
|
|
202
|
-
});
|
|
203
|
-
|
|
204
|
-
it("Logs", () => {
|
|
205
|
-
const debugSpy = vi.spyOn(console, "debug");
|
|
206
|
-
const infoSpy = vi.spyOn(console, "info");
|
|
207
|
-
const warningSpy = vi.spyOn(console, "warn");
|
|
208
|
-
const errorSpy = vi.spyOn(console, "error");
|
|
209
|
-
logger.debug("debug", "zh");
|
|
210
|
-
expect(debugSpy).toHaveBeenCalledWith(expect.stringMatching(/^\[\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d.\d\d\dZ\] zh: debug$/));
|
|
211
|
-
logger.info("info", "zh");
|
|
212
|
-
expect(infoSpy).toHaveBeenCalledWith(expect.stringMatching(/^\[\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d.\d\d\dZ\] zh: info$/));
|
|
213
|
-
logger.warning("warning", "zh");
|
|
214
|
-
expect(warningSpy).toHaveBeenCalledWith(expect.stringMatching(/^\[\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d.\d\d\dZ\] zh: warning$/));
|
|
215
|
-
logger.error("error", "zh");
|
|
216
|
-
expect(errorSpy).toHaveBeenCalledWith(expect.stringMatching(/^\[\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d.\d\d\dZ\] zh: error$/));
|
|
217
|
-
|
|
218
|
-
setLogger(mockLogger);
|
|
219
|
-
expect(logger).toEqual(mockLogger);
|
|
220
|
-
logger.debug("debug", "zh");
|
|
221
|
-
expect(mockLogger.debug).toHaveBeenCalledWith("debug", "zh");
|
|
222
|
-
logger.info("info", "zh");
|
|
223
|
-
expect(mockLogger.info).toHaveBeenCalledWith("info", "zh");
|
|
224
|
-
logger.warning("warning", "zh");
|
|
225
|
-
expect(mockLogger.warning).toHaveBeenCalledWith("warning", "zh");
|
|
226
|
-
logger.error("error", "zh");
|
|
227
|
-
expect(mockLogger.error).toHaveBeenCalledWith("error", "zh");
|
|
228
|
-
});
|
|
229
|
-
|
|
230
|
-
it("Checks install codes of all lengths", () => {
|
|
231
|
-
expect(() => checkInstallCode(Buffer.from("001122", "hex"))).toThrow("Install code 001122 has invalid size");
|
|
232
|
-
|
|
233
|
-
const code8Valid = Buffer.from("83FED3407A932B70", "hex");
|
|
234
|
-
const code8Invalid = Buffer.from("FFFED3407A939723", "hex");
|
|
235
|
-
const code8InvalidFixed = Buffer.from("FFFED3407A93DE84", "hex");
|
|
236
|
-
const code8MissingCRC = Buffer.from("83FED3407A93", "hex");
|
|
237
|
-
|
|
238
|
-
expect(checkInstallCode(code8Valid)).toStrictEqual([code8Valid, undefined]);
|
|
239
|
-
expect(checkInstallCode(code8Invalid)).toStrictEqual([code8InvalidFixed, "invalid CRC"]);
|
|
240
|
-
expect(() => checkInstallCode(code8Invalid, false)).toThrow(`Install code ${code8Invalid.toString("hex")} failed CRC validation`);
|
|
241
|
-
expect(checkInstallCode(code8MissingCRC)).toStrictEqual([code8Valid, "missing CRC"]);
|
|
242
|
-
expect(() => checkInstallCode(code8MissingCRC, false)).toThrow(`Install code ${code8MissingCRC.toString("hex")} failed CRC validation`);
|
|
243
|
-
|
|
244
|
-
const code10Valid = Buffer.from("83FED3407A93972397FC", "hex");
|
|
245
|
-
const code10Invalid = Buffer.from("FFFED3407A939723A5C6", "hex");
|
|
246
|
-
const code10InvalidFixed = Buffer.from("FFFED3407A9397238C4F", "hex");
|
|
247
|
-
// consired as 8-length with invalid CRC
|
|
248
|
-
const code10MissingCRC = Buffer.from("83FED3407A939723", "hex");
|
|
249
|
-
const code10MissingCRCFixed = Buffer.from("83FED3407A932B70", "hex");
|
|
250
|
-
|
|
251
|
-
expect(checkInstallCode(code10Valid)).toStrictEqual([code10Valid, undefined]);
|
|
252
|
-
expect(checkInstallCode(code10Invalid)).toStrictEqual([code10InvalidFixed, "invalid CRC"]);
|
|
253
|
-
expect(() => checkInstallCode(code10Invalid, false)).toThrow(`Install code ${code10Invalid.toString("hex")} failed CRC validation`);
|
|
254
|
-
expect(checkInstallCode(code10MissingCRC)).toStrictEqual([code10MissingCRCFixed, "invalid CRC"]);
|
|
255
|
-
expect(() => checkInstallCode(code10MissingCRC, false)).toThrow(`Install code ${code10MissingCRC.toString("hex")} failed CRC validation`);
|
|
256
|
-
|
|
257
|
-
const code14Valid = Buffer.from("83FED3407A939723A5C639FF4C12", "hex");
|
|
258
|
-
const code14Invalid = Buffer.from("FFFED3407A939723A5C639FF4C12", "hex");
|
|
259
|
-
const code14InvalidFixed = Buffer.from("FFFED3407A939723A5C639FFDE74", "hex");
|
|
260
|
-
const code14MissingCRC = Buffer.from("83FED3407A939723A5C639FF", "hex");
|
|
261
|
-
|
|
262
|
-
expect(checkInstallCode(code14Valid)).toStrictEqual([code14Valid, undefined]);
|
|
263
|
-
expect(checkInstallCode(code14Invalid)).toStrictEqual([code14InvalidFixed, "invalid CRC"]);
|
|
264
|
-
expect(() => checkInstallCode(code14Invalid, false)).toThrow(`Install code ${code14Invalid.toString("hex")} failed CRC validation`);
|
|
265
|
-
expect(checkInstallCode(code14MissingCRC)).toStrictEqual([code14Valid, "missing CRC"]);
|
|
266
|
-
expect(() => checkInstallCode(code14MissingCRC, false)).toThrow(`Install code ${code14MissingCRC.toString("hex")} failed CRC validation`);
|
|
267
|
-
|
|
268
|
-
const code18Valid = Buffer.from("83FED3407A939723A5C639B26916D505C3B5", "hex");
|
|
269
|
-
const code18Invalid = Buffer.from("FFFED3407A939723A5C639B26916D505C3B5", "hex");
|
|
270
|
-
const code18InvalidFixed = Buffer.from("FFFED3407A939723A5C639B26916D505EEB1", "hex");
|
|
271
|
-
const code18MissingCRC = Buffer.from("83FED3407A939723A5C639B26916D505", "hex");
|
|
272
|
-
|
|
273
|
-
expect(checkInstallCode(code18Valid)).toStrictEqual([code18Valid, undefined]);
|
|
274
|
-
expect(checkInstallCode(code18Invalid)).toStrictEqual([code18InvalidFixed, "invalid CRC"]);
|
|
275
|
-
expect(() => checkInstallCode(code18Invalid, false)).toThrow(`Install code ${code18Invalid.toString("hex")} failed CRC validation`);
|
|
276
|
-
expect(checkInstallCode(code18MissingCRC)).toStrictEqual([code18Valid, "missing CRC"]);
|
|
277
|
-
expect(() => checkInstallCode(code18MissingCRC, false)).toThrow(`Install code ${code18MissingCRC.toString("hex")} failed CRC validation`);
|
|
278
|
-
});
|
|
279
|
-
});
|
package/test/vitest.config.mts
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import codspeedPlugin from "@codspeed/vitest-plugin";
|
|
2
|
-
import {defineConfig} from "vitest/config";
|
|
3
|
-
|
|
4
|
-
export default defineConfig({
|
|
5
|
-
plugins: [codspeedPlugin()],
|
|
6
|
-
test: {
|
|
7
|
-
globals: true,
|
|
8
|
-
onConsoleLog(_log: string, _type: "stdout" | "stderr"): boolean | undefined {
|
|
9
|
-
return false;
|
|
10
|
-
},
|
|
11
|
-
coverage: {
|
|
12
|
-
enabled: false,
|
|
13
|
-
provider: "v8",
|
|
14
|
-
include: ["src/**"],
|
|
15
|
-
extension: [".ts"],
|
|
16
|
-
// exclude: [],
|
|
17
|
-
clean: true,
|
|
18
|
-
cleanOnRerun: true,
|
|
19
|
-
reportsDirectory: "coverage",
|
|
20
|
-
reporter: ["text", "html"],
|
|
21
|
-
reportOnFailure: false,
|
|
22
|
-
thresholds: {
|
|
23
|
-
100: true,
|
|
24
|
-
},
|
|
25
|
-
},
|
|
26
|
-
},
|
|
27
|
-
});
|