@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.
Files changed (534) hide show
  1. package/.github/ISSUE_TEMPLATE/e2e-verification.md +36 -0
  2. package/.github/workflows/ci.yml +61 -0
  3. package/.github/workflows/manual-e2e.yml +103 -0
  4. package/CHANGELOG.md +20 -0
  5. package/E2E-VERIFICATION.md +121 -0
  6. package/MIGRATION.md +44 -0
  7. package/README.md +11 -0
  8. package/config.schema.json +99 -1940
  9. package/dist/deviceFactory.d.ts +13 -0
  10. package/dist/deviceFactory.d.ts.map +1 -0
  11. package/dist/deviceFactory.js +81 -0
  12. package/dist/deviceFactory.js.map +1 -0
  13. package/dist/devices/deviceBase.d.ts +50 -0
  14. package/dist/devices/deviceBase.d.ts.map +1 -0
  15. package/dist/devices/deviceBase.js +119 -0
  16. package/dist/devices/deviceBase.js.map +1 -0
  17. package/dist/devices/genericDevice.d.ts +283 -0
  18. package/dist/devices/genericDevice.d.ts.map +1 -0
  19. package/dist/devices/genericDevice.js +1035 -0
  20. package/dist/devices/genericDevice.js.map +1 -0
  21. package/dist/homebridge-ui/public/index.html +72 -440
  22. package/dist/homebridge-ui/server.d.ts +3 -1
  23. package/dist/homebridge-ui/server.d.ts.map +1 -1
  24. package/dist/homebridge-ui/server.js +47 -10
  25. package/dist/homebridge-ui/server.js.map +1 -1
  26. package/dist/index.d.ts.map +1 -1
  27. package/dist/index.js +1 -3
  28. package/dist/index.js.map +1 -1
  29. package/dist/platform.d.ts +27 -0
  30. package/dist/platform.d.ts.map +1 -0
  31. package/dist/platform.js +404 -0
  32. package/dist/platform.js.map +1 -0
  33. package/dist/settings.d.ts +10 -317
  34. package/dist/settings.d.ts.map +1 -1
  35. package/dist/settings.js +5 -30
  36. package/dist/settings.js.map +1 -1
  37. package/dist/switchbotClient.d.ts +32 -0
  38. package/dist/switchbotClient.d.ts.map +1 -0
  39. package/dist/switchbotClient.js +259 -0
  40. package/dist/switchbotClient.js.map +1 -0
  41. package/dist/utils.d.ts +36 -248
  42. package/dist/utils.d.ts.map +1 -1
  43. package/dist/utils.js +38 -1367
  44. package/dist/utils.js.map +1 -1
  45. package/docs/assets/icons.js +1 -1
  46. package/docs/assets/icons.svg +1 -1
  47. package/docs/assets/style.css +3 -3
  48. package/docs/index.html +50 -15
  49. package/docs/variables/default.html +1 -1
  50. package/package.json +19 -18
  51. package/scripts/e2e/README.md +25 -0
  52. package/scripts/e2e/curtain-e2e.sh +70 -0
  53. package/scripts/e2e/fan-e2e.sh +75 -0
  54. package/scripts/e2e/light-advanced-e2e.sh +97 -0
  55. package/scripts/e2e/light-e2e.sh +75 -0
  56. package/scripts/e2e/list-accessories.sh +19 -0
  57. package/scripts/e2e/lock-e2e.sh +65 -0
  58. package/scripts/generate-matter-maps.js +60 -0
  59. package/scripts/run-e2e-local.sh +14 -0
  60. package/src/deviceFactory.ts +122 -0
  61. package/src/devices/deviceBase.ts +141 -0
  62. package/src/devices/genericDevice.ts +965 -0
  63. package/src/homebridge-ui/public/index.html +72 -440
  64. package/src/homebridge-ui/server.ts +52 -10
  65. package/src/index.ts +1 -3
  66. package/src/platform.ts +395 -0
  67. package/src/settings.ts +12 -352
  68. package/src/switchbotClient.ts +266 -0
  69. package/src/utils.ts +47 -1456
  70. package/test/accessory-restore.spec.ts +73 -0
  71. package/test/device-mapping.spec.ts +37 -0
  72. package/test/deviceFactory.spec.ts +18 -0
  73. package/test/e2e/run-e2e.spec.ts +50 -0
  74. package/test/fan-swing.spec.ts +29 -0
  75. package/test/helpers/matter-harness.ts +53 -0
  76. package/test/lock-users.spec.ts +44 -0
  77. package/test/matter-childbridge.spec.ts +55 -0
  78. package/test/matter-descriptors.spec.ts +97 -0
  79. package/test/matter-device-state.spec.ts +101 -0
  80. package/test/matter-integration.spec.ts +70 -0
  81. package/test/platform.integration.spec.ts +55 -0
  82. package/test/switchbot-client-debounce.spec.ts +131 -0
  83. package/test/switchbot-client-openapi.spec.ts +56 -0
  84. package/test/switchbotClient.spec.ts +10 -0
  85. package/test/utils.spec.ts +20 -0
  86. package/vitest.config.ts +7 -0
  87. package/coverage/base.css +0 -224
  88. package/coverage/block-navigation.js +0 -87
  89. package/coverage/clover.xml +0 -15847
  90. package/coverage/coverage-final.json +0 -42
  91. package/coverage/docs/assets/dmt/dmt-component-data.js.html +0 -85
  92. package/coverage/docs/assets/dmt/dmt-components.js.html +0 -286
  93. package/coverage/docs/assets/dmt/index.html +0 -131
  94. package/coverage/docs/assets/hierarchy.js.html +0 -85
  95. package/coverage/docs/assets/icons.js.html +0 -136
  96. package/coverage/docs/assets/index.html +0 -146
  97. package/coverage/docs/assets/main.js.html +0 -265
  98. package/coverage/favicon.png +0 -0
  99. package/coverage/index.html +0 -191
  100. package/coverage/prettify.css +0 -1
  101. package/coverage/prettify.js +0 -2
  102. package/coverage/sort-arrow-sprite.png +0 -0
  103. package/coverage/sorter.js +0 -196
  104. package/coverage/src/device/blindtilt.ts.html +0 -3238
  105. package/coverage/src/device/bot.ts.html +0 -2803
  106. package/coverage/src/device/ceilinglight.ts.html +0 -2338
  107. package/coverage/src/device/colorbulb.ts.html +0 -2824
  108. package/coverage/src/device/contact.ts.html +0 -1465
  109. package/coverage/src/device/curtain.ts.html +0 -2869
  110. package/coverage/src/device/device.ts.html +0 -2500
  111. package/coverage/src/device/fan.ts.html +0 -2242
  112. package/coverage/src/device/hub.ts.html +0 -1408
  113. package/coverage/src/device/humidifier.ts.html +0 -2116
  114. package/coverage/src/device/index.html +0 -416
  115. package/coverage/src/device/iosensor.ts.html +0 -1375
  116. package/coverage/src/device/lightstrip.ts.html +0 -2617
  117. package/coverage/src/device/lock.ts.html +0 -1963
  118. package/coverage/src/device/meter.ts.html +0 -1372
  119. package/coverage/src/device/meterplus.ts.html +0 -1384
  120. package/coverage/src/device/meterpro.ts.html +0 -1618
  121. package/coverage/src/device/motion.ts.html +0 -1264
  122. package/coverage/src/device/plug.ts.html +0 -1372
  123. package/coverage/src/device/relayswitch.ts.html +0 -2284
  124. package/coverage/src/device/robotvacuumcleaner.ts.html +0 -1810
  125. package/coverage/src/device/waterdetector.ts.html +0 -1294
  126. package/coverage/src/homebridge-ui/index.html +0 -116
  127. package/coverage/src/homebridge-ui/server.ts.html +0 -229
  128. package/coverage/src/index.html +0 -161
  129. package/coverage/src/index.ts.html +0 -124
  130. package/coverage/src/irdevice/airconditioner.ts.html +0 -1687
  131. package/coverage/src/irdevice/airpurifier.ts.html +0 -844
  132. package/coverage/src/irdevice/camera.ts.html +0 -475
  133. package/coverage/src/irdevice/fan.ts.html +0 -766
  134. package/coverage/src/irdevice/index.html +0 -251
  135. package/coverage/src/irdevice/irdevice.ts.html +0 -1117
  136. package/coverage/src/irdevice/light.ts.html +0 -826
  137. package/coverage/src/irdevice/other.ts.html +0 -2458
  138. package/coverage/src/irdevice/tv.ts.html +0 -1222
  139. package/coverage/src/irdevice/vacuumcleaner.ts.html +0 -466
  140. package/coverage/src/irdevice/waterheater.ts.html +0 -469
  141. package/coverage/src/platform.ts.html +0 -8776
  142. package/coverage/src/settings.ts.html +0 -934
  143. package/coverage/src/utils.ts.html +0 -2092
  144. package/dist/devices-hap/airpurifier.d.ts +0 -54
  145. package/dist/devices-hap/airpurifier.d.ts.map +0 -1
  146. package/dist/devices-hap/airpurifier.js +0 -533
  147. package/dist/devices-hap/airpurifier.js.map +0 -1
  148. package/dist/devices-hap/blindtilt.d.ts +0 -90
  149. package/dist/devices-hap/blindtilt.d.ts.map +0 -1
  150. package/dist/devices-hap/blindtilt.js +0 -974
  151. package/dist/devices-hap/blindtilt.js.map +0 -1
  152. package/dist/devices-hap/bot.d.ts +0 -102
  153. package/dist/devices-hap/bot.d.ts.map +0 -1
  154. package/dist/devices-hap/bot.js +0 -822
  155. package/dist/devices-hap/bot.js.map +0 -1
  156. package/dist/devices-hap/ceilinglight.d.ts +0 -85
  157. package/dist/devices-hap/ceilinglight.d.ts.map +0 -1
  158. package/dist/devices-hap/ceilinglight.js +0 -707
  159. package/dist/devices-hap/ceilinglight.js.map +0 -1
  160. package/dist/devices-hap/colorbulb.d.ts +0 -88
  161. package/dist/devices-hap/colorbulb.d.ts.map +0 -1
  162. package/dist/devices-hap/colorbulb.js +0 -921
  163. package/dist/devices-hap/colorbulb.js.map +0 -1
  164. package/dist/devices-hap/contact.d.ts +0 -44
  165. package/dist/devices-hap/contact.d.ts.map +0 -1
  166. package/dist/devices-hap/contact.js +0 -409
  167. package/dist/devices-hap/contact.js.map +0 -1
  168. package/dist/devices-hap/curtain.d.ts +0 -73
  169. package/dist/devices-hap/curtain.d.ts.map +0 -1
  170. package/dist/devices-hap/curtain.js +0 -869
  171. package/dist/devices-hap/curtain.js.map +0 -1
  172. package/dist/devices-hap/device.d.ts +0 -108
  173. package/dist/devices-hap/device.d.ts.map +0 -1
  174. package/dist/devices-hap/device.js +0 -821
  175. package/dist/devices-hap/device.js.map +0 -1
  176. package/dist/devices-hap/fan.d.ts +0 -69
  177. package/dist/devices-hap/fan.d.ts.map +0 -1
  178. package/dist/devices-hap/fan.js +0 -655
  179. package/dist/devices-hap/fan.js.map +0 -1
  180. package/dist/devices-hap/hub.d.ts +0 -37
  181. package/dist/devices-hap/hub.d.ts.map +0 -1
  182. package/dist/devices-hap/hub.js +0 -393
  183. package/dist/devices-hap/hub.js.map +0 -1
  184. package/dist/devices-hap/humidifier.d.ts +0 -73
  185. package/dist/devices-hap/humidifier.d.ts.map +0 -1
  186. package/dist/devices-hap/humidifier.js +0 -716
  187. package/dist/devices-hap/humidifier.js.map +0 -1
  188. package/dist/devices-hap/iosensor.d.ts +0 -42
  189. package/dist/devices-hap/iosensor.d.ts.map +0 -1
  190. package/dist/devices-hap/iosensor.js +0 -397
  191. package/dist/devices-hap/iosensor.js.map +0 -1
  192. package/dist/devices-hap/lightstrip.d.ts +0 -79
  193. package/dist/devices-hap/lightstrip.d.ts.map +0 -1
  194. package/dist/devices-hap/lightstrip.js +0 -827
  195. package/dist/devices-hap/lightstrip.js.map +0 -1
  196. package/dist/devices-hap/lock.d.ts +0 -53
  197. package/dist/devices-hap/lock.d.ts.map +0 -1
  198. package/dist/devices-hap/lock.js +0 -569
  199. package/dist/devices-hap/lock.js.map +0 -1
  200. package/dist/devices-hap/meter.d.ts +0 -37
  201. package/dist/devices-hap/meter.d.ts.map +0 -1
  202. package/dist/devices-hap/meter.js +0 -380
  203. package/dist/devices-hap/meter.js.map +0 -1
  204. package/dist/devices-hap/meterplus.d.ts +0 -42
  205. package/dist/devices-hap/meterplus.d.ts.map +0 -1
  206. package/dist/devices-hap/meterplus.js +0 -385
  207. package/dist/devices-hap/meterplus.js.map +0 -1
  208. package/dist/devices-hap/meterpro.d.ts +0 -43
  209. package/dist/devices-hap/meterpro.d.ts.map +0 -1
  210. package/dist/devices-hap/meterpro.js +0 -469
  211. package/dist/devices-hap/meterpro.js.map +0 -1
  212. package/dist/devices-hap/motion.d.ts +0 -42
  213. package/dist/devices-hap/motion.d.ts.map +0 -1
  214. package/dist/devices-hap/motion.js +0 -345
  215. package/dist/devices-hap/motion.js.map +0 -1
  216. package/dist/devices-hap/plug.d.ts +0 -49
  217. package/dist/devices-hap/plug.d.ts.map +0 -1
  218. package/dist/devices-hap/plug.js +0 -400
  219. package/dist/devices-hap/plug.js.map +0 -1
  220. package/dist/devices-hap/relayswitch.d.ts +0 -96
  221. package/dist/devices-hap/relayswitch.d.ts.map +0 -1
  222. package/dist/devices-hap/relayswitch.js +0 -642
  223. package/dist/devices-hap/relayswitch.js.map +0 -1
  224. package/dist/devices-hap/robotvacuumcleaner.d.ts +0 -54
  225. package/dist/devices-hap/robotvacuumcleaner.d.ts.map +0 -1
  226. package/dist/devices-hap/robotvacuumcleaner.js +0 -530
  227. package/dist/devices-hap/robotvacuumcleaner.js.map +0 -1
  228. package/dist/devices-hap/waterdetector.d.ts +0 -41
  229. package/dist/devices-hap/waterdetector.d.ts.map +0 -1
  230. package/dist/devices-hap/waterdetector.js +0 -356
  231. package/dist/devices-hap/waterdetector.js.map +0 -1
  232. package/dist/devices-matter/BaseMatterAccessory.d.ts +0 -90
  233. package/dist/devices-matter/BaseMatterAccessory.d.ts.map +0 -1
  234. package/dist/devices-matter/BaseMatterAccessory.js +0 -264
  235. package/dist/devices-matter/BaseMatterAccessory.js.map +0 -1
  236. package/dist/devices-matter/ColorLightAccessory.d.ts +0 -20
  237. package/dist/devices-matter/ColorLightAccessory.d.ts.map +0 -1
  238. package/dist/devices-matter/ColorLightAccessory.js +0 -95
  239. package/dist/devices-matter/ColorLightAccessory.js.map +0 -1
  240. package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts +0 -18
  241. package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts.map +0 -1
  242. package/dist/devices-matter/ColorTemperatureLightAccessory.js +0 -76
  243. package/dist/devices-matter/ColorTemperatureLightAccessory.js.map +0 -1
  244. package/dist/devices-matter/ContactSensorAccessory.d.ts +0 -12
  245. package/dist/devices-matter/ContactSensorAccessory.d.ts.map +0 -1
  246. package/dist/devices-matter/ContactSensorAccessory.js +0 -34
  247. package/dist/devices-matter/ContactSensorAccessory.js.map +0 -1
  248. package/dist/devices-matter/DimmableLightAccessory.d.ts +0 -58
  249. package/dist/devices-matter/DimmableLightAccessory.d.ts.map +0 -1
  250. package/dist/devices-matter/DimmableLightAccessory.js +0 -167
  251. package/dist/devices-matter/DimmableLightAccessory.js.map +0 -1
  252. package/dist/devices-matter/DoorLockAccessory.d.ts +0 -14
  253. package/dist/devices-matter/DoorLockAccessory.d.ts.map +0 -1
  254. package/dist/devices-matter/DoorLockAccessory.js +0 -50
  255. package/dist/devices-matter/DoorLockAccessory.js.map +0 -1
  256. package/dist/devices-matter/ExtendedColorLightAccessory.d.ts +0 -21
  257. package/dist/devices-matter/ExtendedColorLightAccessory.d.ts.map +0 -1
  258. package/dist/devices-matter/ExtendedColorLightAccessory.js +0 -106
  259. package/dist/devices-matter/ExtendedColorLightAccessory.js.map +0 -1
  260. package/dist/devices-matter/FanAccessory.d.ts +0 -16
  261. package/dist/devices-matter/FanAccessory.d.ts.map +0 -1
  262. package/dist/devices-matter/FanAccessory.js +0 -81
  263. package/dist/devices-matter/FanAccessory.js.map +0 -1
  264. package/dist/devices-matter/HumiditySensorAccessory.d.ts +0 -12
  265. package/dist/devices-matter/HumiditySensorAccessory.d.ts.map +0 -1
  266. package/dist/devices-matter/HumiditySensorAccessory.js +0 -34
  267. package/dist/devices-matter/HumiditySensorAccessory.js.map +0 -1
  268. package/dist/devices-matter/LeakSensorAccessory.d.ts +0 -12
  269. package/dist/devices-matter/LeakSensorAccessory.d.ts.map +0 -1
  270. package/dist/devices-matter/LeakSensorAccessory.js +0 -33
  271. package/dist/devices-matter/LeakSensorAccessory.js.map +0 -1
  272. package/dist/devices-matter/LightSensorAccessory.d.ts +0 -12
  273. package/dist/devices-matter/LightSensorAccessory.d.ts.map +0 -1
  274. package/dist/devices-matter/LightSensorAccessory.js +0 -34
  275. package/dist/devices-matter/LightSensorAccessory.js.map +0 -1
  276. package/dist/devices-matter/OccupancySensorAccessory.d.ts +0 -12
  277. package/dist/devices-matter/OccupancySensorAccessory.d.ts.map +0 -1
  278. package/dist/devices-matter/OccupancySensorAccessory.js +0 -39
  279. package/dist/devices-matter/OccupancySensorAccessory.js.map +0 -1
  280. package/dist/devices-matter/OnOffLightAccessory.d.ts +0 -38
  281. package/dist/devices-matter/OnOffLightAccessory.d.ts.map +0 -1
  282. package/dist/devices-matter/OnOffLightAccessory.js +0 -110
  283. package/dist/devices-matter/OnOffLightAccessory.js.map +0 -1
  284. package/dist/devices-matter/OnOffOutletAccessory.d.ts +0 -14
  285. package/dist/devices-matter/OnOffOutletAccessory.d.ts.map +0 -1
  286. package/dist/devices-matter/OnOffOutletAccessory.js +0 -43
  287. package/dist/devices-matter/OnOffOutletAccessory.js.map +0 -1
  288. package/dist/devices-matter/OnOffSwitchAccessory.d.ts +0 -14
  289. package/dist/devices-matter/OnOffSwitchAccessory.d.ts.map +0 -1
  290. package/dist/devices-matter/OnOffSwitchAccessory.js +0 -42
  291. package/dist/devices-matter/OnOffSwitchAccessory.js.map +0 -1
  292. package/dist/devices-matter/RoboticVacuumAccessory.d.ts +0 -61
  293. package/dist/devices-matter/RoboticVacuumAccessory.d.ts.map +0 -1
  294. package/dist/devices-matter/RoboticVacuumAccessory.js +0 -544
  295. package/dist/devices-matter/RoboticVacuumAccessory.js.map +0 -1
  296. package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts +0 -11
  297. package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts.map +0 -1
  298. package/dist/devices-matter/SmokeCOAlarmAccessory.js +0 -49
  299. package/dist/devices-matter/SmokeCOAlarmAccessory.js.map +0 -1
  300. package/dist/devices-matter/TemperatureSensorAccessory.d.ts +0 -12
  301. package/dist/devices-matter/TemperatureSensorAccessory.d.ts.map +0 -1
  302. package/dist/devices-matter/TemperatureSensorAccessory.js +0 -36
  303. package/dist/devices-matter/TemperatureSensorAccessory.js.map +0 -1
  304. package/dist/devices-matter/ThermostatAccessory.d.ts +0 -19
  305. package/dist/devices-matter/ThermostatAccessory.d.ts.map +0 -1
  306. package/dist/devices-matter/ThermostatAccessory.js +0 -95
  307. package/dist/devices-matter/ThermostatAccessory.js.map +0 -1
  308. package/dist/devices-matter/VenetianBlindAccessory.d.ts +0 -19
  309. package/dist/devices-matter/VenetianBlindAccessory.d.ts.map +0 -1
  310. package/dist/devices-matter/VenetianBlindAccessory.js +0 -99
  311. package/dist/devices-matter/VenetianBlindAccessory.js.map +0 -1
  312. package/dist/devices-matter/WindowBlindAccessory.d.ts +0 -17
  313. package/dist/devices-matter/WindowBlindAccessory.d.ts.map +0 -1
  314. package/dist/devices-matter/WindowBlindAccessory.js +0 -131
  315. package/dist/devices-matter/WindowBlindAccessory.js.map +0 -1
  316. package/dist/devices-matter/custom/PowerStripAccessory.d.ts +0 -97
  317. package/dist/devices-matter/custom/PowerStripAccessory.d.ts.map +0 -1
  318. package/dist/devices-matter/custom/PowerStripAccessory.js +0 -265
  319. package/dist/devices-matter/custom/PowerStripAccessory.js.map +0 -1
  320. package/dist/devices-matter/custom/index.d.ts +0 -8
  321. package/dist/devices-matter/custom/index.d.ts.map +0 -1
  322. package/dist/devices-matter/custom/index.js +0 -8
  323. package/dist/devices-matter/custom/index.js.map +0 -1
  324. package/dist/devices-matter/index.d.ts +0 -29
  325. package/dist/devices-matter/index.d.ts.map +0 -1
  326. package/dist/devices-matter/index.js +0 -28
  327. package/dist/devices-matter/index.js.map +0 -1
  328. package/dist/irdevice/airconditioner.d.ts +0 -61
  329. package/dist/irdevice/airconditioner.d.ts.map +0 -1
  330. package/dist/irdevice/airconditioner.js +0 -472
  331. package/dist/irdevice/airconditioner.js.map +0 -1
  332. package/dist/irdevice/airpurifier.d.ts +0 -50
  333. package/dist/irdevice/airpurifier.d.ts.map +0 -1
  334. package/dist/irdevice/airpurifier.js +0 -213
  335. package/dist/irdevice/airpurifier.js.map +0 -1
  336. package/dist/irdevice/camera.d.ts +0 -32
  337. package/dist/irdevice/camera.d.ts.map +0 -1
  338. package/dist/irdevice/camera.js +0 -107
  339. package/dist/irdevice/camera.js.map +0 -1
  340. package/dist/irdevice/fan.d.ts +0 -36
  341. package/dist/irdevice/fan.d.ts.map +0 -1
  342. package/dist/irdevice/fan.js +0 -200
  343. package/dist/irdevice/fan.js.map +0 -1
  344. package/dist/irdevice/irdevice.d.ts +0 -69
  345. package/dist/irdevice/irdevice.d.ts.map +0 -1
  346. package/dist/irdevice/irdevice.js +0 -339
  347. package/dist/irdevice/irdevice.js.map +0 -1
  348. package/dist/irdevice/light.d.ts +0 -36
  349. package/dist/irdevice/light.d.ts.map +0 -1
  350. package/dist/irdevice/light.js +0 -206
  351. package/dist/irdevice/light.js.map +0 -1
  352. package/dist/irdevice/other.d.ts +0 -57
  353. package/dist/irdevice/other.d.ts.map +0 -1
  354. package/dist/irdevice/other.js +0 -778
  355. package/dist/irdevice/other.js.map +0 -1
  356. package/dist/irdevice/tv.d.ts +0 -45
  357. package/dist/irdevice/tv.d.ts.map +0 -1
  358. package/dist/irdevice/tv.js +0 -327
  359. package/dist/irdevice/tv.js.map +0 -1
  360. package/dist/irdevice/vacuumcleaner.d.ts +0 -28
  361. package/dist/irdevice/vacuumcleaner.d.ts.map +0 -1
  362. package/dist/irdevice/vacuumcleaner.js +0 -104
  363. package/dist/irdevice/vacuumcleaner.js.map +0 -1
  364. package/dist/irdevice/waterheater.d.ts +0 -30
  365. package/dist/irdevice/waterheater.d.ts.map +0 -1
  366. package/dist/irdevice/waterheater.js +0 -105
  367. package/dist/irdevice/waterheater.js.map +0 -1
  368. package/dist/platform-hap.d.ts +0 -160
  369. package/dist/platform-hap.d.ts.map +0 -1
  370. package/dist/platform-hap.js +0 -3041
  371. package/dist/platform-hap.js.map +0 -1
  372. package/dist/platform-matter.d.ts +0 -188
  373. package/dist/platform-matter.d.ts.map +0 -1
  374. package/dist/platform-matter.js +0 -2545
  375. package/dist/platform-matter.js.map +0 -1
  376. package/dist/test/apiRequestTracker.test.d.ts +0 -2
  377. package/dist/test/apiRequestTracker.test.d.ts.map +0 -1
  378. package/dist/test/apiRequestTracker.test.js +0 -392
  379. package/dist/test/apiRequestTracker.test.js.map +0 -1
  380. package/dist/test/hap/device-webhook-context.test.d.ts +0 -2
  381. package/dist/test/hap/device-webhook-context.test.d.ts.map +0 -1
  382. package/dist/test/hap/device-webhook-context.test.js +0 -128
  383. package/dist/test/hap/device-webhook-context.test.js.map +0 -1
  384. package/dist/test/hap/platform-hap.logging.test.d.ts +0 -2
  385. package/dist/test/hap/platform-hap.logging.test.d.ts.map +0 -1
  386. package/dist/test/hap/platform-hap.logging.test.js +0 -33
  387. package/dist/test/hap/platform-hap.logging.test.js.map +0 -1
  388. package/dist/test/hap/platform-hap.test.d.ts +0 -2
  389. package/dist/test/hap/platform-hap.test.d.ts.map +0 -1
  390. package/dist/test/hap/platform-hap.test.js +0 -62
  391. package/dist/test/hap/platform-hap.test.js.map +0 -1
  392. package/dist/test/helpers/platform-fixtures.d.ts +0 -9
  393. package/dist/test/helpers/platform-fixtures.d.ts.map +0 -1
  394. package/dist/test/helpers/platform-fixtures.js +0 -30
  395. package/dist/test/helpers/platform-fixtures.js.map +0 -1
  396. package/dist/test/homebridge-ui/server.test.d.ts +0 -2
  397. package/dist/test/homebridge-ui/server.test.d.ts.map +0 -1
  398. package/dist/test/homebridge-ui/server.test.js +0 -445
  399. package/dist/test/homebridge-ui/server.test.js.map +0 -1
  400. package/dist/test/index.test.d.ts +0 -2
  401. package/dist/test/index.test.d.ts.map +0 -1
  402. package/dist/test/index.test.js +0 -19
  403. package/dist/test/index.test.js.map +0 -1
  404. package/dist/test/matter/devices-matter/baseMatterAccessory.test.d.ts +0 -2
  405. package/dist/test/matter/devices-matter/baseMatterAccessory.test.d.ts.map +0 -1
  406. package/dist/test/matter/devices-matter/baseMatterAccessory.test.js +0 -71
  407. package/dist/test/matter/devices-matter/baseMatterAccessory.test.js.map +0 -1
  408. package/dist/test/matter/platform-matter.additional.test.d.ts +0 -2
  409. package/dist/test/matter/platform-matter.additional.test.d.ts.map +0 -1
  410. package/dist/test/matter/platform-matter.additional.test.js +0 -35
  411. package/dist/test/matter/platform-matter.additional.test.js.map +0 -1
  412. package/dist/test/matter/platform-matter.bleparse.test.d.ts +0 -2
  413. package/dist/test/matter/platform-matter.bleparse.test.d.ts.map +0 -1
  414. package/dist/test/matter/platform-matter.bleparse.test.js +0 -43
  415. package/dist/test/matter/platform-matter.bleparse.test.js.map +0 -1
  416. package/dist/test/matter/platform-matter.cleanup.test.d.ts +0 -2
  417. package/dist/test/matter/platform-matter.cleanup.test.d.ts.map +0 -1
  418. package/dist/test/matter/platform-matter.cleanup.test.js +0 -70
  419. package/dist/test/matter/platform-matter.cleanup.test.js.map +0 -1
  420. package/dist/test/matter/platform-matter.keepstale.test.d.ts +0 -2
  421. package/dist/test/matter/platform-matter.keepstale.test.d.ts.map +0 -1
  422. package/dist/test/matter/platform-matter.keepstale.test.js +0 -27
  423. package/dist/test/matter/platform-matter.keepstale.test.js.map +0 -1
  424. package/dist/test/matter/platform-matter.logging.test.d.ts +0 -2
  425. package/dist/test/matter/platform-matter.logging.test.d.ts.map +0 -1
  426. package/dist/test/matter/platform-matter.logging.test.js +0 -29
  427. package/dist/test/matter/platform-matter.logging.test.js.map +0 -1
  428. package/dist/test/matter/platform-matter.mapping.test.d.ts +0 -2
  429. package/dist/test/matter/platform-matter.mapping.test.d.ts.map +0 -1
  430. package/dist/test/matter/platform-matter.mapping.test.js +0 -43
  431. package/dist/test/matter/platform-matter.mapping.test.js.map +0 -1
  432. package/dist/test/matter/platform-matter.openapi-mapping.test.d.ts +0 -2
  433. package/dist/test/matter/platform-matter.openapi-mapping.test.d.ts.map +0 -1
  434. package/dist/test/matter/platform-matter.openapi-mapping.test.js +0 -84
  435. package/dist/test/matter/platform-matter.openapi-mapping.test.js.map +0 -1
  436. package/dist/test/matter/platform-matter.test.d.ts +0 -2
  437. package/dist/test/matter/platform-matter.test.d.ts.map +0 -1
  438. package/dist/test/matter/platform-matter.test.js +0 -117
  439. package/dist/test/matter/platform-matter.test.js.map +0 -1
  440. package/dist/test/matter/platform-matter.unregister.test.d.ts +0 -2
  441. package/dist/test/matter/platform-matter.unregister.test.d.ts.map +0 -1
  442. package/dist/test/matter/platform-matter.unregister.test.js +0 -30
  443. package/dist/test/matter/platform-matter.unregister.test.js.map +0 -1
  444. package/dist/test/matter/platform-matter.webhook.test.d.ts +0 -2
  445. package/dist/test/matter/platform-matter.webhook.test.d.ts.map +0 -1
  446. package/dist/test/matter/platform-matter.webhook.test.js +0 -46
  447. package/dist/test/matter/platform-matter.webhook.test.js.map +0 -1
  448. package/dist/test/utils.test.d.ts +0 -2
  449. package/dist/test/utils.test.d.ts.map +0 -1
  450. package/dist/test/utils.test.js +0 -95
  451. package/dist/test/utils.test.js.map +0 -1
  452. package/dist/test/verifyconfig.test.d.ts +0 -2
  453. package/dist/test/verifyconfig.test.d.ts.map +0 -1
  454. package/dist/test/verifyconfig.test.js +0 -167
  455. package/dist/test/verifyconfig.test.js.map +0 -1
  456. package/src/custom.d.ts +0 -7
  457. package/src/devices-hap/airpurifier.ts +0 -568
  458. package/src/devices-hap/blindtilt.ts +0 -1049
  459. package/src/devices-hap/bot.ts +0 -910
  460. package/src/devices-hap/ceilinglight.ts +0 -747
  461. package/src/devices-hap/colorbulb.ts +0 -940
  462. package/src/devices-hap/contact.ts +0 -457
  463. package/src/devices-hap/curtain.ts +0 -944
  464. package/src/devices-hap/device.ts +0 -890
  465. package/src/devices-hap/fan.ts +0 -716
  466. package/src/devices-hap/hub.ts +0 -440
  467. package/src/devices-hap/humidifier.ts +0 -762
  468. package/src/devices-hap/iosensor.ts +0 -442
  469. package/src/devices-hap/lightstrip.ts +0 -863
  470. package/src/devices-hap/lock.ts +0 -627
  471. package/src/devices-hap/meter.ts +0 -427
  472. package/src/devices-hap/meterplus.ts +0 -431
  473. package/src/devices-hap/meterpro.ts +0 -523
  474. package/src/devices-hap/motion.ts +0 -390
  475. package/src/devices-hap/plug.ts +0 -427
  476. package/src/devices-hap/relayswitch.ts +0 -727
  477. package/src/devices-hap/robotvacuumcleaner.ts +0 -574
  478. package/src/devices-hap/waterdetector.ts +0 -400
  479. package/src/devices-matter/BaseMatterAccessory.ts +0 -302
  480. package/src/devices-matter/ColorLightAccessory.ts +0 -110
  481. package/src/devices-matter/ColorTemperatureLightAccessory.ts +0 -90
  482. package/src/devices-matter/ContactSensorAccessory.ts +0 -41
  483. package/src/devices-matter/DimmableLightAccessory.ts +0 -192
  484. package/src/devices-matter/DoorLockAccessory.ts +0 -60
  485. package/src/devices-matter/ExtendedColorLightAccessory.ts +0 -122
  486. package/src/devices-matter/FanAccessory.ts +0 -95
  487. package/src/devices-matter/HumiditySensorAccessory.ts +0 -41
  488. package/src/devices-matter/LeakSensorAccessory.ts +0 -40
  489. package/src/devices-matter/LightSensorAccessory.ts +0 -41
  490. package/src/devices-matter/OccupancySensorAccessory.ts +0 -48
  491. package/src/devices-matter/OnOffLightAccessory.ts +0 -125
  492. package/src/devices-matter/OnOffOutletAccessory.ts +0 -51
  493. package/src/devices-matter/OnOffSwitchAccessory.ts +0 -51
  494. package/src/devices-matter/RoboticVacuumAccessory.ts +0 -621
  495. package/src/devices-matter/SmokeCOAlarmAccessory.ts +0 -59
  496. package/src/devices-matter/TemperatureSensorAccessory.ts +0 -43
  497. package/src/devices-matter/ThermostatAccessory.ts +0 -110
  498. package/src/devices-matter/VenetianBlindAccessory.ts +0 -115
  499. package/src/devices-matter/WindowBlindAccessory.ts +0 -135
  500. package/src/devices-matter/custom/PowerStripAccessory.ts +0 -309
  501. package/src/devices-matter/custom/index.ts +0 -8
  502. package/src/devices-matter/index.ts +0 -29
  503. package/src/irdevice/airconditioner.ts +0 -533
  504. package/src/irdevice/airpurifier.ts +0 -252
  505. package/src/irdevice/camera.ts +0 -129
  506. package/src/irdevice/fan.ts +0 -226
  507. package/src/irdevice/irdevice.ts +0 -383
  508. package/src/irdevice/light.ts +0 -246
  509. package/src/irdevice/other.ts +0 -790
  510. package/src/irdevice/tv.ts +0 -378
  511. package/src/irdevice/vacuumcleaner.ts +0 -126
  512. package/src/irdevice/waterheater.ts +0 -127
  513. package/src/platform-hap.ts +0 -3193
  514. package/src/platform-matter.ts +0 -2703
  515. package/src/test/apiRequestTracker.test.ts +0 -417
  516. package/src/test/hap/device-webhook-context.test.ts +0 -136
  517. package/src/test/hap/platform-hap.logging.test.ts +0 -36
  518. package/src/test/hap/platform-hap.test.ts +0 -70
  519. package/src/test/helpers/platform-fixtures.ts +0 -33
  520. package/src/test/homebridge-ui/server.test.ts +0 -486
  521. package/src/test/index.test.ts +0 -24
  522. package/src/test/matter/devices-matter/baseMatterAccessory.test.ts +0 -88
  523. package/src/test/matter/platform-matter.additional.test.ts +0 -44
  524. package/src/test/matter/platform-matter.bleparse.test.ts +0 -47
  525. package/src/test/matter/platform-matter.cleanup.test.ts +0 -86
  526. package/src/test/matter/platform-matter.keepstale.test.ts +0 -37
  527. package/src/test/matter/platform-matter.logging.test.ts +0 -33
  528. package/src/test/matter/platform-matter.mapping.test.ts +0 -57
  529. package/src/test/matter/platform-matter.openapi-mapping.test.ts +0 -109
  530. package/src/test/matter/platform-matter.test.ts +0 -144
  531. package/src/test/matter/platform-matter.unregister.test.ts +0 -39
  532. package/src/test/matter/platform-matter.webhook.test.ts +0 -54
  533. package/src/test/utils.test.ts +0 -96
  534. 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
- })
@@ -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
- })