@switchbot/homebridge-switchbot 5.0.0-beta.70 → 5.0.0-beta.72
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/.github/ISSUE_TEMPLATE/e2e-verification.md +36 -0
- package/.github/workflows/ci.yml +61 -0
- package/.github/workflows/manual-e2e.yml +103 -0
- package/CHANGELOG.md +20 -0
- package/E2E-VERIFICATION.md +121 -0
- package/MIGRATION.md +44 -0
- package/README.md +11 -0
- package/config.schema.json +99 -1940
- package/dist/deviceFactory.d.ts +13 -0
- package/dist/deviceFactory.d.ts.map +1 -0
- package/dist/deviceFactory.js +81 -0
- package/dist/deviceFactory.js.map +1 -0
- package/dist/devices/deviceBase.d.ts +50 -0
- package/dist/devices/deviceBase.d.ts.map +1 -0
- package/dist/devices/deviceBase.js +119 -0
- package/dist/devices/deviceBase.js.map +1 -0
- package/dist/devices/genericDevice.d.ts +283 -0
- package/dist/devices/genericDevice.d.ts.map +1 -0
- package/dist/devices/genericDevice.js +1035 -0
- package/dist/devices/genericDevice.js.map +1 -0
- package/dist/homebridge-ui/public/index.html +72 -440
- package/dist/homebridge-ui/server.d.ts +3 -1
- package/dist/homebridge-ui/server.d.ts.map +1 -1
- package/dist/homebridge-ui/server.js +47 -10
- package/dist/homebridge-ui/server.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -3
- package/dist/index.js.map +1 -1
- package/dist/platform.d.ts +27 -0
- package/dist/platform.d.ts.map +1 -0
- package/dist/platform.js +404 -0
- package/dist/platform.js.map +1 -0
- package/dist/settings.d.ts +10 -317
- package/dist/settings.d.ts.map +1 -1
- package/dist/settings.js +5 -30
- package/dist/settings.js.map +1 -1
- package/dist/switchbotClient.d.ts +32 -0
- package/dist/switchbotClient.d.ts.map +1 -0
- package/dist/switchbotClient.js +259 -0
- package/dist/switchbotClient.js.map +1 -0
- package/dist/utils.d.ts +36 -248
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +38 -1367
- package/dist/utils.js.map +1 -1
- package/docs/assets/icons.js +1 -1
- package/docs/assets/icons.svg +1 -1
- package/docs/assets/style.css +3 -3
- package/docs/index.html +50 -15
- package/docs/variables/default.html +1 -1
- package/package.json +19 -18
- package/scripts/e2e/README.md +25 -0
- package/scripts/e2e/curtain-e2e.sh +70 -0
- package/scripts/e2e/fan-e2e.sh +75 -0
- package/scripts/e2e/light-advanced-e2e.sh +97 -0
- package/scripts/e2e/light-e2e.sh +75 -0
- package/scripts/e2e/list-accessories.sh +19 -0
- package/scripts/e2e/lock-e2e.sh +65 -0
- package/scripts/generate-matter-maps.js +60 -0
- package/scripts/run-e2e-local.sh +14 -0
- package/src/deviceFactory.ts +122 -0
- package/src/devices/deviceBase.ts +141 -0
- package/src/devices/genericDevice.ts +965 -0
- package/src/homebridge-ui/public/index.html +72 -440
- package/src/homebridge-ui/server.ts +52 -10
- package/src/index.ts +1 -3
- package/src/platform.ts +395 -0
- package/src/settings.ts +12 -352
- package/src/switchbotClient.ts +266 -0
- package/src/utils.ts +47 -1456
- package/test/accessory-restore.spec.ts +73 -0
- package/test/device-mapping.spec.ts +37 -0
- package/test/deviceFactory.spec.ts +18 -0
- package/test/e2e/run-e2e.spec.ts +50 -0
- package/test/fan-swing.spec.ts +29 -0
- package/test/helpers/matter-harness.ts +53 -0
- package/test/lock-users.spec.ts +44 -0
- package/test/matter-childbridge.spec.ts +55 -0
- package/test/matter-descriptors.spec.ts +97 -0
- package/test/matter-device-state.spec.ts +101 -0
- package/test/matter-integration.spec.ts +70 -0
- package/test/platform.integration.spec.ts +55 -0
- package/test/switchbot-client-debounce.spec.ts +131 -0
- package/test/switchbot-client-openapi.spec.ts +56 -0
- package/test/switchbotClient.spec.ts +10 -0
- package/test/utils.spec.ts +20 -0
- package/vitest.config.ts +7 -0
- package/coverage/base.css +0 -224
- package/coverage/block-navigation.js +0 -87
- package/coverage/clover.xml +0 -15847
- package/coverage/coverage-final.json +0 -42
- package/coverage/docs/assets/dmt/dmt-component-data.js.html +0 -85
- package/coverage/docs/assets/dmt/dmt-components.js.html +0 -286
- package/coverage/docs/assets/dmt/index.html +0 -131
- package/coverage/docs/assets/hierarchy.js.html +0 -85
- package/coverage/docs/assets/icons.js.html +0 -136
- package/coverage/docs/assets/index.html +0 -146
- package/coverage/docs/assets/main.js.html +0 -265
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +0 -191
- package/coverage/prettify.css +0 -1
- package/coverage/prettify.js +0 -2
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +0 -196
- package/coverage/src/device/blindtilt.ts.html +0 -3238
- package/coverage/src/device/bot.ts.html +0 -2803
- package/coverage/src/device/ceilinglight.ts.html +0 -2338
- package/coverage/src/device/colorbulb.ts.html +0 -2824
- package/coverage/src/device/contact.ts.html +0 -1465
- package/coverage/src/device/curtain.ts.html +0 -2869
- package/coverage/src/device/device.ts.html +0 -2500
- package/coverage/src/device/fan.ts.html +0 -2242
- package/coverage/src/device/hub.ts.html +0 -1408
- package/coverage/src/device/humidifier.ts.html +0 -2116
- package/coverage/src/device/index.html +0 -416
- package/coverage/src/device/iosensor.ts.html +0 -1375
- package/coverage/src/device/lightstrip.ts.html +0 -2617
- package/coverage/src/device/lock.ts.html +0 -1963
- package/coverage/src/device/meter.ts.html +0 -1372
- package/coverage/src/device/meterplus.ts.html +0 -1384
- package/coverage/src/device/meterpro.ts.html +0 -1618
- package/coverage/src/device/motion.ts.html +0 -1264
- package/coverage/src/device/plug.ts.html +0 -1372
- package/coverage/src/device/relayswitch.ts.html +0 -2284
- package/coverage/src/device/robotvacuumcleaner.ts.html +0 -1810
- package/coverage/src/device/waterdetector.ts.html +0 -1294
- package/coverage/src/homebridge-ui/index.html +0 -116
- package/coverage/src/homebridge-ui/server.ts.html +0 -229
- package/coverage/src/index.html +0 -161
- package/coverage/src/index.ts.html +0 -124
- package/coverage/src/irdevice/airconditioner.ts.html +0 -1687
- package/coverage/src/irdevice/airpurifier.ts.html +0 -844
- package/coverage/src/irdevice/camera.ts.html +0 -475
- package/coverage/src/irdevice/fan.ts.html +0 -766
- package/coverage/src/irdevice/index.html +0 -251
- package/coverage/src/irdevice/irdevice.ts.html +0 -1117
- package/coverage/src/irdevice/light.ts.html +0 -826
- package/coverage/src/irdevice/other.ts.html +0 -2458
- package/coverage/src/irdevice/tv.ts.html +0 -1222
- package/coverage/src/irdevice/vacuumcleaner.ts.html +0 -466
- package/coverage/src/irdevice/waterheater.ts.html +0 -469
- package/coverage/src/platform.ts.html +0 -8776
- package/coverage/src/settings.ts.html +0 -934
- package/coverage/src/utils.ts.html +0 -2092
- package/dist/devices-hap/airpurifier.d.ts +0 -54
- package/dist/devices-hap/airpurifier.d.ts.map +0 -1
- package/dist/devices-hap/airpurifier.js +0 -533
- package/dist/devices-hap/airpurifier.js.map +0 -1
- package/dist/devices-hap/blindtilt.d.ts +0 -90
- package/dist/devices-hap/blindtilt.d.ts.map +0 -1
- package/dist/devices-hap/blindtilt.js +0 -974
- package/dist/devices-hap/blindtilt.js.map +0 -1
- package/dist/devices-hap/bot.d.ts +0 -102
- package/dist/devices-hap/bot.d.ts.map +0 -1
- package/dist/devices-hap/bot.js +0 -822
- package/dist/devices-hap/bot.js.map +0 -1
- package/dist/devices-hap/ceilinglight.d.ts +0 -85
- package/dist/devices-hap/ceilinglight.d.ts.map +0 -1
- package/dist/devices-hap/ceilinglight.js +0 -707
- package/dist/devices-hap/ceilinglight.js.map +0 -1
- package/dist/devices-hap/colorbulb.d.ts +0 -88
- package/dist/devices-hap/colorbulb.d.ts.map +0 -1
- package/dist/devices-hap/colorbulb.js +0 -921
- package/dist/devices-hap/colorbulb.js.map +0 -1
- package/dist/devices-hap/contact.d.ts +0 -44
- package/dist/devices-hap/contact.d.ts.map +0 -1
- package/dist/devices-hap/contact.js +0 -409
- package/dist/devices-hap/contact.js.map +0 -1
- package/dist/devices-hap/curtain.d.ts +0 -73
- package/dist/devices-hap/curtain.d.ts.map +0 -1
- package/dist/devices-hap/curtain.js +0 -869
- package/dist/devices-hap/curtain.js.map +0 -1
- package/dist/devices-hap/device.d.ts +0 -108
- package/dist/devices-hap/device.d.ts.map +0 -1
- package/dist/devices-hap/device.js +0 -821
- package/dist/devices-hap/device.js.map +0 -1
- package/dist/devices-hap/fan.d.ts +0 -69
- package/dist/devices-hap/fan.d.ts.map +0 -1
- package/dist/devices-hap/fan.js +0 -655
- package/dist/devices-hap/fan.js.map +0 -1
- package/dist/devices-hap/hub.d.ts +0 -37
- package/dist/devices-hap/hub.d.ts.map +0 -1
- package/dist/devices-hap/hub.js +0 -393
- package/dist/devices-hap/hub.js.map +0 -1
- package/dist/devices-hap/humidifier.d.ts +0 -73
- package/dist/devices-hap/humidifier.d.ts.map +0 -1
- package/dist/devices-hap/humidifier.js +0 -716
- package/dist/devices-hap/humidifier.js.map +0 -1
- package/dist/devices-hap/iosensor.d.ts +0 -42
- package/dist/devices-hap/iosensor.d.ts.map +0 -1
- package/dist/devices-hap/iosensor.js +0 -397
- package/dist/devices-hap/iosensor.js.map +0 -1
- package/dist/devices-hap/lightstrip.d.ts +0 -79
- package/dist/devices-hap/lightstrip.d.ts.map +0 -1
- package/dist/devices-hap/lightstrip.js +0 -827
- package/dist/devices-hap/lightstrip.js.map +0 -1
- package/dist/devices-hap/lock.d.ts +0 -53
- package/dist/devices-hap/lock.d.ts.map +0 -1
- package/dist/devices-hap/lock.js +0 -569
- package/dist/devices-hap/lock.js.map +0 -1
- package/dist/devices-hap/meter.d.ts +0 -37
- package/dist/devices-hap/meter.d.ts.map +0 -1
- package/dist/devices-hap/meter.js +0 -380
- package/dist/devices-hap/meter.js.map +0 -1
- package/dist/devices-hap/meterplus.d.ts +0 -42
- package/dist/devices-hap/meterplus.d.ts.map +0 -1
- package/dist/devices-hap/meterplus.js +0 -385
- package/dist/devices-hap/meterplus.js.map +0 -1
- package/dist/devices-hap/meterpro.d.ts +0 -43
- package/dist/devices-hap/meterpro.d.ts.map +0 -1
- package/dist/devices-hap/meterpro.js +0 -469
- package/dist/devices-hap/meterpro.js.map +0 -1
- package/dist/devices-hap/motion.d.ts +0 -42
- package/dist/devices-hap/motion.d.ts.map +0 -1
- package/dist/devices-hap/motion.js +0 -345
- package/dist/devices-hap/motion.js.map +0 -1
- package/dist/devices-hap/plug.d.ts +0 -49
- package/dist/devices-hap/plug.d.ts.map +0 -1
- package/dist/devices-hap/plug.js +0 -400
- package/dist/devices-hap/plug.js.map +0 -1
- package/dist/devices-hap/relayswitch.d.ts +0 -96
- package/dist/devices-hap/relayswitch.d.ts.map +0 -1
- package/dist/devices-hap/relayswitch.js +0 -642
- package/dist/devices-hap/relayswitch.js.map +0 -1
- package/dist/devices-hap/robotvacuumcleaner.d.ts +0 -54
- package/dist/devices-hap/robotvacuumcleaner.d.ts.map +0 -1
- package/dist/devices-hap/robotvacuumcleaner.js +0 -530
- package/dist/devices-hap/robotvacuumcleaner.js.map +0 -1
- package/dist/devices-hap/waterdetector.d.ts +0 -41
- package/dist/devices-hap/waterdetector.d.ts.map +0 -1
- package/dist/devices-hap/waterdetector.js +0 -356
- package/dist/devices-hap/waterdetector.js.map +0 -1
- package/dist/devices-matter/BaseMatterAccessory.d.ts +0 -90
- package/dist/devices-matter/BaseMatterAccessory.d.ts.map +0 -1
- package/dist/devices-matter/BaseMatterAccessory.js +0 -264
- package/dist/devices-matter/BaseMatterAccessory.js.map +0 -1
- package/dist/devices-matter/ColorLightAccessory.d.ts +0 -20
- package/dist/devices-matter/ColorLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ColorLightAccessory.js +0 -95
- package/dist/devices-matter/ColorLightAccessory.js.map +0 -1
- package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts +0 -18
- package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ColorTemperatureLightAccessory.js +0 -76
- package/dist/devices-matter/ColorTemperatureLightAccessory.js.map +0 -1
- package/dist/devices-matter/ContactSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/ContactSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ContactSensorAccessory.js +0 -34
- package/dist/devices-matter/ContactSensorAccessory.js.map +0 -1
- package/dist/devices-matter/DimmableLightAccessory.d.ts +0 -58
- package/dist/devices-matter/DimmableLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/DimmableLightAccessory.js +0 -167
- package/dist/devices-matter/DimmableLightAccessory.js.map +0 -1
- package/dist/devices-matter/DoorLockAccessory.d.ts +0 -14
- package/dist/devices-matter/DoorLockAccessory.d.ts.map +0 -1
- package/dist/devices-matter/DoorLockAccessory.js +0 -50
- package/dist/devices-matter/DoorLockAccessory.js.map +0 -1
- package/dist/devices-matter/ExtendedColorLightAccessory.d.ts +0 -21
- package/dist/devices-matter/ExtendedColorLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ExtendedColorLightAccessory.js +0 -106
- package/dist/devices-matter/ExtendedColorLightAccessory.js.map +0 -1
- package/dist/devices-matter/FanAccessory.d.ts +0 -16
- package/dist/devices-matter/FanAccessory.d.ts.map +0 -1
- package/dist/devices-matter/FanAccessory.js +0 -81
- package/dist/devices-matter/FanAccessory.js.map +0 -1
- package/dist/devices-matter/HumiditySensorAccessory.d.ts +0 -12
- package/dist/devices-matter/HumiditySensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/HumiditySensorAccessory.js +0 -34
- package/dist/devices-matter/HumiditySensorAccessory.js.map +0 -1
- package/dist/devices-matter/LeakSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/LeakSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/LeakSensorAccessory.js +0 -33
- package/dist/devices-matter/LeakSensorAccessory.js.map +0 -1
- package/dist/devices-matter/LightSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/LightSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/LightSensorAccessory.js +0 -34
- package/dist/devices-matter/LightSensorAccessory.js.map +0 -1
- package/dist/devices-matter/OccupancySensorAccessory.d.ts +0 -12
- package/dist/devices-matter/OccupancySensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OccupancySensorAccessory.js +0 -39
- package/dist/devices-matter/OccupancySensorAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffLightAccessory.d.ts +0 -38
- package/dist/devices-matter/OnOffLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffLightAccessory.js +0 -110
- package/dist/devices-matter/OnOffLightAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffOutletAccessory.d.ts +0 -14
- package/dist/devices-matter/OnOffOutletAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffOutletAccessory.js +0 -43
- package/dist/devices-matter/OnOffOutletAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffSwitchAccessory.d.ts +0 -14
- package/dist/devices-matter/OnOffSwitchAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffSwitchAccessory.js +0 -42
- package/dist/devices-matter/OnOffSwitchAccessory.js.map +0 -1
- package/dist/devices-matter/RoboticVacuumAccessory.d.ts +0 -61
- package/dist/devices-matter/RoboticVacuumAccessory.d.ts.map +0 -1
- package/dist/devices-matter/RoboticVacuumAccessory.js +0 -544
- package/dist/devices-matter/RoboticVacuumAccessory.js.map +0 -1
- package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts +0 -11
- package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts.map +0 -1
- package/dist/devices-matter/SmokeCOAlarmAccessory.js +0 -49
- package/dist/devices-matter/SmokeCOAlarmAccessory.js.map +0 -1
- package/dist/devices-matter/TemperatureSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/TemperatureSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/TemperatureSensorAccessory.js +0 -36
- package/dist/devices-matter/TemperatureSensorAccessory.js.map +0 -1
- package/dist/devices-matter/ThermostatAccessory.d.ts +0 -19
- package/dist/devices-matter/ThermostatAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ThermostatAccessory.js +0 -95
- package/dist/devices-matter/ThermostatAccessory.js.map +0 -1
- package/dist/devices-matter/VenetianBlindAccessory.d.ts +0 -19
- package/dist/devices-matter/VenetianBlindAccessory.d.ts.map +0 -1
- package/dist/devices-matter/VenetianBlindAccessory.js +0 -99
- package/dist/devices-matter/VenetianBlindAccessory.js.map +0 -1
- package/dist/devices-matter/WindowBlindAccessory.d.ts +0 -17
- package/dist/devices-matter/WindowBlindAccessory.d.ts.map +0 -1
- package/dist/devices-matter/WindowBlindAccessory.js +0 -131
- package/dist/devices-matter/WindowBlindAccessory.js.map +0 -1
- package/dist/devices-matter/custom/PowerStripAccessory.d.ts +0 -97
- package/dist/devices-matter/custom/PowerStripAccessory.d.ts.map +0 -1
- package/dist/devices-matter/custom/PowerStripAccessory.js +0 -265
- package/dist/devices-matter/custom/PowerStripAccessory.js.map +0 -1
- package/dist/devices-matter/custom/index.d.ts +0 -8
- package/dist/devices-matter/custom/index.d.ts.map +0 -1
- package/dist/devices-matter/custom/index.js +0 -8
- package/dist/devices-matter/custom/index.js.map +0 -1
- package/dist/devices-matter/index.d.ts +0 -29
- package/dist/devices-matter/index.d.ts.map +0 -1
- package/dist/devices-matter/index.js +0 -28
- package/dist/devices-matter/index.js.map +0 -1
- package/dist/irdevice/airconditioner.d.ts +0 -61
- package/dist/irdevice/airconditioner.d.ts.map +0 -1
- package/dist/irdevice/airconditioner.js +0 -472
- package/dist/irdevice/airconditioner.js.map +0 -1
- package/dist/irdevice/airpurifier.d.ts +0 -50
- package/dist/irdevice/airpurifier.d.ts.map +0 -1
- package/dist/irdevice/airpurifier.js +0 -213
- package/dist/irdevice/airpurifier.js.map +0 -1
- package/dist/irdevice/camera.d.ts +0 -32
- package/dist/irdevice/camera.d.ts.map +0 -1
- package/dist/irdevice/camera.js +0 -107
- package/dist/irdevice/camera.js.map +0 -1
- package/dist/irdevice/fan.d.ts +0 -36
- package/dist/irdevice/fan.d.ts.map +0 -1
- package/dist/irdevice/fan.js +0 -200
- package/dist/irdevice/fan.js.map +0 -1
- package/dist/irdevice/irdevice.d.ts +0 -69
- package/dist/irdevice/irdevice.d.ts.map +0 -1
- package/dist/irdevice/irdevice.js +0 -339
- package/dist/irdevice/irdevice.js.map +0 -1
- package/dist/irdevice/light.d.ts +0 -36
- package/dist/irdevice/light.d.ts.map +0 -1
- package/dist/irdevice/light.js +0 -206
- package/dist/irdevice/light.js.map +0 -1
- package/dist/irdevice/other.d.ts +0 -57
- package/dist/irdevice/other.d.ts.map +0 -1
- package/dist/irdevice/other.js +0 -778
- package/dist/irdevice/other.js.map +0 -1
- package/dist/irdevice/tv.d.ts +0 -45
- package/dist/irdevice/tv.d.ts.map +0 -1
- package/dist/irdevice/tv.js +0 -327
- package/dist/irdevice/tv.js.map +0 -1
- package/dist/irdevice/vacuumcleaner.d.ts +0 -28
- package/dist/irdevice/vacuumcleaner.d.ts.map +0 -1
- package/dist/irdevice/vacuumcleaner.js +0 -104
- package/dist/irdevice/vacuumcleaner.js.map +0 -1
- package/dist/irdevice/waterheater.d.ts +0 -30
- package/dist/irdevice/waterheater.d.ts.map +0 -1
- package/dist/irdevice/waterheater.js +0 -105
- package/dist/irdevice/waterheater.js.map +0 -1
- package/dist/platform-hap.d.ts +0 -160
- package/dist/platform-hap.d.ts.map +0 -1
- package/dist/platform-hap.js +0 -3041
- package/dist/platform-hap.js.map +0 -1
- package/dist/platform-matter.d.ts +0 -188
- package/dist/platform-matter.d.ts.map +0 -1
- package/dist/platform-matter.js +0 -2545
- package/dist/platform-matter.js.map +0 -1
- package/dist/test/apiRequestTracker.test.d.ts +0 -2
- package/dist/test/apiRequestTracker.test.d.ts.map +0 -1
- package/dist/test/apiRequestTracker.test.js +0 -392
- package/dist/test/apiRequestTracker.test.js.map +0 -1
- package/dist/test/hap/device-webhook-context.test.d.ts +0 -2
- package/dist/test/hap/device-webhook-context.test.d.ts.map +0 -1
- package/dist/test/hap/device-webhook-context.test.js +0 -128
- package/dist/test/hap/device-webhook-context.test.js.map +0 -1
- package/dist/test/hap/platform-hap.logging.test.d.ts +0 -2
- package/dist/test/hap/platform-hap.logging.test.d.ts.map +0 -1
- package/dist/test/hap/platform-hap.logging.test.js +0 -33
- package/dist/test/hap/platform-hap.logging.test.js.map +0 -1
- package/dist/test/hap/platform-hap.test.d.ts +0 -2
- package/dist/test/hap/platform-hap.test.d.ts.map +0 -1
- package/dist/test/hap/platform-hap.test.js +0 -62
- package/dist/test/hap/platform-hap.test.js.map +0 -1
- package/dist/test/helpers/platform-fixtures.d.ts +0 -9
- package/dist/test/helpers/platform-fixtures.d.ts.map +0 -1
- package/dist/test/helpers/platform-fixtures.js +0 -30
- package/dist/test/helpers/platform-fixtures.js.map +0 -1
- package/dist/test/homebridge-ui/server.test.d.ts +0 -2
- package/dist/test/homebridge-ui/server.test.d.ts.map +0 -1
- package/dist/test/homebridge-ui/server.test.js +0 -445
- package/dist/test/homebridge-ui/server.test.js.map +0 -1
- package/dist/test/index.test.d.ts +0 -2
- package/dist/test/index.test.d.ts.map +0 -1
- package/dist/test/index.test.js +0 -19
- package/dist/test/index.test.js.map +0 -1
- package/dist/test/matter/devices-matter/baseMatterAccessory.test.d.ts +0 -2
- package/dist/test/matter/devices-matter/baseMatterAccessory.test.d.ts.map +0 -1
- package/dist/test/matter/devices-matter/baseMatterAccessory.test.js +0 -71
- package/dist/test/matter/devices-matter/baseMatterAccessory.test.js.map +0 -1
- package/dist/test/matter/platform-matter.additional.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.additional.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.additional.test.js +0 -35
- package/dist/test/matter/platform-matter.additional.test.js.map +0 -1
- package/dist/test/matter/platform-matter.bleparse.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.bleparse.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.bleparse.test.js +0 -43
- package/dist/test/matter/platform-matter.bleparse.test.js.map +0 -1
- package/dist/test/matter/platform-matter.cleanup.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.cleanup.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.cleanup.test.js +0 -70
- package/dist/test/matter/platform-matter.cleanup.test.js.map +0 -1
- package/dist/test/matter/platform-matter.keepstale.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.keepstale.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.keepstale.test.js +0 -27
- package/dist/test/matter/platform-matter.keepstale.test.js.map +0 -1
- package/dist/test/matter/platform-matter.logging.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.logging.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.logging.test.js +0 -29
- package/dist/test/matter/platform-matter.logging.test.js.map +0 -1
- package/dist/test/matter/platform-matter.mapping.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.mapping.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.mapping.test.js +0 -43
- package/dist/test/matter/platform-matter.mapping.test.js.map +0 -1
- package/dist/test/matter/platform-matter.openapi-mapping.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.openapi-mapping.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.openapi-mapping.test.js +0 -84
- package/dist/test/matter/platform-matter.openapi-mapping.test.js.map +0 -1
- package/dist/test/matter/platform-matter.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.test.js +0 -117
- package/dist/test/matter/platform-matter.test.js.map +0 -1
- package/dist/test/matter/platform-matter.unregister.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.unregister.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.unregister.test.js +0 -30
- package/dist/test/matter/platform-matter.unregister.test.js.map +0 -1
- package/dist/test/matter/platform-matter.webhook.test.d.ts +0 -2
- package/dist/test/matter/platform-matter.webhook.test.d.ts.map +0 -1
- package/dist/test/matter/platform-matter.webhook.test.js +0 -46
- package/dist/test/matter/platform-matter.webhook.test.js.map +0 -1
- package/dist/test/utils.test.d.ts +0 -2
- package/dist/test/utils.test.d.ts.map +0 -1
- package/dist/test/utils.test.js +0 -95
- package/dist/test/utils.test.js.map +0 -1
- package/dist/test/verifyconfig.test.d.ts +0 -2
- package/dist/test/verifyconfig.test.d.ts.map +0 -1
- package/dist/test/verifyconfig.test.js +0 -167
- package/dist/test/verifyconfig.test.js.map +0 -1
- package/src/custom.d.ts +0 -7
- package/src/devices-hap/airpurifier.ts +0 -568
- package/src/devices-hap/blindtilt.ts +0 -1049
- package/src/devices-hap/bot.ts +0 -910
- package/src/devices-hap/ceilinglight.ts +0 -747
- package/src/devices-hap/colorbulb.ts +0 -940
- package/src/devices-hap/contact.ts +0 -457
- package/src/devices-hap/curtain.ts +0 -944
- package/src/devices-hap/device.ts +0 -890
- package/src/devices-hap/fan.ts +0 -716
- package/src/devices-hap/hub.ts +0 -440
- package/src/devices-hap/humidifier.ts +0 -762
- package/src/devices-hap/iosensor.ts +0 -442
- package/src/devices-hap/lightstrip.ts +0 -863
- package/src/devices-hap/lock.ts +0 -627
- package/src/devices-hap/meter.ts +0 -427
- package/src/devices-hap/meterplus.ts +0 -431
- package/src/devices-hap/meterpro.ts +0 -523
- package/src/devices-hap/motion.ts +0 -390
- package/src/devices-hap/plug.ts +0 -427
- package/src/devices-hap/relayswitch.ts +0 -727
- package/src/devices-hap/robotvacuumcleaner.ts +0 -574
- package/src/devices-hap/waterdetector.ts +0 -400
- package/src/devices-matter/BaseMatterAccessory.ts +0 -302
- package/src/devices-matter/ColorLightAccessory.ts +0 -110
- package/src/devices-matter/ColorTemperatureLightAccessory.ts +0 -90
- package/src/devices-matter/ContactSensorAccessory.ts +0 -41
- package/src/devices-matter/DimmableLightAccessory.ts +0 -192
- package/src/devices-matter/DoorLockAccessory.ts +0 -60
- package/src/devices-matter/ExtendedColorLightAccessory.ts +0 -122
- package/src/devices-matter/FanAccessory.ts +0 -95
- package/src/devices-matter/HumiditySensorAccessory.ts +0 -41
- package/src/devices-matter/LeakSensorAccessory.ts +0 -40
- package/src/devices-matter/LightSensorAccessory.ts +0 -41
- package/src/devices-matter/OccupancySensorAccessory.ts +0 -48
- package/src/devices-matter/OnOffLightAccessory.ts +0 -125
- package/src/devices-matter/OnOffOutletAccessory.ts +0 -51
- package/src/devices-matter/OnOffSwitchAccessory.ts +0 -51
- package/src/devices-matter/RoboticVacuumAccessory.ts +0 -621
- package/src/devices-matter/SmokeCOAlarmAccessory.ts +0 -59
- package/src/devices-matter/TemperatureSensorAccessory.ts +0 -43
- package/src/devices-matter/ThermostatAccessory.ts +0 -110
- package/src/devices-matter/VenetianBlindAccessory.ts +0 -115
- package/src/devices-matter/WindowBlindAccessory.ts +0 -135
- package/src/devices-matter/custom/PowerStripAccessory.ts +0 -309
- package/src/devices-matter/custom/index.ts +0 -8
- package/src/devices-matter/index.ts +0 -29
- package/src/irdevice/airconditioner.ts +0 -533
- package/src/irdevice/airpurifier.ts +0 -252
- package/src/irdevice/camera.ts +0 -129
- package/src/irdevice/fan.ts +0 -226
- package/src/irdevice/irdevice.ts +0 -383
- package/src/irdevice/light.ts +0 -246
- package/src/irdevice/other.ts +0 -790
- package/src/irdevice/tv.ts +0 -378
- package/src/irdevice/vacuumcleaner.ts +0 -126
- package/src/irdevice/waterheater.ts +0 -127
- package/src/platform-hap.ts +0 -3193
- package/src/platform-matter.ts +0 -2703
- package/src/test/apiRequestTracker.test.ts +0 -417
- package/src/test/hap/device-webhook-context.test.ts +0 -136
- package/src/test/hap/platform-hap.logging.test.ts +0 -36
- package/src/test/hap/platform-hap.test.ts +0 -70
- package/src/test/helpers/platform-fixtures.ts +0 -33
- package/src/test/homebridge-ui/server.test.ts +0 -486
- package/src/test/index.test.ts +0 -24
- package/src/test/matter/devices-matter/baseMatterAccessory.test.ts +0 -88
- package/src/test/matter/platform-matter.additional.test.ts +0 -44
- package/src/test/matter/platform-matter.bleparse.test.ts +0 -47
- package/src/test/matter/platform-matter.cleanup.test.ts +0 -86
- package/src/test/matter/platform-matter.keepstale.test.ts +0 -37
- package/src/test/matter/platform-matter.logging.test.ts +0 -33
- package/src/test/matter/platform-matter.mapping.test.ts +0 -57
- package/src/test/matter/platform-matter.openapi-mapping.test.ts +0 -109
- package/src/test/matter/platform-matter.test.ts +0 -144
- package/src/test/matter/platform-matter.unregister.test.ts +0 -39
- package/src/test/matter/platform-matter.webhook.test.ts +0 -54
- package/src/test/utils.test.ts +0 -96
- package/src/test/verifyconfig.test.ts +0 -198
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it, vi } from 'vitest'
|
|
2
|
-
|
|
3
|
-
import { SwitchBotMatterPlatform } from '../../platform-matter.js'
|
|
4
|
-
import { formatDeviceIdAsMac } from '../../utils.js'
|
|
5
|
-
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js'
|
|
6
|
-
|
|
7
|
-
describe('platform-matter lifecycle cleanup', () => {
|
|
8
|
-
it('clearDeviceResources removes timers, instances and BLE handler entries', async () => {
|
|
9
|
-
// Setup stubbed API and logs
|
|
10
|
-
const handlers: Record<string, (...args: any[]) => any> = {}
|
|
11
|
-
const api: any = makeApiStub({ registerPlatformAccessories: vi.fn(), unregisterPlatformAccessories: vi.fn(), clusterNames: { OnOff: 'OnOff' } })
|
|
12
|
-
api._handlers = handlers
|
|
13
|
-
// keep api.on as a single-statement arrow to satisfy lint
|
|
14
|
-
api.on = (ev: string, fn: (...args: any[]) => any) => (handlers[ev] = fn)
|
|
15
|
-
|
|
16
|
-
const log = makeLogStub()
|
|
17
|
-
|
|
18
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
19
|
-
|
|
20
|
-
// Insert a fake timer, accessory instance, and BLE handler
|
|
21
|
-
const deviceId = 'AA:BB:CC:11:22:33'
|
|
22
|
-
const nid = (platform as any).normalizeDeviceId(deviceId)
|
|
23
|
-
|
|
24
|
-
const timer = setInterval(() => {}, 100000)
|
|
25
|
-
;(platform as any).refreshTimers.set(nid, timer)
|
|
26
|
-
;(platform as any).accessoryInstances.set(nid, { dummy: true })
|
|
27
|
-
;(platform as any).bleEventHandler[deviceId.toLowerCase()] = () => {}
|
|
28
|
-
|
|
29
|
-
// Ensure they exist prior
|
|
30
|
-
expect((platform as any).refreshTimers.get(nid)).toBeDefined()
|
|
31
|
-
expect((platform as any).accessoryInstances.get(nid)).toBeDefined()
|
|
32
|
-
expect((platform as any).bleEventHandler[deviceId.toLowerCase()]).toBeDefined()
|
|
33
|
-
|
|
34
|
-
// Call the private helper
|
|
35
|
-
;(platform as any).clearDeviceResources(deviceId)
|
|
36
|
-
|
|
37
|
-
// Now they should be removed
|
|
38
|
-
expect((platform as any).refreshTimers.get(nid)).toBeUndefined()
|
|
39
|
-
expect((platform as any).accessoryInstances.get(nid)).toBeUndefined()
|
|
40
|
-
expect((platform as any).bleEventHandler[deviceId.toLowerCase()]).toBeUndefined()
|
|
41
|
-
})
|
|
42
|
-
|
|
43
|
-
it('shutdown handler clears all timers and handlers when invoked', async () => {
|
|
44
|
-
// Setup stubbed API and logs
|
|
45
|
-
const handlers: Record<string, (...args: any[]) => any> = {}
|
|
46
|
-
const api: any = makeApiStub({ registerPlatformAccessories: vi.fn(), unregisterPlatformAccessories: vi.fn(), clusterNames: { OnOff: 'OnOff' } })
|
|
47
|
-
api._handlers = handlers
|
|
48
|
-
// keep api.on as a single-statement arrow to satisfy lint
|
|
49
|
-
api.on = (ev: string, fn: (...args: any[]) => any) => (handlers[ev] = fn)
|
|
50
|
-
|
|
51
|
-
const log = makeLogStub()
|
|
52
|
-
|
|
53
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
54
|
-
|
|
55
|
-
// Add two timers to the platform (using normalized ids)
|
|
56
|
-
const ids = ['devA', 'devB']
|
|
57
|
-
for (const id of ids) {
|
|
58
|
-
const nid = (platform as any).normalizeDeviceId(id)
|
|
59
|
-
const t = setInterval(() => {}, 100000)
|
|
60
|
-
;(platform as any).refreshTimers.set(nid, t)
|
|
61
|
-
;(platform as any).accessoryInstances.set(nid, { dummy: true })
|
|
62
|
-
try {
|
|
63
|
-
const mac = formatDeviceIdAsMac(id).toLowerCase()
|
|
64
|
-
;(platform as any).bleEventHandler[mac] = () => {}
|
|
65
|
-
} catch {
|
|
66
|
-
// ignore formatting errors in this test
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
// Invoke didFinishLaunching to ensure the platform registered its shutdown handler
|
|
71
|
-
await Promise.resolve(api._handlers.didFinishLaunching?.())
|
|
72
|
-
|
|
73
|
-
// Shutdown handler should now be registered on api._handlers.shutdown
|
|
74
|
-
expect(typeof api._handlers.shutdown).toBe('function')
|
|
75
|
-
|
|
76
|
-
// Call the shutdown handler
|
|
77
|
-
await Promise.resolve(api._handlers.shutdown())
|
|
78
|
-
|
|
79
|
-
// All refresh timers should be cleared
|
|
80
|
-
for (const id of ids) {
|
|
81
|
-
const nid = (platform as any).normalizeDeviceId(id)
|
|
82
|
-
expect((platform as any).refreshTimers.get(nid)).toBeUndefined()
|
|
83
|
-
expect((platform as any).accessoryInstances.get(nid)).toBeUndefined()
|
|
84
|
-
}
|
|
85
|
-
})
|
|
86
|
-
})
|
|
@@ -1,37 +0,0 @@
|
|
|
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('keepStaleAccessories config flag behavior', () => {
|
|
7
|
-
it('keeps previously-registered accessories when options.keepStaleAccessories=true', async () => {
|
|
8
|
-
const unregister = vi.fn()
|
|
9
|
-
const register = vi.fn()
|
|
10
|
-
const api: any = makeApiStub({ unregisterPlatformAccessories: unregister, registerPlatformAccessories: register })
|
|
11
|
-
|
|
12
|
-
const log: any = makeLogStub()
|
|
13
|
-
|
|
14
|
-
// Create platform with keepStaleAccessories = true
|
|
15
|
-
const platform = new SwitchBotMatterPlatform(log as any, { options: { keepStaleAccessories: true } } as any, api)
|
|
16
|
-
|
|
17
|
-
// Seed discovered devices (one device)
|
|
18
|
-
;(platform as any).discoveredDevices = [{ deviceId: 'DEV1', deviceType: 'Plug', deviceName: 'Device 1' }]
|
|
19
|
-
|
|
20
|
-
// Insert a stale accessory into matterAccessories
|
|
21
|
-
const staleUuid = api.matter.uuid.generate('stale-device')
|
|
22
|
-
const staleAcc: any = { uuid: staleUuid, displayName: 'Stale', context: { deviceId: 'STALE_DEVICE' } }
|
|
23
|
-
;(platform as any).matterAccessories.set(staleUuid, staleAcc)
|
|
24
|
-
|
|
25
|
-
// Mock createAccessoryFromDevice to return a simple accessory for DEV1
|
|
26
|
-
vi.spyOn(platform as any, 'createAccessoryFromDevice').mockResolvedValue({ displayName: 'Device 1', uuid: 'uuid-DEV1', context: { deviceId: 'DEV1' } } as any)
|
|
27
|
-
|
|
28
|
-
// Run registration which includes stale-removal logic
|
|
29
|
-
await (platform as any).registerMatterAccessories()
|
|
30
|
-
|
|
31
|
-
// Expect unregister NOT called (we kept stale accessory)
|
|
32
|
-
expect(unregister).not.toHaveBeenCalled()
|
|
33
|
-
|
|
34
|
-
// Stale accessory should still be present in matterAccessories
|
|
35
|
-
expect((platform as any).matterAccessories.get(staleUuid)).toBeDefined()
|
|
36
|
-
})
|
|
37
|
-
})
|
|
@@ -1,33 +0,0 @@
|
|
|
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
|
-
* Verifies that debug logger formats arguments so that accessory displayName
|
|
8
|
-
* appears in the output for cached accessory load logs.
|
|
9
|
-
*/
|
|
10
|
-
describe('platform-matter logging', () => {
|
|
11
|
-
it('prints accessory name when loading cached Matter accessory', async () => {
|
|
12
|
-
const api: any = makeApiStub()
|
|
13
|
-
const log: any = makeLogStub()
|
|
14
|
-
|
|
15
|
-
const platform = new SwitchBotMatterPlatform(log as any, {
|
|
16
|
-
name: 'SwitchBot',
|
|
17
|
-
credentials: {},
|
|
18
|
-
options: { logging: 'debug' },
|
|
19
|
-
} as any, api)
|
|
20
|
-
|
|
21
|
-
// Simulate Homebridge restoring a cached Matter accessory
|
|
22
|
-
const acc: any = { uuid: 'uuid-TEST', displayName: 'Test Device', context: { deviceId: 'DEV1' } }
|
|
23
|
-
;(platform as any).configureMatterAccessory(acc)
|
|
24
|
-
// debugLog is async and gated; yield to allow the logger to run
|
|
25
|
-
await new Promise(resolve => setTimeout(resolve, 0))
|
|
26
|
-
|
|
27
|
-
// In 'debug' mode, debugLog uses log.info with a [DEBUG] prefix
|
|
28
|
-
// Ensure one of the info calls contains the message with the device name
|
|
29
|
-
const calls = (log.info as any).mock.calls as Array<string[]>
|
|
30
|
-
const hasLine = calls.some(args => String(args[0]).includes('Loading cached Matter accessory: Test Device'))
|
|
31
|
-
expect(hasLine).toBe(true)
|
|
32
|
-
})
|
|
33
|
-
})
|
|
@@ -1,57 +0,0 @@
|
|
|
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('platform-matter mapping helper', () => {
|
|
7
|
-
it('prefers accessory instance update methods for battery and falls back to api.matter.updateAccessoryState', async () => {
|
|
8
|
-
const updateAccessoryState = vi.fn()
|
|
9
|
-
const api: any = makeApiStub({ updateAccessoryState, clusterNames: { OnOff: 'OnOff', LevelControl: 'LevelControl', ColorControl: 'ColorControl', PowerSource: 'powerSource' } })
|
|
10
|
-
|
|
11
|
-
const log: any = makeLogStub()
|
|
12
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
13
|
-
|
|
14
|
-
// Create a fake accessory instance with updateBatteryPercentage
|
|
15
|
-
const deviceId = 'DEV123'
|
|
16
|
-
const nid = (platform as any).normalizeDeviceId(deviceId)
|
|
17
|
-
const fakeInstance = { updateBatteryPercentage: vi.fn() }
|
|
18
|
-
;(platform as any).accessoryInstances.set(nid, fakeInstance)
|
|
19
|
-
|
|
20
|
-
// Call the private helper with different battery field names
|
|
21
|
-
await (platform as any).applyStatusToAccessory('uuid-test', { deviceId } as any, { batteryPercentage: 55 })
|
|
22
|
-
expect(fakeInstance.updateBatteryPercentage).toHaveBeenCalled()
|
|
23
|
-
|
|
24
|
-
// Remove instance to force fallback
|
|
25
|
-
;(platform as any).accessoryInstances.delete(nid)
|
|
26
|
-
await (platform as any).applyStatusToAccessory('uuid-test', { deviceId } as any, { battery: 30 })
|
|
27
|
-
expect(updateAccessoryState).toHaveBeenCalled()
|
|
28
|
-
})
|
|
29
|
-
|
|
30
|
-
it('handles temperature and humidity synonyms', async () => {
|
|
31
|
-
const updateAccessoryState = vi.fn()
|
|
32
|
-
const api: any = makeApiStub({ updateAccessoryState })
|
|
33
|
-
|
|
34
|
-
const log: any = makeLogStub()
|
|
35
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
36
|
-
|
|
37
|
-
const deviceId = 'DEV-TEMP'
|
|
38
|
-
await (platform as any).applyStatusToAccessory('uuid-temp', { deviceId } as any, { temp: 21.5, humid: 48 })
|
|
39
|
-
|
|
40
|
-
// Expect updateAccessoryState to have been called for temperature and humidity
|
|
41
|
-
expect(updateAccessoryState).toHaveBeenCalled()
|
|
42
|
-
})
|
|
43
|
-
|
|
44
|
-
it('applies VOC and PM10 mappings when present', async () => {
|
|
45
|
-
const updateAccessoryState = vi.fn()
|
|
46
|
-
const api: any = makeApiStub({ updateAccessoryState })
|
|
47
|
-
|
|
48
|
-
const log: any = makeLogStub()
|
|
49
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
50
|
-
|
|
51
|
-
const deviceId = 'DEV-AQ'
|
|
52
|
-
await (platform as any).applyStatusToAccessory('uuid-aq', { deviceId } as any, { voc: 123, pm10: 56 })
|
|
53
|
-
|
|
54
|
-
// Expect updateAccessoryState (or safeUpdate fallback) to have been called for voc and pm10
|
|
55
|
-
expect(updateAccessoryState).toHaveBeenCalled()
|
|
56
|
-
})
|
|
57
|
-
})
|
|
@@ -1,109 +0,0 @@
|
|
|
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('platform-matter OpenAPI -> Matter mapping', () => {
|
|
7
|
-
it('maps light OpenAPI status (on/off, brightness, color, battery) to accessory instance helpers', async () => {
|
|
8
|
-
const api: any = makeApiStub()
|
|
9
|
-
const log = makeLogStub()
|
|
10
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
11
|
-
|
|
12
|
-
const deviceId = 'LIGHT-1'
|
|
13
|
-
const nid = (platform as any).normalizeDeviceId(deviceId)
|
|
14
|
-
|
|
15
|
-
const instance = {
|
|
16
|
-
updateOnOffState: vi.fn(),
|
|
17
|
-
updateBrightness: vi.fn(),
|
|
18
|
-
updateHueSaturation: vi.fn(),
|
|
19
|
-
updateBatteryPercentage: vi.fn(),
|
|
20
|
-
}
|
|
21
|
-
;(platform as any).accessoryInstances.set(nid, instance)
|
|
22
|
-
|
|
23
|
-
const status = { power: true, brightness: 80, color: '255:128:64', battery: 92 }
|
|
24
|
-
await (platform as any).applyStatusToAccessory('uuid-light', { deviceId } as any, status)
|
|
25
|
-
|
|
26
|
-
expect(instance.updateOnOffState).toHaveBeenCalled()
|
|
27
|
-
expect(instance.updateBrightness).toHaveBeenCalled()
|
|
28
|
-
expect(instance.updateHueSaturation).toHaveBeenCalled()
|
|
29
|
-
expect(instance.updateBatteryPercentage).toHaveBeenCalled()
|
|
30
|
-
})
|
|
31
|
-
|
|
32
|
-
it('maps MeterPro OpenAPI status (temp, humid, co2, pm25, voc) to accessory instance helpers', async () => {
|
|
33
|
-
const api: any = makeApiStub()
|
|
34
|
-
const log = makeLogStub()
|
|
35
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
36
|
-
|
|
37
|
-
const deviceId = 'METERPRO-1'
|
|
38
|
-
const nid = (platform as any).normalizeDeviceId(deviceId)
|
|
39
|
-
|
|
40
|
-
const instance = {
|
|
41
|
-
updateTemperature: vi.fn(),
|
|
42
|
-
updateHumidity: vi.fn(),
|
|
43
|
-
updateCO2: vi.fn(),
|
|
44
|
-
updatePM25: vi.fn(),
|
|
45
|
-
updateVOC: vi.fn(),
|
|
46
|
-
}
|
|
47
|
-
;(platform as any).accessoryInstances.set(nid, instance)
|
|
48
|
-
|
|
49
|
-
const status = { temp: 21.4, humid: 45, co2: 410, pm25: 12, voc: 85 }
|
|
50
|
-
await (platform as any).applyStatusToAccessory('uuid-meter', { deviceId } as any, status)
|
|
51
|
-
|
|
52
|
-
expect(instance.updateTemperature).toHaveBeenCalled()
|
|
53
|
-
expect(instance.updateHumidity).toHaveBeenCalled()
|
|
54
|
-
expect(instance.updateCO2).toHaveBeenCalled()
|
|
55
|
-
expect(instance.updatePM25).toHaveBeenCalled()
|
|
56
|
-
expect(instance.updateVOC).toHaveBeenCalled()
|
|
57
|
-
})
|
|
58
|
-
|
|
59
|
-
it('maps lock OpenAPI status to lock helper', async () => {
|
|
60
|
-
const api: any = makeApiStub()
|
|
61
|
-
const log = makeLogStub()
|
|
62
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
63
|
-
|
|
64
|
-
const deviceId = 'LOCK-1'
|
|
65
|
-
const nid = (platform as any).normalizeDeviceId(deviceId)
|
|
66
|
-
|
|
67
|
-
const instance = { updateLockState: vi.fn() }
|
|
68
|
-
;(platform as any).accessoryInstances.set(nid, instance)
|
|
69
|
-
|
|
70
|
-
const status = { lock: true }
|
|
71
|
-
await (platform as any).applyStatusToAccessory('uuid-lock', { deviceId } as any, status)
|
|
72
|
-
|
|
73
|
-
expect(instance.updateLockState).toHaveBeenCalled()
|
|
74
|
-
})
|
|
75
|
-
|
|
76
|
-
it('maps curtain position synonyms to lift position helper', async () => {
|
|
77
|
-
const api: any = makeApiStub()
|
|
78
|
-
const log = makeLogStub()
|
|
79
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
80
|
-
|
|
81
|
-
const deviceId = 'CURTAIN-1'
|
|
82
|
-
const nid = (platform as any).normalizeDeviceId(deviceId)
|
|
83
|
-
|
|
84
|
-
const instance = { updateLiftPosition: vi.fn() }
|
|
85
|
-
;(platform as any).accessoryInstances.set(nid, instance)
|
|
86
|
-
|
|
87
|
-
await (platform as any).applyStatusToAccessory('uuid-cur', { deviceId, deviceType: 'Curtain' } as any, { position: 25 })
|
|
88
|
-
await (platform as any).applyStatusToAccessory('uuid-cur', { deviceId, deviceType: 'Curtain' } as any, { slidePosition: 75 })
|
|
89
|
-
|
|
90
|
-
expect(instance.updateLiftPosition).toHaveBeenCalled()
|
|
91
|
-
})
|
|
92
|
-
|
|
93
|
-
it('maps robot vacuum run state / on to updateRunMode or updateOperationalState', async () => {
|
|
94
|
-
const api: any = makeApiStub()
|
|
95
|
-
const log = makeLogStub()
|
|
96
|
-
const platform = new SwitchBotMatterPlatform(log as any, {} as any, api)
|
|
97
|
-
|
|
98
|
-
const deviceId = 'RVC-1'
|
|
99
|
-
const nid = (platform as any).normalizeDeviceId(deviceId)
|
|
100
|
-
|
|
101
|
-
const instance: any = { updateRunMode: vi.fn(), updateOperationalState: vi.fn() }
|
|
102
|
-
;(platform as any).accessoryInstances.set(nid, instance)
|
|
103
|
-
|
|
104
|
-
await (platform as any).applyStatusToAccessory('uuid-rvc', { deviceId, deviceType: 'K10+' } as any, { runState: 'cleaning', power: true })
|
|
105
|
-
|
|
106
|
-
const calls = (instance.updateRunMode.mock?.calls?.length || 0) + (instance.updateOperationalState.mock?.calls?.length || 0)
|
|
107
|
-
expect(calls).toBeGreaterThan(0)
|
|
108
|
-
})
|
|
109
|
-
})
|
|
@@ -1,144 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it, vi } from 'vitest'
|
|
2
|
-
|
|
3
|
-
import { SwitchBotMatterPlatform } from '../../platform-matter.js'
|
|
4
|
-
import { PLATFORM_NAME, PLUGIN_NAME } from '../../settings.js'
|
|
5
|
-
import { makeApiStub, makeLogStub } from '../helpers/platform-fixtures.js'
|
|
6
|
-
|
|
7
|
-
describe('platform-matter discovered devices', () => {
|
|
8
|
-
it('uses discovered devices and registers them (platform + robotic)', async () => {
|
|
9
|
-
const mockRegister = vi.fn()
|
|
10
|
-
const api: any = makeApiStub({
|
|
11
|
-
registerPlatformAccessories: mockRegister,
|
|
12
|
-
clusterNames: { OnOff: 'OnOff', LevelControl: 'LevelControl', ColorControl: 'ColorControl' },
|
|
13
|
-
deviceTypes: { RoboticVacuumCleaner: 'rvc' },
|
|
14
|
-
})
|
|
15
|
-
|
|
16
|
-
const log: any = makeLogStub()
|
|
17
|
-
|
|
18
|
-
const config: any = {}
|
|
19
|
-
|
|
20
|
-
const platform = new SwitchBotMatterPlatform(log, config, api)
|
|
21
|
-
|
|
22
|
-
// Provide discovered devices
|
|
23
|
-
;(platform as any).discoveredDevices = [
|
|
24
|
-
{ deviceId: 'dev1', deviceName: 'Lamp', deviceType: 'Plug' },
|
|
25
|
-
{ deviceId: 'vac1', deviceName: 'Vac', deviceType: 'K10+' },
|
|
26
|
-
] as any
|
|
27
|
-
|
|
28
|
-
// Stub accessory creation to avoid instantiating full device classes
|
|
29
|
-
;(platform as any).createAccessoryFromDevice = async (dev: any) => ({ displayName: dev.deviceName, uuid: api.matter.uuid.generate(dev.deviceId) } as any)
|
|
30
|
-
|
|
31
|
-
await (platform as any).registerMatterAccessories()
|
|
32
|
-
|
|
33
|
-
// Ensure registerPlatformAccessories was called at least once
|
|
34
|
-
expect(mockRegister).toHaveBeenCalled()
|
|
35
|
-
|
|
36
|
-
// Sum total accessories registered across all calls
|
|
37
|
-
const totalRegistered = mockRegister.mock.calls.reduce((sum: number, call: any) => sum + ((call[2] && call[2].length) || 0), 0)
|
|
38
|
-
expect(totalRegistered).toBe(2)
|
|
39
|
-
|
|
40
|
-
// Verify PLUGIN_NAME and PLATFORM_NAME were used in the calls
|
|
41
|
-
for (const call of mockRegister.mock.calls) {
|
|
42
|
-
expect(call[0]).toBe(PLUGIN_NAME)
|
|
43
|
-
expect(call[1]).toBe(PLATFORM_NAME)
|
|
44
|
-
}
|
|
45
|
-
})
|
|
46
|
-
|
|
47
|
-
it('applies per-device config overrides when deviceId matches discovered device', async () => {
|
|
48
|
-
const mockRegister = vi.fn()
|
|
49
|
-
|
|
50
|
-
const api: any = {
|
|
51
|
-
matter: {
|
|
52
|
-
uuid: { generate: (s: string) => `uuid-${s}` },
|
|
53
|
-
registerPlatformAccessories: mockRegister,
|
|
54
|
-
clusterNames: { OnOff: 'OnOff', LevelControl: 'LevelControl', ColorControl: 'ColorControl' },
|
|
55
|
-
deviceTypes: { RoboticVacuumCleaner: 'rvc' },
|
|
56
|
-
},
|
|
57
|
-
isMatterAvailable: () => true,
|
|
58
|
-
isMatterEnabled: () => true,
|
|
59
|
-
on: () => {},
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
const log: any = { info: vi.fn(), warn: vi.fn(), debug: vi.fn(), error: vi.fn() }
|
|
63
|
-
|
|
64
|
-
const config: any = {
|
|
65
|
-
options: {
|
|
66
|
-
devices: [{ deviceId: 'dev1', configDeviceName: 'Configured Lamp', logging: 'debug' }],
|
|
67
|
-
},
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
const platform = new SwitchBotMatterPlatform(log, config, api)
|
|
71
|
-
|
|
72
|
-
;(platform as any).discoveredDevices = [{ deviceId: 'dev1', deviceName: 'Lamp', deviceType: 'Plug' }] as any
|
|
73
|
-
|
|
74
|
-
const seen: any[] = []
|
|
75
|
-
;(platform as any).createAccessoryFromDevice = async (dev: any) => {
|
|
76
|
-
seen.push(dev)
|
|
77
|
-
return {
|
|
78
|
-
displayName: dev.deviceName ?? dev.configDeviceName,
|
|
79
|
-
uuid: api.matter.uuid.generate(dev.deviceId),
|
|
80
|
-
} as any
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
await (platform as any).registerMatterAccessories()
|
|
84
|
-
|
|
85
|
-
// createAccessoryFromDevice should have been called once with merged config
|
|
86
|
-
expect(seen.length).toBe(1)
|
|
87
|
-
expect(seen[0].deviceId).toBe('dev1')
|
|
88
|
-
// per-device config values should be present on the merged device
|
|
89
|
-
expect(seen[0].configDeviceName).toBe('Configured Lamp')
|
|
90
|
-
expect(seen[0].logging).toBe('debug')
|
|
91
|
-
})
|
|
92
|
-
|
|
93
|
-
it('ignores config-only devices by default but includes them when allowConfigOnlyDevices=true', async () => {
|
|
94
|
-
const mockRegister = vi.fn()
|
|
95
|
-
|
|
96
|
-
const api: any = {
|
|
97
|
-
matter: {
|
|
98
|
-
uuid: { generate: (s: string) => `uuid-${s}` },
|
|
99
|
-
registerPlatformAccessories: mockRegister,
|
|
100
|
-
clusterNames: { OnOff: 'OnOff', LevelControl: 'LevelControl', ColorControl: 'ColorControl' },
|
|
101
|
-
deviceTypes: { RoboticVacuumCleaner: 'rvc' },
|
|
102
|
-
},
|
|
103
|
-
isMatterAvailable: () => true,
|
|
104
|
-
isMatterEnabled: () => true,
|
|
105
|
-
on: () => {},
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
const log: any = { info: vi.fn(), warn: vi.fn(), debug: vi.fn(), error: vi.fn() }
|
|
109
|
-
|
|
110
|
-
// config-only device (cfg1) and one discovered device (dev1)
|
|
111
|
-
const cfgOnly = { deviceId: 'cfg1', configDeviceName: 'OnlyInConfig', deviceType: 'Plug' }
|
|
112
|
-
const configDefault: any = { options: { devices: [cfgOnly] } }
|
|
113
|
-
|
|
114
|
-
const platformDefault = new SwitchBotMatterPlatform(log, configDefault, api)
|
|
115
|
-
;(platformDefault as any).discoveredDevices = [{ deviceId: 'dev1', deviceName: 'Lamp', deviceType: 'Plug' }] as any
|
|
116
|
-
const seenDefault: any[] = []
|
|
117
|
-
;(platformDefault as any).createAccessoryFromDevice = async (dev: any) => {
|
|
118
|
-
seenDefault.push(dev)
|
|
119
|
-
return {
|
|
120
|
-
displayName: dev.deviceName ?? dev.configDeviceName,
|
|
121
|
-
uuid: api.matter.uuid.generate(dev.deviceId),
|
|
122
|
-
} as any
|
|
123
|
-
}
|
|
124
|
-
await (platformDefault as any).registerMatterAccessories()
|
|
125
|
-
// Should only see discovered device (cfg1 ignored)
|
|
126
|
-
expect(seenDefault.find((d: any) => d.deviceId === 'cfg1')).toBeUndefined()
|
|
127
|
-
|
|
128
|
-
// Now opt-in to include config-only devices
|
|
129
|
-
const configOptIn: any = { options: { devices: [cfgOnly], allowConfigOnlyDevices: true } }
|
|
130
|
-
const platformOptIn = new SwitchBotMatterPlatform(log, configOptIn, api)
|
|
131
|
-
;(platformOptIn as any).discoveredDevices = [{ deviceId: 'dev1', deviceName: 'Lamp', deviceType: 'Plug' }] as any
|
|
132
|
-
const seenOptIn: any[] = []
|
|
133
|
-
;(platformOptIn as any).createAccessoryFromDevice = async (dev: any) => {
|
|
134
|
-
seenOptIn.push(dev)
|
|
135
|
-
return {
|
|
136
|
-
displayName: dev.deviceName ?? dev.configDeviceName,
|
|
137
|
-
uuid: api.matter.uuid.generate(dev.deviceId),
|
|
138
|
-
} as any
|
|
139
|
-
}
|
|
140
|
-
await (platformOptIn as any).registerMatterAccessories()
|
|
141
|
-
// Should include the config-only device now
|
|
142
|
-
expect(seenOptIn.find((d: any) => d.deviceId === 'cfg1')).toBeDefined()
|
|
143
|
-
})
|
|
144
|
-
})
|
|
@@ -1,39 +0,0 @@
|
|
|
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
|
-
})
|
|
@@ -1,54 +0,0 @@
|
|
|
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
|
-
})
|
package/src/test/utils.test.ts
DELETED
|
@@ -1,96 +0,0 @@
|
|
|
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
|
-
})
|