@switchbot/homebridge-switchbot 5.0.0-beta.4 → 5.0.0-beta.40
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 +13 -0
- package/README.md +23 -3
- package/config.schema.json +722 -13684
- package/dist/devices-hap/device.d.ts +18 -8
- package/dist/devices-hap/device.d.ts.map +1 -1
- package/dist/devices-hap/device.js +121 -68
- package/dist/devices-hap/device.js.map +1 -1
- package/dist/devices-matter/BaseMatterAccessory.d.ts +27 -0
- package/dist/devices-matter/BaseMatterAccessory.d.ts.map +1 -1
- package/dist/devices-matter/BaseMatterAccessory.js +169 -5
- package/dist/devices-matter/BaseMatterAccessory.js.map +1 -1
- package/dist/devices-matter/ColorLightAccessory.d.ts.map +1 -1
- package/dist/devices-matter/ColorLightAccessory.js +12 -12
- package/dist/devices-matter/ColorLightAccessory.js.map +1 -1
- package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts.map +1 -1
- package/dist/devices-matter/ColorTemperatureLightAccessory.js +5 -7
- package/dist/devices-matter/ColorTemperatureLightAccessory.js.map +1 -1
- package/dist/devices-matter/DimmableLightAccessory.js +9 -9
- package/dist/devices-matter/DimmableLightAccessory.js.map +1 -1
- package/dist/devices-matter/ExtendedColorLightAccessory.d.ts.map +1 -1
- package/dist/devices-matter/ExtendedColorLightAccessory.js +14 -15
- package/dist/devices-matter/ExtendedColorLightAccessory.js.map +1 -1
- package/dist/devices-matter/OnOffLightAccessory.d.ts.map +1 -1
- package/dist/devices-matter/OnOffLightAccessory.js +8 -16
- package/dist/devices-matter/OnOffLightAccessory.js.map +1 -1
- package/dist/devices-matter/OnOffOutletAccessory.d.ts +2 -0
- package/dist/devices-matter/OnOffOutletAccessory.d.ts.map +1 -1
- package/dist/devices-matter/OnOffOutletAccessory.js +10 -7
- package/dist/devices-matter/OnOffOutletAccessory.js.map +1 -1
- package/dist/devices-matter/OnOffSwitchAccessory.js +2 -2
- package/dist/devices-matter/OnOffSwitchAccessory.js.map +1 -1
- package/dist/homebridge-ui/public/index.html +48 -1
- package/dist/homebridge-ui/server.js +53 -8
- package/dist/homebridge-ui/server.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -7
- package/dist/index.js.map +1 -1
- package/dist/irdevice/irdevice.d.ts +11 -10
- package/dist/irdevice/irdevice.d.ts.map +1 -1
- package/dist/irdevice/irdevice.js +76 -35
- package/dist/irdevice/irdevice.js.map +1 -1
- package/dist/platform-hap.d.ts +21 -15
- package/dist/platform-hap.d.ts.map +1 -1
- package/dist/platform-hap.js +246 -147
- package/dist/platform-hap.js.map +1 -1
- package/dist/platform-matter.d.ts +88 -6
- package/dist/platform-matter.d.ts.map +1 -1
- package/dist/platform-matter.js +1726 -243
- package/dist/platform-matter.js.map +1 -1
- package/dist/settings.d.ts +41 -6
- package/dist/settings.d.ts.map +1 -1
- package/dist/settings.js.map +1 -1
- package/dist/test/hap/platform-hap.logging.test.d.ts +2 -0
- package/dist/test/hap/platform-hap.logging.test.d.ts.map +1 -0
- package/dist/test/hap/platform-hap.logging.test.js +33 -0
- package/dist/test/hap/platform-hap.logging.test.js.map +1 -0
- package/dist/test/hap/platform-hap.test.d.ts +2 -0
- package/dist/test/hap/platform-hap.test.d.ts.map +1 -0
- package/dist/test/hap/platform-hap.test.js +62 -0
- package/dist/test/hap/platform-hap.test.js.map +1 -0
- package/dist/test/helpers/platform-fixtures.d.ts +9 -0
- package/dist/test/helpers/platform-fixtures.d.ts.map +1 -0
- package/dist/test/helpers/platform-fixtures.js +30 -0
- package/dist/test/helpers/platform-fixtures.js.map +1 -0
- package/dist/{index.test.d.ts.map → test/index.test.d.ts.map} +1 -1
- package/dist/test/index.test.js +19 -0
- package/dist/test/index.test.js.map +1 -0
- package/dist/test/matter/devices-matter/baseMatterAccessory.test.d.ts +2 -0
- package/dist/test/matter/devices-matter/baseMatterAccessory.test.d.ts.map +1 -0
- package/dist/test/matter/devices-matter/baseMatterAccessory.test.js +71 -0
- package/dist/test/matter/devices-matter/baseMatterAccessory.test.js.map +1 -0
- package/dist/test/matter/platform-matter.additional.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.additional.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.additional.test.js +35 -0
- package/dist/test/matter/platform-matter.additional.test.js.map +1 -0
- package/dist/test/matter/platform-matter.bleparse.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.bleparse.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.bleparse.test.js +43 -0
- package/dist/test/matter/platform-matter.bleparse.test.js.map +1 -0
- package/dist/test/matter/platform-matter.cleanup.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.cleanup.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.cleanup.test.js +70 -0
- package/dist/test/matter/platform-matter.cleanup.test.js.map +1 -0
- package/dist/test/matter/platform-matter.keepstale.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.keepstale.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.keepstale.test.js +27 -0
- package/dist/test/matter/platform-matter.keepstale.test.js.map +1 -0
- package/dist/test/matter/platform-matter.logging.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.logging.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.logging.test.js +29 -0
- package/dist/test/matter/platform-matter.logging.test.js.map +1 -0
- package/dist/test/matter/platform-matter.mapping.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.mapping.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.mapping.test.js +43 -0
- package/dist/test/matter/platform-matter.mapping.test.js.map +1 -0
- package/dist/test/matter/platform-matter.openapi-mapping.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.openapi-mapping.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.openapi-mapping.test.js +84 -0
- package/dist/test/matter/platform-matter.openapi-mapping.test.js.map +1 -0
- package/dist/test/matter/platform-matter.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.test.js +117 -0
- package/dist/test/matter/platform-matter.test.js.map +1 -0
- package/dist/test/matter/platform-matter.unregister.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.unregister.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.unregister.test.js +30 -0
- package/dist/test/matter/platform-matter.unregister.test.js.map +1 -0
- package/dist/test/utils.test.d.ts +2 -0
- package/dist/test/utils.test.d.ts.map +1 -0
- package/dist/test/utils.test.js +95 -0
- package/dist/test/utils.test.js.map +1 -0
- package/dist/test/verifyconfig.test.d.ts.map +1 -0
- package/dist/{verifyconfig.test.js → test/verifyconfig.test.js} +2 -2
- package/dist/test/verifyconfig.test.js.map +1 -0
- package/dist/utils.d.ts +196 -3
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +656 -30
- package/dist/utils.js.map +1 -1
- package/docs/assets/main.js +2 -2
- package/docs/index.html +20 -2
- package/docs/variables/default.html +1 -1
- package/package.json +14 -14
- package/src/devices-hap/device.ts +129 -69
- package/src/devices-matter/BaseMatterAccessory.ts +176 -5
- package/src/devices-matter/ColorLightAccessory.ts +12 -12
- package/src/devices-matter/ColorTemperatureLightAccessory.ts +5 -7
- package/src/devices-matter/DimmableLightAccessory.ts +9 -9
- package/src/devices-matter/ExtendedColorLightAccessory.ts +14 -15
- package/src/devices-matter/OnOffLightAccessory.ts +8 -16
- package/src/devices-matter/OnOffOutletAccessory.ts +12 -7
- package/src/devices-matter/OnOffSwitchAccessory.ts +2 -2
- package/src/homebridge-ui/public/index.html +48 -1
- package/src/homebridge-ui/server.ts +55 -8
- package/src/index.ts +4 -7
- package/src/irdevice/irdevice.ts +74 -35
- package/src/platform-hap.ts +270 -160
- package/src/platform-matter.ts +1768 -240
- package/src/settings.ts +45 -2
- package/src/test/hap/platform-hap.logging.test.ts +36 -0
- package/src/test/hap/platform-hap.test.ts +70 -0
- package/src/test/helpers/platform-fixtures.ts +33 -0
- package/src/test/index.test.ts +24 -0
- package/src/test/matter/devices-matter/baseMatterAccessory.test.ts +88 -0
- package/src/test/matter/platform-matter.additional.test.ts +44 -0
- package/src/test/matter/platform-matter.bleparse.test.ts +47 -0
- package/src/test/matter/platform-matter.cleanup.test.ts +86 -0
- package/src/test/matter/platform-matter.keepstale.test.ts +37 -0
- package/src/test/matter/platform-matter.logging.test.ts +33 -0
- package/src/test/matter/platform-matter.mapping.test.ts +57 -0
- package/src/test/matter/platform-matter.openapi-mapping.test.ts +109 -0
- package/src/test/matter/platform-matter.test.ts +144 -0
- package/src/test/matter/platform-matter.unregister.test.ts +39 -0
- package/src/test/utils.test.ts +96 -0
- package/src/{verifyconfig.test.ts → test/verifyconfig.test.ts} +12 -11
- package/src/utils.ts +714 -32
- package/dist/index.test.js +0 -14
- package/dist/index.test.js.map +0 -1
- package/dist/verifyconfig.test.d.ts.map +0 -1
- package/dist/verifyconfig.test.js.map +0 -1
- package/src/index.test.ts +0 -19
- /package/dist/{index.test.d.ts → test/index.test.d.ts} +0 -0
- /package/dist/{verifyconfig.test.d.ts → test/verifyconfig.test.d.ts} +0 -0
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import registerPlatform from '../index.js';
|
|
3
|
+
import { PLATFORM_NAME, PLUGIN_NAME } from '../settings.js';
|
|
4
|
+
describe('index.ts', () => {
|
|
5
|
+
it('should register the platform with homebridge', () => {
|
|
6
|
+
const api = {
|
|
7
|
+
registerPlatform: vi.fn(),
|
|
8
|
+
};
|
|
9
|
+
registerPlatform(api);
|
|
10
|
+
// The platform registration now uses a runtime proxy/delegate constructor so
|
|
11
|
+
// assert the call happened and the third argument is a constructor function.
|
|
12
|
+
expect(api.registerPlatform).toHaveBeenCalled();
|
|
13
|
+
const callArgs = api.registerPlatform.mock.calls[0];
|
|
14
|
+
expect(callArgs[0]).toBe(PLUGIN_NAME);
|
|
15
|
+
expect(callArgs[1]).toBe(PLATFORM_NAME);
|
|
16
|
+
expect(typeof callArgs[2]).toBe('function');
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
//# sourceMappingURL=index.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../src/test/index.test.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAEjD,OAAO,gBAAgB,MAAM,aAAa,CAAA;AAC1C,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAE3D,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACxB,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,GAAG,GAAG;YACV,gBAAgB,EAAE,EAAE,CAAC,EAAE,EAAE;SACR,CAAA;QAEnB,gBAAgB,CAAC,GAAG,CAAC,CAAA;QAErB,6EAA6E;QAC7E,6EAA6E;QAC7E,MAAM,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,gBAAgB,EAAE,CAAA;QAC/C,MAAM,QAAQ,GAAI,GAAG,CAAC,gBAAwB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;QAC5D,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QACrC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;QACvC,MAAM,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;IAC7C,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"baseMatterAccessory.test.d.ts","sourceRoot":"","sources":["../../../../src/test/matter/devices-matter/baseMatterAccessory.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { BaseMatterAccessory } from '../../../devices-matter/BaseMatterAccessory.js';
|
|
3
|
+
// Minimal concrete subclass for testing
|
|
4
|
+
class TestAccessory extends BaseMatterAccessory {
|
|
5
|
+
constructor(api, log, opts) {
|
|
6
|
+
super(api, log, {
|
|
7
|
+
uuid: opts?.uuid ?? api.matter.uuid.generate('test'),
|
|
8
|
+
displayName: opts?.displayName ?? 'Test',
|
|
9
|
+
deviceType: opts?.deviceType ?? 'OnOffLight',
|
|
10
|
+
serialNumber: opts?.serialNumber ?? 'TEST-1',
|
|
11
|
+
manufacturer: opts?.manufacturer ?? 'TestCo',
|
|
12
|
+
model: opts?.model ?? 'T-1',
|
|
13
|
+
firmwareRevision: opts?.firmwareRevision ?? '1.0',
|
|
14
|
+
hardwareRevision: opts?.hardwareRevision ?? '1.0',
|
|
15
|
+
context: opts?.context ?? {},
|
|
16
|
+
clusters: opts?.clusters,
|
|
17
|
+
handlers: opts?.handlers,
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
describe('baseMatterAccessory helpers', () => {
|
|
22
|
+
it('sendOnCommand uses OpenAPI helper and updates state', async () => {
|
|
23
|
+
const update = vi.fn();
|
|
24
|
+
const sendOpenAPI = vi.fn(async () => ({ response: {}, statusCode: 200 }));
|
|
25
|
+
const api = { matter: { clusterNames: { OnOff: 'onOff', LevelControl: 'level', ColorControl: 'color' }, uuid: { generate: () => 'uuid-1' }, updateAccessoryState: update } };
|
|
26
|
+
const log = { info: vi.fn(), debug: vi.fn(), error: vi.fn(), warn: vi.fn() };
|
|
27
|
+
const ctx = { deviceId: 'DEV-1', sendOpenAPI, connectionType: 'OpenAPI' };
|
|
28
|
+
const acc = new TestAccessory(api, log, { context: ctx });
|
|
29
|
+
await acc.sendOnCommand();
|
|
30
|
+
expect(sendOpenAPI).toHaveBeenCalledWith('turnOn', 'default');
|
|
31
|
+
expect(update).toHaveBeenCalledWith(acc.uuid, 'onOff', { onOff: true });
|
|
32
|
+
});
|
|
33
|
+
it('sendOnCommand uses BLE helper when connectionType is BLE', async () => {
|
|
34
|
+
const update = vi.fn();
|
|
35
|
+
const sendBLE = vi.fn(async () => true);
|
|
36
|
+
const api = { matter: { clusterNames: { OnOff: 'onOff', LevelControl: 'level', ColorControl: 'color' }, uuid: { generate: () => 'uuid-2' }, updateAccessoryState: update } };
|
|
37
|
+
const log = { info: vi.fn(), debug: vi.fn(), error: vi.fn(), warn: vi.fn() };
|
|
38
|
+
const ctx = { deviceId: 'DEV-2', sendBLE, connectionType: 'BLE' };
|
|
39
|
+
const acc = new TestAccessory(api, log, { context: ctx });
|
|
40
|
+
await acc.sendOnCommand();
|
|
41
|
+
expect(sendBLE).toHaveBeenCalledWith('turnOn');
|
|
42
|
+
expect(update).toHaveBeenCalledWith(acc.uuid, 'onOff', { onOff: true });
|
|
43
|
+
});
|
|
44
|
+
it('sendSetBrightness sends percent and updates LevelControl', async () => {
|
|
45
|
+
const update = vi.fn();
|
|
46
|
+
const sendOpenAPI = vi.fn(async () => ({ response: {}, statusCode: 200 }));
|
|
47
|
+
const api = { matter: { clusterNames: { OnOff: 'onOff', LevelControl: 'level', ColorControl: 'color' }, uuid: { generate: () => 'uuid-3' }, updateAccessoryState: update } };
|
|
48
|
+
const log = { info: vi.fn(), debug: vi.fn(), error: vi.fn(), warn: vi.fn() };
|
|
49
|
+
const ctx = { deviceId: 'DEV-3', sendOpenAPI, connectionType: 'OpenAPI' };
|
|
50
|
+
const acc = new TestAccessory(api, log, { context: ctx });
|
|
51
|
+
await acc.sendSetBrightness(50);
|
|
52
|
+
expect(sendOpenAPI).toHaveBeenCalledWith('setBrightness', '50');
|
|
53
|
+
const expectedLevel = Math.round((50 / 100) * 254);
|
|
54
|
+
expect(update).toHaveBeenCalledWith(acc.uuid, 'level', { currentLevel: expectedLevel });
|
|
55
|
+
});
|
|
56
|
+
it('sendSetColor sends RGB and updates ColorControl', async () => {
|
|
57
|
+
const update = vi.fn();
|
|
58
|
+
const sendOpenAPI = vi.fn(async () => ({ response: {}, statusCode: 200 }));
|
|
59
|
+
const api = { matter: { clusterNames: { OnOff: 'onOff', LevelControl: 'level', ColorControl: 'color' }, uuid: { generate: () => 'uuid-4' }, updateAccessoryState: update } };
|
|
60
|
+
const log = { info: vi.fn(), debug: vi.fn(), error: vi.fn(), warn: vi.fn() };
|
|
61
|
+
const ctx = { deviceId: 'DEV-4', sendOpenAPI, connectionType: 'OpenAPI' };
|
|
62
|
+
const acc = new TestAccessory(api, log, { context: ctx });
|
|
63
|
+
await acc.sendSetColor(255, 128, 0);
|
|
64
|
+
expect(sendOpenAPI).toHaveBeenCalledWith('setColor', '255:128:0');
|
|
65
|
+
expect(update).toHaveBeenCalled();
|
|
66
|
+
// Ensure we updated ColorControl cluster with numeric attributes
|
|
67
|
+
const calledWith = (update.mock.calls[0] || update.mock.calls[1]);
|
|
68
|
+
expect(calledWith[1] === 'color' || calledWith[1] === api.matter.clusterNames.ColorControl).toBeTruthy();
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
//# sourceMappingURL=baseMatterAccessory.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"baseMatterAccessory.test.js","sourceRoot":"","sources":["../../../../src/test/matter/devices-matter/baseMatterAccessory.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.additional.test.d.ts","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.additional.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js';
|
|
3
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js';
|
|
4
|
+
describe('additional platform-matter mapping tests', () => {
|
|
5
|
+
it('parses OpenAPI color strings and triggers an update', async () => {
|
|
6
|
+
const updateAccessoryState = vi.fn();
|
|
7
|
+
const api = makeApiStub({ updateAccessoryState });
|
|
8
|
+
const log = makeLogStub();
|
|
9
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
10
|
+
// Some OpenAPI statuses provide color as comma/colon separated or hex
|
|
11
|
+
await platform.applyStatusToAccessory('uuid-col', { deviceId: 'DEV-COL' }, { color: '255:128:64' });
|
|
12
|
+
await platform.applyStatusToAccessory('uuid-col', { deviceId: 'DEV-COL' }, { color: '255,128,64' });
|
|
13
|
+
await platform.applyStatusToAccessory('uuid-col', { deviceId: 'DEV-COL' }, { color: '#FF8040' });
|
|
14
|
+
expect(updateAccessoryState).toHaveBeenCalled();
|
|
15
|
+
});
|
|
16
|
+
it('maps MeterPro CO2 values to Matter updates', async () => {
|
|
17
|
+
const updateAccessoryState = vi.fn();
|
|
18
|
+
const api = makeApiStub({ updateAccessoryState });
|
|
19
|
+
const log = makeLogStub();
|
|
20
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
21
|
+
await platform.applyStatusToAccessory('uuid-co2', { deviceId: 'DEV-METERPRO' }, { co2: 420 });
|
|
22
|
+
expect(updateAccessoryState).toHaveBeenCalled();
|
|
23
|
+
});
|
|
24
|
+
it('handles curtain position synonyms (position / slidePosition)', async () => {
|
|
25
|
+
const updateAccessoryState = vi.fn();
|
|
26
|
+
const api = makeApiStub({ updateAccessoryState });
|
|
27
|
+
const log = makeLogStub();
|
|
28
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
29
|
+
// Provide status with position and slidePosition synonyms
|
|
30
|
+
await platform.applyStatusToAccessory('uuid-cur', { deviceId: 'DEV-CUR', deviceType: 'Curtain' }, { position: 30 });
|
|
31
|
+
await platform.applyStatusToAccessory('uuid-cur', { deviceId: 'DEV-CUR', deviceType: 'Curtain' }, { slidePosition: 70 });
|
|
32
|
+
expect(updateAccessoryState).toHaveBeenCalled();
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
//# sourceMappingURL=platform-matter.additional.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.additional.test.js","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.additional.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAEjD,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAA;AAClE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAA;AAE1E,QAAQ,CAAC,0CAA0C,EAAE,GAAG,EAAE;IACxD,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACnE,MAAM,oBAAoB,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;QACpC,MAAM,GAAG,GAAQ,WAAW,CAAC,EAAE,oBAAoB,EAAE,CAAC,CAAA;QACtD,MAAM,GAAG,GAAG,WAAW,EAAE,CAAA;QACzB,MAAM,QAAQ,GAAG,IAAI,uBAAuB,CAAC,GAAU,EAAE,EAAS,EAAE,GAAG,CAAC,CAAA;QAExE,sEAAsE;QACtE,MAAO,QAAgB,CAAC,sBAAsB,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAS,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAA;QACnH,MAAO,QAAgB,CAAC,sBAAsB,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAS,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAA;QACnH,MAAO,QAAgB,CAAC,sBAAsB,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAS,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAA;QAEhH,MAAM,CAAC,oBAAoB,CAAC,CAAC,gBAAgB,EAAE,CAAA;IACjD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,oBAAoB,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;QACpC,MAAM,GAAG,GAAQ,WAAW,CAAC,EAAE,oBAAoB,EAAE,CAAC,CAAA;QACtD,MAAM,GAAG,GAAG,WAAW,EAAE,CAAA;QACzB,MAAM,QAAQ,GAAG,IAAI,uBAAuB,CAAC,GAAU,EAAE,EAAS,EAAE,GAAG,CAAC,CAAA;QAExE,MAAO,QAAgB,CAAC,sBAAsB,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,cAAc,EAAS,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAA;QAE7G,MAAM,CAAC,oBAAoB,CAAC,CAAC,gBAAgB,EAAE,CAAA;IACjD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC5E,MAAM,oBAAoB,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;QACpC,MAAM,GAAG,GAAQ,WAAW,CAAC,EAAE,oBAAoB,EAAE,CAAC,CAAA;QACtD,MAAM,GAAG,GAAG,WAAW,EAAE,CAAA;QACzB,MAAM,QAAQ,GAAG,IAAI,uBAAuB,CAAC,GAAU,EAAE,EAAS,EAAE,GAAG,CAAC,CAAA;QAExE,0DAA0D;QAC1D,MAAO,QAAgB,CAAC,sBAAsB,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAS,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAA;QACnI,MAAO,QAAgB,CAAC,sBAAsB,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAS,EAAE,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC,CAAA;QAExI,MAAM,CAAC,oBAAoB,CAAC,CAAC,gBAAgB,EAAE,CAAA;IACjD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.bleparse.test.d.ts","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.bleparse.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js';
|
|
3
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js';
|
|
4
|
+
describe('platform-matter BLE advertisement parser', () => {
|
|
5
|
+
it('parses extended serviceData fields correctly', () => {
|
|
6
|
+
const updateAccessoryState = vi.fn();
|
|
7
|
+
const api = makeApiStub({ updateAccessoryState });
|
|
8
|
+
const log = makeLogStub();
|
|
9
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
10
|
+
const dev = { deviceId: 'DEV-TEST' };
|
|
11
|
+
const sd = {
|
|
12
|
+
temp: 22.3,
|
|
13
|
+
humid: 45,
|
|
14
|
+
pm25: 12,
|
|
15
|
+
pm10: 34,
|
|
16
|
+
voc: 120,
|
|
17
|
+
co2: 420,
|
|
18
|
+
motion: 1,
|
|
19
|
+
open: 0,
|
|
20
|
+
leak: 0,
|
|
21
|
+
position: 30,
|
|
22
|
+
fanSpeed: 75,
|
|
23
|
+
battery: 88,
|
|
24
|
+
rgb: '255:128:64',
|
|
25
|
+
};
|
|
26
|
+
const parsed = platform.parseAdvertisementForDevice(dev, sd);
|
|
27
|
+
expect(parsed).toBeTruthy();
|
|
28
|
+
expect(parsed.temperature).toBeCloseTo(22.3);
|
|
29
|
+
expect(parsed.humidity).toBe(45);
|
|
30
|
+
expect(parsed.pm25).toBe(12);
|
|
31
|
+
expect(parsed.pm10).toBe(34);
|
|
32
|
+
expect(parsed.voc).toBe(120);
|
|
33
|
+
expect(parsed.co2).toBe(420);
|
|
34
|
+
expect(parsed.motion).toBeTruthy();
|
|
35
|
+
expect(parsed.contact).toBeDefined();
|
|
36
|
+
expect(parsed.leak).toBeFalsy();
|
|
37
|
+
expect(parsed.position).toBe(30);
|
|
38
|
+
expect(parsed.fanSpeed).toBe(75);
|
|
39
|
+
expect(parsed.battery).toBe(88);
|
|
40
|
+
expect(parsed.color).toEqual({ r: 255, g: 128, b: 64 });
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=platform-matter.bleparse.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.bleparse.test.js","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.bleparse.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAEjD,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAA;AAClE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAA;AAE1E,QAAQ,CAAC,0CAA0C,EAAE,GAAG,EAAE;IACxD,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,oBAAoB,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;QACpC,MAAM,GAAG,GAAQ,WAAW,CAAC,EAAE,oBAAoB,EAAE,CAAC,CAAA;QAEtD,MAAM,GAAG,GAAQ,WAAW,EAAE,CAAA;QAC9B,MAAM,QAAQ,GAAG,IAAI,uBAAuB,CAAC,GAAU,EAAE,EAAS,EAAE,GAAG,CAAC,CAAA;QAExE,MAAM,GAAG,GAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAA;QACzC,MAAM,EAAE,GAAG;YACT,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,EAAE;YACT,IAAI,EAAE,EAAE;YACR,IAAI,EAAE,EAAE;YACR,GAAG,EAAE,GAAG;YACR,GAAG,EAAE,GAAG;YACR,MAAM,EAAE,CAAC;YACT,IAAI,EAAE,CAAC;YACP,IAAI,EAAE,CAAC;YACP,QAAQ,EAAE,EAAE;YACZ,QAAQ,EAAE,EAAE;YACZ,OAAO,EAAE,EAAE;YACX,GAAG,EAAE,YAAY;SAClB,CAAA;QAED,MAAM,MAAM,GAAI,QAAgB,CAAC,2BAA2B,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;QACrE,MAAM,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,CAAA;QAC3B,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;QAC5C,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAChC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAC5B,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAC5B,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC5B,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC5B,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,CAAA;QAClC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,CAAA;QAC/B,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAChC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAChC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAC/B,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAA;IACzD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.cleanup.test.d.ts","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.cleanup.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js';
|
|
3
|
+
import { formatDeviceIdAsMac } from '../../utils.js';
|
|
4
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js';
|
|
5
|
+
describe('platform-matter lifecycle cleanup', () => {
|
|
6
|
+
it('clearDeviceResources removes timers, instances and BLE handler entries', async () => {
|
|
7
|
+
// Setup stubbed API and logs
|
|
8
|
+
const handlers = {};
|
|
9
|
+
const api = makeApiStub({ registerPlatformAccessories: vi.fn(), unregisterPlatformAccessories: vi.fn(), clusterNames: { OnOff: 'OnOff' } });
|
|
10
|
+
api._handlers = handlers;
|
|
11
|
+
// keep api.on as a single-statement arrow to satisfy lint
|
|
12
|
+
api.on = (ev, fn) => (handlers[ev] = fn);
|
|
13
|
+
const log = makeLogStub();
|
|
14
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
15
|
+
// Insert a fake timer, accessory instance, and BLE handler
|
|
16
|
+
const deviceId = 'AA:BB:CC:11:22:33';
|
|
17
|
+
const nid = platform.normalizeDeviceId(deviceId);
|
|
18
|
+
const timer = setInterval(() => { }, 100000);
|
|
19
|
+
platform.refreshTimers.set(nid, timer);
|
|
20
|
+
platform.accessoryInstances.set(nid, { dummy: true });
|
|
21
|
+
platform.bleEventHandler[deviceId.toLowerCase()] = () => { };
|
|
22
|
+
// Ensure they exist prior
|
|
23
|
+
expect(platform.refreshTimers.get(nid)).toBeDefined();
|
|
24
|
+
expect(platform.accessoryInstances.get(nid)).toBeDefined();
|
|
25
|
+
expect(platform.bleEventHandler[deviceId.toLowerCase()]).toBeDefined();
|
|
26
|
+
platform.clearDeviceResources(deviceId);
|
|
27
|
+
// Now they should be removed
|
|
28
|
+
expect(platform.refreshTimers.get(nid)).toBeUndefined();
|
|
29
|
+
expect(platform.accessoryInstances.get(nid)).toBeUndefined();
|
|
30
|
+
expect(platform.bleEventHandler[deviceId.toLowerCase()]).toBeUndefined();
|
|
31
|
+
});
|
|
32
|
+
it('shutdown handler clears all timers and handlers when invoked', async () => {
|
|
33
|
+
// Setup stubbed API and logs
|
|
34
|
+
const handlers = {};
|
|
35
|
+
const api = makeApiStub({ registerPlatformAccessories: vi.fn(), unregisterPlatformAccessories: vi.fn(), clusterNames: { OnOff: 'OnOff' } });
|
|
36
|
+
api._handlers = handlers;
|
|
37
|
+
// keep api.on as a single-statement arrow to satisfy lint
|
|
38
|
+
api.on = (ev, fn) => (handlers[ev] = fn);
|
|
39
|
+
const log = makeLogStub();
|
|
40
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
41
|
+
// Add two timers to the platform (using normalized ids)
|
|
42
|
+
const ids = ['devA', 'devB'];
|
|
43
|
+
for (const id of ids) {
|
|
44
|
+
const nid = platform.normalizeDeviceId(id);
|
|
45
|
+
const t = setInterval(() => { }, 100000);
|
|
46
|
+
platform.refreshTimers.set(nid, t);
|
|
47
|
+
platform.accessoryInstances.set(nid, { dummy: true });
|
|
48
|
+
try {
|
|
49
|
+
const mac = formatDeviceIdAsMac(id).toLowerCase();
|
|
50
|
+
platform.bleEventHandler[mac] = () => { };
|
|
51
|
+
}
|
|
52
|
+
catch {
|
|
53
|
+
// ignore formatting errors in this test
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
// Invoke didFinishLaunching to ensure the platform registered its shutdown handler
|
|
57
|
+
await Promise.resolve(api._handlers.didFinishLaunching?.());
|
|
58
|
+
// Shutdown handler should now be registered on api._handlers.shutdown
|
|
59
|
+
expect(typeof api._handlers.shutdown).toBe('function');
|
|
60
|
+
// Call the shutdown handler
|
|
61
|
+
await Promise.resolve(api._handlers.shutdown());
|
|
62
|
+
// All refresh timers should be cleared
|
|
63
|
+
for (const id of ids) {
|
|
64
|
+
const nid = platform.normalizeDeviceId(id);
|
|
65
|
+
expect(platform.refreshTimers.get(nid)).toBeUndefined();
|
|
66
|
+
expect(platform.accessoryInstances.get(nid)).toBeUndefined();
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
//# sourceMappingURL=platform-matter.cleanup.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.cleanup.test.js","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.cleanup.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.keepstale.test.d.ts","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.keepstale.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js';
|
|
3
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js';
|
|
4
|
+
describe('keepStaleAccessories config flag behavior', () => {
|
|
5
|
+
it('keeps previously-registered accessories when options.keepStaleAccessories=true', async () => {
|
|
6
|
+
const unregister = vi.fn();
|
|
7
|
+
const register = vi.fn();
|
|
8
|
+
const api = makeApiStub({ unregisterPlatformAccessories: unregister, registerPlatformAccessories: register });
|
|
9
|
+
const log = makeLogStub();
|
|
10
|
+
// Create platform with keepStaleAccessories = true
|
|
11
|
+
const platform = new SwitchBotMatterPlatform(log, { options: { keepStaleAccessories: true } }, api);
|
|
12
|
+
platform.discoveredDevices = [{ deviceId: 'DEV1', deviceType: 'Plug', deviceName: 'Device 1' }];
|
|
13
|
+
// Insert a stale accessory into matterAccessories
|
|
14
|
+
const staleUuid = api.matter.uuid.generate('stale-device');
|
|
15
|
+
const staleAcc = { uuid: staleUuid, displayName: 'Stale', context: { deviceId: 'STALE_DEVICE' } };
|
|
16
|
+
platform.matterAccessories.set(staleUuid, staleAcc);
|
|
17
|
+
// Mock createAccessoryFromDevice to return a simple accessory for DEV1
|
|
18
|
+
vi.spyOn(platform, 'createAccessoryFromDevice').mockResolvedValue({ displayName: 'Device 1', uuid: 'uuid-DEV1', context: { deviceId: 'DEV1' } });
|
|
19
|
+
// Run registration which includes stale-removal logic
|
|
20
|
+
await platform.registerMatterAccessories();
|
|
21
|
+
// Expect unregister NOT called (we kept stale accessory)
|
|
22
|
+
expect(unregister).not.toHaveBeenCalled();
|
|
23
|
+
// Stale accessory should still be present in matterAccessories
|
|
24
|
+
expect(platform.matterAccessories.get(staleUuid)).toBeDefined();
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
//# sourceMappingURL=platform-matter.keepstale.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.keepstale.test.js","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.keepstale.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAEjD,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAA;AAClE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAA;AAE1E,QAAQ,CAAC,2CAA2C,EAAE,GAAG,EAAE;IACzD,EAAE,CAAC,gFAAgF,EAAE,KAAK,IAAI,EAAE;QAC9F,MAAM,UAAU,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;QAC1B,MAAM,QAAQ,GAAG,EAAE,CAAC,EAAE,EAAE,CAAA;QACxB,MAAM,GAAG,GAAQ,WAAW,CAAC,EAAE,6BAA6B,EAAE,UAAU,EAAE,2BAA2B,EAAE,QAAQ,EAAE,CAAC,CAAA;QAElH,MAAM,GAAG,GAAQ,WAAW,EAAE,CAAA;QAE9B,mDAAmD;QACnD,MAAM,QAAQ,GAAG,IAAI,uBAAuB,CAAC,GAAU,EAAE,EAAE,OAAO,EAAE,EAAE,oBAAoB,EAAE,IAAI,EAAE,EAAS,EAAE,GAAG,CAAC,CAGhH;QAAC,QAAgB,CAAC,iBAAiB,GAAG,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAA;QAEzG,kDAAkD;QAClD,MAAM,SAAS,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAA;QAC1D,MAAM,QAAQ,GAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,cAAc,EAAE,EAAE,CACrG;QAAC,QAAgB,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;QAE7D,uEAAuE;QACvE,EAAE,CAAC,KAAK,CAAC,QAAe,EAAE,2BAA2B,CAAC,CAAC,iBAAiB,CAAC,EAAE,WAAW,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAS,CAAC,CAAA;QAE9J,sDAAsD;QACtD,MAAO,QAAgB,CAAC,yBAAyB,EAAE,CAAA;QAEnD,yDAAyD;QACzD,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;QAEzC,+DAA+D;QAC/D,MAAM,CAAE,QAAgB,CAAC,iBAAiB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,EAAE,CAAA;IAC1E,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.logging.test.d.ts","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.logging.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js';
|
|
3
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js';
|
|
4
|
+
/**
|
|
5
|
+
* Verifies that debug logger formats arguments so that accessory displayName
|
|
6
|
+
* appears in the output for cached accessory load logs.
|
|
7
|
+
*/
|
|
8
|
+
describe('platform-matter logging', () => {
|
|
9
|
+
it('prints accessory name when loading cached Matter accessory', async () => {
|
|
10
|
+
const api = makeApiStub();
|
|
11
|
+
const log = makeLogStub();
|
|
12
|
+
const platform = new SwitchBotMatterPlatform(log, {
|
|
13
|
+
name: 'SwitchBot',
|
|
14
|
+
credentials: {},
|
|
15
|
+
options: { logging: 'debug' },
|
|
16
|
+
}, api);
|
|
17
|
+
// Simulate Homebridge restoring a cached Matter accessory
|
|
18
|
+
const acc = { uuid: 'uuid-TEST', displayName: 'Test Device', context: { deviceId: 'DEV1' } };
|
|
19
|
+
platform.configureMatterAccessory(acc);
|
|
20
|
+
// debugLog is async and gated; yield to allow the logger to run
|
|
21
|
+
await new Promise(resolve => setTimeout(resolve, 0));
|
|
22
|
+
// In 'debug' mode, debugLog uses log.info with a [DEBUG] prefix
|
|
23
|
+
// Ensure one of the info calls contains the message with the device name
|
|
24
|
+
const calls = log.info.mock.calls;
|
|
25
|
+
const hasLine = calls.some(args => String(args[0]).includes('Loading cached Matter accessory: Test Device'));
|
|
26
|
+
expect(hasLine).toBe(true);
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
//# sourceMappingURL=platform-matter.logging.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.logging.test.js","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.logging.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAE7C,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAA;AAClE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAA;AAE1E;;;GAGG;AACH,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,EAAE,CAAC,4DAA4D,EAAE,KAAK,IAAI,EAAE;QAC1E,MAAM,GAAG,GAAQ,WAAW,EAAE,CAAA;QAC9B,MAAM,GAAG,GAAQ,WAAW,EAAE,CAAA;QAE9B,MAAM,QAAQ,GAAG,IAAI,uBAAuB,CAAC,GAAU,EAAE;YACvD,IAAI,EAAE,WAAW;YACjB,WAAW,EAAE,EAAE;YACf,OAAO,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE;SACvB,EAAE,GAAG,CAAC,CAAA;QAEd,0DAA0D;QAC1D,MAAM,GAAG,GAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,aAAa,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAChG;QAAC,QAAgB,CAAC,wBAAwB,CAAC,GAAG,CAAC,CAAA;QAChD,gEAAgE;QAChE,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAA;QAEpD,gEAAgE;QAChE,yEAAyE;QACzE,MAAM,KAAK,GAAI,GAAG,CAAC,IAAY,CAAC,IAAI,CAAC,KAAwB,CAAA;QAC7D,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,8CAA8C,CAAC,CAAC,CAAA;QAC5G,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC5B,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.mapping.test.d.ts","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.mapping.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js';
|
|
3
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js';
|
|
4
|
+
describe('platform-matter mapping helper', () => {
|
|
5
|
+
it('prefers accessory instance update methods for battery and falls back to api.matter.updateAccessoryState', async () => {
|
|
6
|
+
const updateAccessoryState = vi.fn();
|
|
7
|
+
const api = makeApiStub({ updateAccessoryState, clusterNames: { OnOff: 'OnOff', LevelControl: 'LevelControl', ColorControl: 'ColorControl', PowerSource: 'powerSource' } });
|
|
8
|
+
const log = makeLogStub();
|
|
9
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
10
|
+
// Create a fake accessory instance with updateBatteryPercentage
|
|
11
|
+
const deviceId = 'DEV123';
|
|
12
|
+
const nid = platform.normalizeDeviceId(deviceId);
|
|
13
|
+
const fakeInstance = { updateBatteryPercentage: vi.fn() };
|
|
14
|
+
platform.accessoryInstances.set(nid, fakeInstance);
|
|
15
|
+
// Call the private helper with different battery field names
|
|
16
|
+
await platform.applyStatusToAccessory('uuid-test', { deviceId }, { batteryPercentage: 55 });
|
|
17
|
+
expect(fakeInstance.updateBatteryPercentage).toHaveBeenCalled();
|
|
18
|
+
platform.accessoryInstances.delete(nid);
|
|
19
|
+
await platform.applyStatusToAccessory('uuid-test', { deviceId }, { battery: 30 });
|
|
20
|
+
expect(updateAccessoryState).toHaveBeenCalled();
|
|
21
|
+
});
|
|
22
|
+
it('handles temperature and humidity synonyms', async () => {
|
|
23
|
+
const updateAccessoryState = vi.fn();
|
|
24
|
+
const api = makeApiStub({ updateAccessoryState });
|
|
25
|
+
const log = makeLogStub();
|
|
26
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
27
|
+
const deviceId = 'DEV-TEMP';
|
|
28
|
+
await platform.applyStatusToAccessory('uuid-temp', { deviceId }, { temp: 21.5, humid: 48 });
|
|
29
|
+
// Expect updateAccessoryState to have been called for temperature and humidity
|
|
30
|
+
expect(updateAccessoryState).toHaveBeenCalled();
|
|
31
|
+
});
|
|
32
|
+
it('applies VOC and PM10 mappings when present', async () => {
|
|
33
|
+
const updateAccessoryState = vi.fn();
|
|
34
|
+
const api = makeApiStub({ updateAccessoryState });
|
|
35
|
+
const log = makeLogStub();
|
|
36
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
37
|
+
const deviceId = 'DEV-AQ';
|
|
38
|
+
await platform.applyStatusToAccessory('uuid-aq', { deviceId }, { voc: 123, pm10: 56 });
|
|
39
|
+
// Expect updateAccessoryState (or safeUpdate fallback) to have been called for voc and pm10
|
|
40
|
+
expect(updateAccessoryState).toHaveBeenCalled();
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=platform-matter.mapping.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.mapping.test.js","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.mapping.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.openapi-mapping.test.d.ts","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.openapi-mapping.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
2
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js';
|
|
3
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js';
|
|
4
|
+
describe('platform-matter OpenAPI -> Matter mapping', () => {
|
|
5
|
+
it('maps light OpenAPI status (on/off, brightness, color, battery) to accessory instance helpers', async () => {
|
|
6
|
+
const api = makeApiStub();
|
|
7
|
+
const log = makeLogStub();
|
|
8
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
9
|
+
const deviceId = 'LIGHT-1';
|
|
10
|
+
const nid = platform.normalizeDeviceId(deviceId);
|
|
11
|
+
const instance = {
|
|
12
|
+
updateOnOffState: vi.fn(),
|
|
13
|
+
updateBrightness: vi.fn(),
|
|
14
|
+
updateHueSaturation: vi.fn(),
|
|
15
|
+
updateBatteryPercentage: vi.fn(),
|
|
16
|
+
};
|
|
17
|
+
platform.accessoryInstances.set(nid, instance);
|
|
18
|
+
const status = { power: true, brightness: 80, color: '255:128:64', battery: 92 };
|
|
19
|
+
await platform.applyStatusToAccessory('uuid-light', { deviceId }, status);
|
|
20
|
+
expect(instance.updateOnOffState).toHaveBeenCalled();
|
|
21
|
+
expect(instance.updateBrightness).toHaveBeenCalled();
|
|
22
|
+
expect(instance.updateHueSaturation).toHaveBeenCalled();
|
|
23
|
+
expect(instance.updateBatteryPercentage).toHaveBeenCalled();
|
|
24
|
+
});
|
|
25
|
+
it('maps MeterPro OpenAPI status (temp, humid, co2, pm25, voc) to accessory instance helpers', async () => {
|
|
26
|
+
const api = makeApiStub();
|
|
27
|
+
const log = makeLogStub();
|
|
28
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
29
|
+
const deviceId = 'METERPRO-1';
|
|
30
|
+
const nid = platform.normalizeDeviceId(deviceId);
|
|
31
|
+
const instance = {
|
|
32
|
+
updateTemperature: vi.fn(),
|
|
33
|
+
updateHumidity: vi.fn(),
|
|
34
|
+
updateCO2: vi.fn(),
|
|
35
|
+
updatePM25: vi.fn(),
|
|
36
|
+
updateVOC: vi.fn(),
|
|
37
|
+
};
|
|
38
|
+
platform.accessoryInstances.set(nid, instance);
|
|
39
|
+
const status = { temp: 21.4, humid: 45, co2: 410, pm25: 12, voc: 85 };
|
|
40
|
+
await platform.applyStatusToAccessory('uuid-meter', { deviceId }, status);
|
|
41
|
+
expect(instance.updateTemperature).toHaveBeenCalled();
|
|
42
|
+
expect(instance.updateHumidity).toHaveBeenCalled();
|
|
43
|
+
expect(instance.updateCO2).toHaveBeenCalled();
|
|
44
|
+
expect(instance.updatePM25).toHaveBeenCalled();
|
|
45
|
+
expect(instance.updateVOC).toHaveBeenCalled();
|
|
46
|
+
});
|
|
47
|
+
it('maps lock OpenAPI status to lock helper', async () => {
|
|
48
|
+
const api = makeApiStub();
|
|
49
|
+
const log = makeLogStub();
|
|
50
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
51
|
+
const deviceId = 'LOCK-1';
|
|
52
|
+
const nid = platform.normalizeDeviceId(deviceId);
|
|
53
|
+
const instance = { updateLockState: vi.fn() };
|
|
54
|
+
platform.accessoryInstances.set(nid, instance);
|
|
55
|
+
const status = { lock: true };
|
|
56
|
+
await platform.applyStatusToAccessory('uuid-lock', { deviceId }, status);
|
|
57
|
+
expect(instance.updateLockState).toHaveBeenCalled();
|
|
58
|
+
});
|
|
59
|
+
it('maps curtain position synonyms to lift position helper', async () => {
|
|
60
|
+
const api = makeApiStub();
|
|
61
|
+
const log = makeLogStub();
|
|
62
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
63
|
+
const deviceId = 'CURTAIN-1';
|
|
64
|
+
const nid = platform.normalizeDeviceId(deviceId);
|
|
65
|
+
const instance = { updateLiftPosition: vi.fn() };
|
|
66
|
+
platform.accessoryInstances.set(nid, instance);
|
|
67
|
+
await platform.applyStatusToAccessory('uuid-cur', { deviceId, deviceType: 'Curtain' }, { position: 25 });
|
|
68
|
+
await platform.applyStatusToAccessory('uuid-cur', { deviceId, deviceType: 'Curtain' }, { slidePosition: 75 });
|
|
69
|
+
expect(instance.updateLiftPosition).toHaveBeenCalled();
|
|
70
|
+
});
|
|
71
|
+
it('maps robot vacuum run state / on to updateRunMode or updateOperationalState', async () => {
|
|
72
|
+
const api = makeApiStub();
|
|
73
|
+
const log = makeLogStub();
|
|
74
|
+
const platform = new SwitchBotMatterPlatform(log, {}, api);
|
|
75
|
+
const deviceId = 'RVC-1';
|
|
76
|
+
const nid = platform.normalizeDeviceId(deviceId);
|
|
77
|
+
const instance = { updateRunMode: vi.fn(), updateOperationalState: vi.fn() };
|
|
78
|
+
platform.accessoryInstances.set(nid, instance);
|
|
79
|
+
await platform.applyStatusToAccessory('uuid-rvc', { deviceId, deviceType: 'K10+' }, { runState: 'cleaning', power: true });
|
|
80
|
+
const calls = (instance.updateRunMode.mock?.calls?.length || 0) + (instance.updateOperationalState.mock?.calls?.length || 0);
|
|
81
|
+
expect(calls).toBeGreaterThan(0);
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
//# sourceMappingURL=platform-matter.openapi-mapping.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.openapi-mapping.test.js","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.openapi-mapping.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"platform-matter.test.d.ts","sourceRoot":"","sources":["../../../src/test/matter/platform-matter.test.ts"],"names":[],"mappings":""}
|