@switchbot/homebridge-switchbot 5.0.0-beta.7 → 5.0.0-beta.70
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 +15 -0
- package/README.md +45 -3
- package/config.schema.json +871 -13754
- package/dist/devices-hap/airpurifier.d.ts.map +1 -1
- package/dist/devices-hap/airpurifier.js +12 -6
- package/dist/devices-hap/airpurifier.js.map +1 -1
- package/dist/devices-hap/blindtilt.js +3 -3
- package/dist/devices-hap/bot.d.ts.map +1 -1
- package/dist/devices-hap/bot.js +16 -5
- package/dist/devices-hap/bot.js.map +1 -1
- package/dist/devices-hap/ceilinglight.d.ts.map +1 -1
- package/dist/devices-hap/ceilinglight.js +13 -7
- package/dist/devices-hap/ceilinglight.js.map +1 -1
- package/dist/devices-hap/colorbulb.d.ts.map +1 -1
- package/dist/devices-hap/colorbulb.js +49 -9
- package/dist/devices-hap/colorbulb.js.map +1 -1
- package/dist/devices-hap/contact.js +3 -3
- package/dist/devices-hap/curtain.js +2 -2
- package/dist/devices-hap/curtain.js.map +1 -1
- 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 +141 -69
- package/dist/devices-hap/device.js.map +1 -1
- package/dist/devices-hap/fan.d.ts.map +1 -1
- package/dist/devices-hap/fan.js +12 -6
- package/dist/devices-hap/fan.js.map +1 -1
- package/dist/devices-hap/hub.d.ts.map +1 -1
- package/dist/devices-hap/hub.js +6 -5
- package/dist/devices-hap/hub.js.map +1 -1
- package/dist/devices-hap/humidifier.d.ts +5 -0
- package/dist/devices-hap/humidifier.d.ts.map +1 -1
- package/dist/devices-hap/humidifier.js +92 -4
- package/dist/devices-hap/humidifier.js.map +1 -1
- package/dist/devices-hap/iosensor.d.ts.map +1 -1
- package/dist/devices-hap/iosensor.js +36 -21
- package/dist/devices-hap/iosensor.js.map +1 -1
- package/dist/devices-hap/lightstrip.d.ts.map +1 -1
- package/dist/devices-hap/lightstrip.js +38 -8
- package/dist/devices-hap/lightstrip.js.map +1 -1
- package/dist/devices-hap/lock.d.ts.map +1 -1
- package/dist/devices-hap/lock.js +14 -6
- package/dist/devices-hap/lock.js.map +1 -1
- package/dist/devices-hap/meter.d.ts.map +1 -1
- package/dist/devices-hap/meter.js +6 -5
- package/dist/devices-hap/meter.js.map +1 -1
- package/dist/devices-hap/meterplus.d.ts.map +1 -1
- package/dist/devices-hap/meterplus.js +6 -5
- package/dist/devices-hap/meterplus.js.map +1 -1
- package/dist/devices-hap/meterpro.d.ts.map +1 -1
- package/dist/devices-hap/meterpro.js +7 -6
- package/dist/devices-hap/meterpro.js.map +1 -1
- package/dist/devices-hap/motion.js +3 -3
- package/dist/devices-hap/plug.d.ts.map +1 -1
- package/dist/devices-hap/plug.js +11 -6
- package/dist/devices-hap/plug.js.map +1 -1
- package/dist/devices-hap/relayswitch.js +3 -3
- package/dist/devices-hap/robotvacuumcleaner.d.ts.map +1 -1
- package/dist/devices-hap/robotvacuumcleaner.js +13 -6
- package/dist/devices-hap/robotvacuumcleaner.js.map +1 -1
- package/dist/devices-hap/waterdetector.js +3 -3
- 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/devices-matter/RoboticVacuumAccessory.d.ts +36 -43
- package/dist/devices-matter/RoboticVacuumAccessory.d.ts.map +1 -1
- package/dist/devices-matter/RoboticVacuumAccessory.js +478 -268
- package/dist/devices-matter/RoboticVacuumAccessory.js.map +1 -1
- package/dist/devices-matter/VenetianBlindAccessory.d.ts +6 -6
- package/dist/devices-matter/VenetianBlindAccessory.d.ts.map +1 -1
- package/dist/devices-matter/VenetianBlindAccessory.js.map +1 -1
- package/dist/devices-matter/WindowBlindAccessory.d.ts +5 -5
- package/dist/devices-matter/WindowBlindAccessory.d.ts.map +1 -1
- package/dist/devices-matter/WindowBlindAccessory.js +57 -6
- package/dist/devices-matter/WindowBlindAccessory.js.map +1 -1
- package/dist/homebridge-ui/public/index.html +219 -19
- package/dist/homebridge-ui/server.js +0 -31
- package/dist/homebridge-ui/server.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -9
- 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 +26 -15
- package/dist/platform-hap.d.ts.map +1 -1
- package/dist/platform-hap.js +333 -153
- package/dist/platform-hap.js.map +1 -1
- package/dist/platform-matter.d.ts +93 -6
- package/dist/platform-matter.d.ts.map +1 -1
- package/dist/platform-matter.js +1878 -229
- package/dist/platform-matter.js.map +1 -1
- package/dist/settings.d.ts +75 -7
- package/dist/settings.d.ts.map +1 -1
- package/dist/settings.js.map +1 -1
- package/dist/test/apiRequestTracker.test.d.ts +2 -0
- package/dist/test/apiRequestTracker.test.d.ts.map +1 -0
- package/dist/test/apiRequestTracker.test.js +392 -0
- package/dist/test/apiRequestTracker.test.js.map +1 -0
- package/dist/test/hap/device-webhook-context.test.d.ts +2 -0
- package/dist/test/hap/device-webhook-context.test.d.ts.map +1 -0
- package/dist/test/hap/device-webhook-context.test.js +128 -0
- package/dist/test/hap/device-webhook-context.test.js.map +1 -0
- 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/test/homebridge-ui/server.test.d.ts +2 -0
- package/dist/test/homebridge-ui/server.test.d.ts.map +1 -0
- package/dist/test/homebridge-ui/server.test.js +445 -0
- package/dist/test/homebridge-ui/server.test.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/matter/platform-matter.webhook.test.d.ts +2 -0
- package/dist/test/matter/platform-matter.webhook.test.d.ts.map +1 -0
- package/dist/test/matter/platform-matter.webhook.test.js +46 -0
- package/dist/test/matter/platform-matter.webhook.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 +204 -3
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +713 -33
- package/dist/utils.js.map +1 -1
- package/docs/assets/highlight.css +14 -0
- package/docs/assets/main.js +2 -2
- package/docs/index.html +31 -2
- package/docs/variables/default.html +1 -1
- package/package.json +15 -15
- package/src/devices-hap/airpurifier.ts +11 -6
- package/src/devices-hap/blindtilt.ts +3 -3
- package/src/devices-hap/bot.ts +15 -5
- package/src/devices-hap/ceilinglight.ts +12 -7
- package/src/devices-hap/colorbulb.ts +46 -10
- package/src/devices-hap/contact.ts +3 -3
- package/src/devices-hap/curtain.ts +2 -2
- package/src/devices-hap/device.ts +149 -70
- package/src/devices-hap/fan.ts +11 -6
- package/src/devices-hap/hub.ts +6 -5
- package/src/devices-hap/humidifier.ts +97 -4
- package/src/devices-hap/iosensor.ts +36 -21
- package/src/devices-hap/lightstrip.ts +35 -8
- package/src/devices-hap/lock.ts +13 -6
- package/src/devices-hap/meter.ts +6 -5
- package/src/devices-hap/meterplus.ts +6 -5
- package/src/devices-hap/meterpro.ts +7 -6
- package/src/devices-hap/motion.ts +3 -3
- package/src/devices-hap/plug.ts +10 -6
- package/src/devices-hap/relayswitch.ts +3 -3
- package/src/devices-hap/robotvacuumcleaner.ts +12 -6
- package/src/devices-hap/waterdetector.ts +3 -3
- 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/devices-matter/RoboticVacuumAccessory.ts +529 -315
- package/src/devices-matter/VenetianBlindAccessory.ts +5 -5
- package/src/devices-matter/WindowBlindAccessory.ts +53 -10
- package/src/homebridge-ui/public/index.html +219 -19
- package/src/homebridge-ui/server.ts +0 -34
- package/src/index.ts +4 -10
- package/src/irdevice/irdevice.ts +74 -35
- package/src/platform-hap.ts +365 -169
- package/src/platform-matter.ts +1923 -230
- package/src/settings.ts +78 -3
- package/src/test/apiRequestTracker.test.ts +417 -0
- package/src/test/hap/device-webhook-context.test.ts +136 -0
- 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/homebridge-ui/server.test.ts +486 -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/matter/platform-matter.webhook.test.ts +54 -0
- package/src/test/utils.test.ts +96 -0
- package/src/{verifyconfig.test.ts → test/verifyconfig.test.ts} +12 -11
- package/src/utils.ts +777 -36
- 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,39 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest'
|
|
2
|
+
|
|
3
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js'
|
|
4
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js'
|
|
5
|
+
|
|
6
|
+
describe('removeDisabledAccessories and unregister edge cases', () => {
|
|
7
|
+
it('clears resources and unregisters accessory even with invalid timer and non-MAC deviceId', async () => {
|
|
8
|
+
// Prepare API stub
|
|
9
|
+
const unregister = vi.fn()
|
|
10
|
+
const api: any = makeApiStub({ unregisterPlatformAccessories: unregister })
|
|
11
|
+
const log: any = makeLogStub()
|
|
12
|
+
const platform = new SwitchBotMatterPlatform(log as any, { enableOnOffLight: false } as any, api)
|
|
13
|
+
|
|
14
|
+
// Build a fake serialized accessory matching the generated UUID for OnOff Light
|
|
15
|
+
const uuid = api.matter.uuid.generate('matter-onoff-light')
|
|
16
|
+
const accessory: any = { uuid, displayName: 'OnOff Light', context: { deviceId: 'NOT-A-MAC' } }
|
|
17
|
+
|
|
18
|
+
// Put invalid timer object into refreshTimers to ensure code handles it
|
|
19
|
+
const nid = (platform as any).normalizeDeviceId(accessory.context.deviceId)
|
|
20
|
+
;(platform as any).refreshTimers.set(nid, null as any)
|
|
21
|
+
;(platform as any).accessoryInstances.set(nid, { dummy: true })
|
|
22
|
+
|
|
23
|
+
// Insert accessory into matterAccessories so removeDisabledAccessories will see it
|
|
24
|
+
;(platform as any).matterAccessories.set(uuid, accessory)
|
|
25
|
+
|
|
26
|
+
// Spy on clearDeviceResources
|
|
27
|
+
const spyClear = vi.spyOn(platform as any, 'clearDeviceResources')
|
|
28
|
+
|
|
29
|
+
// Call removeDisabledAccessories directly
|
|
30
|
+
await (platform as any).removeDisabledAccessories()
|
|
31
|
+
|
|
32
|
+
// Expect unregister was called and matterAccessories cleared
|
|
33
|
+
expect(unregister).toHaveBeenCalled()
|
|
34
|
+
expect((platform as any).matterAccessories.get(uuid)).toBeUndefined()
|
|
35
|
+
|
|
36
|
+
// clearDeviceResources should have been called with the accessory.deviceId
|
|
37
|
+
expect(spyClear).toHaveBeenCalledWith(accessory.context.deviceId)
|
|
38
|
+
})
|
|
39
|
+
})
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest'
|
|
2
|
+
|
|
3
|
+
import { SwitchBotMatterPlatform } from '../../platform-matter.js'
|
|
4
|
+
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js'
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Verify that Matter accessories receive the effective webhook flag
|
|
8
|
+
* in their context when a global webhook option is enabled and the
|
|
9
|
+
* per-device webhook setting is undefined.
|
|
10
|
+
*/
|
|
11
|
+
describe('platform-matter webhook context propagation', () => {
|
|
12
|
+
it('sets context.webhook=true when global webhook is enabled and device.webhook is undefined', async () => {
|
|
13
|
+
const api: any = makeApiStub()
|
|
14
|
+
const log: any = makeLogStub()
|
|
15
|
+
|
|
16
|
+
const platform = new SwitchBotMatterPlatform(log as any, {
|
|
17
|
+
name: 'SwitchBot',
|
|
18
|
+
options: { webhook: true },
|
|
19
|
+
} as any, api)
|
|
20
|
+
|
|
21
|
+
// Minimal device that maps to a known Matter accessory constructor
|
|
22
|
+
const dev: any = {
|
|
23
|
+
deviceId: 'DEV-WH-1',
|
|
24
|
+
deviceName: 'Webhook Plug',
|
|
25
|
+
deviceType: 'Plug',
|
|
26
|
+
// webhook intentionally undefined to test fallback
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const acc = await (platform as any).createAccessoryFromDevice(dev)
|
|
30
|
+
expect(acc).toBeDefined()
|
|
31
|
+
expect((acc as any).context?.webhook).toBe(true)
|
|
32
|
+
})
|
|
33
|
+
|
|
34
|
+
it('keeps explicit device.webhook=false even when global webhook is true', async () => {
|
|
35
|
+
const api: any = makeApiStub()
|
|
36
|
+
const log: any = makeLogStub()
|
|
37
|
+
|
|
38
|
+
const platform = new SwitchBotMatterPlatform(log as any, {
|
|
39
|
+
name: 'SwitchBot',
|
|
40
|
+
options: { webhook: true },
|
|
41
|
+
} as any, api)
|
|
42
|
+
|
|
43
|
+
const dev: any = {
|
|
44
|
+
deviceId: 'DEV-WH-2',
|
|
45
|
+
deviceName: 'No Webhook Plug',
|
|
46
|
+
deviceType: 'Plug',
|
|
47
|
+
webhook: false,
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
const acc = await (platform as any).createAccessoryFromDevice(dev)
|
|
51
|
+
expect(acc).toBeDefined()
|
|
52
|
+
expect((acc as any).context?.webhook).toBe(false)
|
|
53
|
+
})
|
|
54
|
+
})
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from 'vitest'
|
|
2
|
+
|
|
3
|
+
import { createPlatformProxy, detectMatter } from '../utils.js'
|
|
4
|
+
|
|
5
|
+
describe('detectMatter', () => {
|
|
6
|
+
it('returns enabled true when api.isMatterEnabled is a function that returns true', () => {
|
|
7
|
+
const api: any = { isMatterEnabled: () => true }
|
|
8
|
+
const info = detectMatter(api)
|
|
9
|
+
expect(info.enabled).toBe(true)
|
|
10
|
+
expect(info.reason).toMatch(/isMatterEnabled\(\)/)
|
|
11
|
+
})
|
|
12
|
+
|
|
13
|
+
it('returns enabled true when api.isMatterEnabled is a truthy property', () => {
|
|
14
|
+
const api: any = { isMatterEnabled: true }
|
|
15
|
+
const info = detectMatter(api)
|
|
16
|
+
expect(info.enabled).toBe(true)
|
|
17
|
+
expect(info.reason).toMatch(/property present/)
|
|
18
|
+
})
|
|
19
|
+
|
|
20
|
+
it('uses server fallback when present', () => {
|
|
21
|
+
const api: any = { server: { isMatterEnabled: () => false } }
|
|
22
|
+
const info = detectMatter(api)
|
|
23
|
+
expect(info.enabled).toBe(false)
|
|
24
|
+
expect(info.reason).toMatch(/server.isMatterEnabled\(\)/)
|
|
25
|
+
})
|
|
26
|
+
|
|
27
|
+
it('returns enabled false with a reason when no API is present', () => {
|
|
28
|
+
const api: any = {}
|
|
29
|
+
const info = detectMatter(api)
|
|
30
|
+
expect(info.enabled).toBe(false)
|
|
31
|
+
expect(typeof info.reason).toBe('string')
|
|
32
|
+
})
|
|
33
|
+
})
|
|
34
|
+
|
|
35
|
+
describe('createPlatformProxy', () => {
|
|
36
|
+
it('selects HAP platform when Matter is disabled and delegates configureAccessory', () => {
|
|
37
|
+
class HapStub {
|
|
38
|
+
public static created = false
|
|
39
|
+
public configured: any = undefined
|
|
40
|
+
constructor(public log: any, public config: any, public api: any) {
|
|
41
|
+
HapStub.created = true
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
configureAccessory(acc: any) {
|
|
45
|
+
this.configured = acc
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
class MatterStub {
|
|
50
|
+
constructor() {
|
|
51
|
+
throw new Error('should not be constructed')
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const ProxyCtor = createPlatformProxy(HapStub as any, MatterStub as any)
|
|
56
|
+
const log = { info: vi.fn() }
|
|
57
|
+
const api = { isMatterEnabled: false }
|
|
58
|
+
const proxy = new (ProxyCtor as any)(log, {}, api)
|
|
59
|
+
|
|
60
|
+
// delegate should be instance of HapStub
|
|
61
|
+
expect(HapStub.created).toBe(true)
|
|
62
|
+
expect(typeof proxy.delegate.configureAccessory).toBe('function')
|
|
63
|
+
proxy.configureAccessory('accessory')
|
|
64
|
+
expect(proxy.delegate.configured).toBe('accessory')
|
|
65
|
+
// log should mention HAP
|
|
66
|
+
expect((log.info as any).mock.calls[0][0]).toMatch(/HAP/)
|
|
67
|
+
})
|
|
68
|
+
|
|
69
|
+
it('selects Matter platform when isMatterEnabled is true', () => {
|
|
70
|
+
class HapStub2 {
|
|
71
|
+
constructor() {
|
|
72
|
+
throw new Error('should not be constructed')
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
class MatterStub2 {
|
|
77
|
+
public configured: any = undefined
|
|
78
|
+
constructor(public log: any, public config: any, public api: any) {}
|
|
79
|
+
|
|
80
|
+
configureMatterAccessory(acc: any) {
|
|
81
|
+
this.configured = acc
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
const ProxyCtor = createPlatformProxy(HapStub2 as any, MatterStub2 as any)
|
|
86
|
+
const log = { info: vi.fn() }
|
|
87
|
+
const api = { isMatterEnabled: () => true }
|
|
88
|
+
const proxy = new (ProxyCtor as any)(log, {}, api)
|
|
89
|
+
|
|
90
|
+
// delegate should be instance of MatterStub2
|
|
91
|
+
expect(typeof proxy.delegate.configureMatterAccessory).toBe('function')
|
|
92
|
+
;(proxy as any).configureMatterAccessory('macc')
|
|
93
|
+
expect(proxy.delegate.configured).toBe('macc')
|
|
94
|
+
expect((log.info as any).mock.calls[0][0]).toMatch(/Matter/)
|
|
95
|
+
})
|
|
96
|
+
})
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import type { SwitchBotPlatformConfig } from '../settings.js'
|
|
2
|
+
|
|
3
|
+
import { describe, expect, it } from 'vitest'
|
|
3
4
|
|
|
4
5
|
// Create a minimal mock of the SwitchBotPlatform to test verifyConfig
|
|
5
6
|
class MockSwitchBotPlatform {
|
|
@@ -102,10 +103,10 @@ describe('verifyConfig fix for reboot loop', () => {
|
|
|
102
103
|
|
|
103
104
|
// This should NOT throw an error anymore - it should log instead
|
|
104
105
|
await expect(platform.verifyConfig()).resolves.not.toThrow()
|
|
105
|
-
|
|
106
|
+
|
|
106
107
|
// Verify that the error was logged instead of thrown
|
|
107
108
|
expect(platform.errorLogCalls).toContain(
|
|
108
|
-
'The devices config section is missing the *Device ID* in the config. Please check your config.'
|
|
109
|
+
'The devices config section is missing the *Device ID* in the config. Please check your config.',
|
|
109
110
|
)
|
|
110
111
|
})
|
|
111
112
|
|
|
@@ -132,10 +133,10 @@ describe('verifyConfig fix for reboot loop', () => {
|
|
|
132
133
|
|
|
133
134
|
// This should NOT throw an error anymore - it should log instead
|
|
134
135
|
await expect(platform.verifyConfig()).resolves.not.toThrow()
|
|
135
|
-
|
|
136
|
+
|
|
136
137
|
// Verify that the error was logged instead of thrown
|
|
137
138
|
expect(platform.errorLogCalls).toContain(
|
|
138
|
-
'The devices config section is missing the *Device Type* in the config. Please check your config.'
|
|
139
|
+
'The devices config section is missing the *Device Type* in the config. Please check your config.',
|
|
139
140
|
)
|
|
140
141
|
})
|
|
141
142
|
|
|
@@ -187,11 +188,11 @@ describe('verifyConfig fix for reboot loop', () => {
|
|
|
187
188
|
|
|
188
189
|
// Should not throw or log device config errors with valid config
|
|
189
190
|
await expect(platform.verifyConfig()).resolves.not.toThrow()
|
|
190
|
-
|
|
191
|
+
|
|
191
192
|
// Should not have device config errors
|
|
192
|
-
expect(platform.errorLogCalls.filter(msg =>
|
|
193
|
-
msg.includes('missing the *Device ID*')
|
|
194
|
-
msg.includes('missing the *Device Type*')
|
|
193
|
+
expect(platform.errorLogCalls.filter(msg =>
|
|
194
|
+
msg.includes('missing the *Device ID*')
|
|
195
|
+
|| msg.includes('missing the *Device Type*'),
|
|
195
196
|
)).toHaveLength(0)
|
|
196
197
|
})
|
|
197
|
-
})
|
|
198
|
+
})
|