mirror of
https://github.com/home-assistant/core.git
synced 2025-07-20 03:37:07 +00:00
Add hub3 support for switchbot integration (#145371)
add support for hub3
This commit is contained in:
parent
5e25bbba2d
commit
08c453581c
@ -79,6 +79,7 @@ PLATFORMS_BY_TYPE = {
|
||||
SupportedModels.K10_VACUUM.value: [Platform.VACUUM, Platform.SENSOR],
|
||||
SupportedModels.K10_PRO_VACUUM.value: [Platform.VACUUM, Platform.SENSOR],
|
||||
SupportedModels.K10_PRO_COMBO_VACUUM.value: [Platform.VACUUM, Platform.SENSOR],
|
||||
SupportedModels.HUB3.value: [Platform.SENSOR, Platform.BINARY_SENSOR],
|
||||
}
|
||||
CLASS_BY_DEVICE = {
|
||||
SupportedModels.CEILING_LIGHT.value: switchbot.SwitchbotCeilingLight,
|
||||
|
@ -43,6 +43,7 @@ class SupportedModels(StrEnum):
|
||||
K10_VACUUM = "k10_vacuum"
|
||||
K10_PRO_VACUUM = "k10_pro_vacuum"
|
||||
K10_PRO_COMBO_VACUUM = "k10_pro_combo_vacumm"
|
||||
HUB3 = "hub3"
|
||||
|
||||
|
||||
CONNECTABLE_SUPPORTED_MODEL_TYPES = {
|
||||
@ -78,6 +79,7 @@ NON_CONNECTABLE_SUPPORTED_MODEL_TYPES = {
|
||||
SwitchbotModel.LEAK: SupportedModels.LEAK,
|
||||
SwitchbotModel.REMOTE: SupportedModels.REMOTE,
|
||||
SwitchbotModel.HUBMINI_MATTER: SupportedModels.HUBMINI_MATTER,
|
||||
SwitchbotModel.HUB3: SupportedModels.HUB3,
|
||||
}
|
||||
|
||||
SUPPORTED_MODEL_TYPES = (
|
||||
|
@ -688,3 +688,30 @@ S10_VACUUM_SERVICE_INFO = BluetoothServiceInfoBleak(
|
||||
connectable=True,
|
||||
tx_power=-127,
|
||||
)
|
||||
|
||||
|
||||
HUB3_SERVICE_INFO = BluetoothServiceInfoBleak(
|
||||
name="Hub3",
|
||||
manufacturer_data={
|
||||
2409: b"\xb0\xe9\xfen^)\x00\xffh&\xd6d\x83\x03\x994\x80",
|
||||
},
|
||||
service_data={"0000fd3d-0000-1000-8000-00805f9b34fb": b"\x00\x00d\x00\x10\xb9@"},
|
||||
service_uuids=["cba20d00-224d-11e6-9fb8-0002a5d5c51b"],
|
||||
address="AA:BB:CC:DD:EE:FF",
|
||||
rssi=-60,
|
||||
source="local",
|
||||
advertisement=generate_advertisement_data(
|
||||
local_name="Hub3",
|
||||
manufacturer_data={
|
||||
2409: b"\xb0\xe9\xfen^)\x00\xffh&\xd6d\x83\x03\x994\x80",
|
||||
},
|
||||
service_data={
|
||||
"0000fd3d-0000-1000-8000-00805f9b34fb": b"\x00\x00d\x00\x10\xb9@"
|
||||
},
|
||||
service_uuids=["cba20d00-224d-11e6-9fb8-0002a5d5c51b"],
|
||||
),
|
||||
device=generate_ble_device("AA:BB:CC:DD:EE:FF", "Hub3"),
|
||||
time=0,
|
||||
connectable=True,
|
||||
tx_power=-127,
|
||||
)
|
||||
|
@ -23,6 +23,7 @@ from homeassistant.setup import async_setup_component
|
||||
|
||||
from . import (
|
||||
CIRCULATOR_FAN_SERVICE_INFO,
|
||||
HUB3_SERVICE_INFO,
|
||||
HUBMINI_MATTER_SERVICE_INFO,
|
||||
LEAK_SERVICE_INFO,
|
||||
REMOTE_SERVICE_INFO,
|
||||
@ -385,3 +386,63 @@ async def test_fan_sensors(hass: HomeAssistant) -> None:
|
||||
|
||||
assert await hass.config_entries.async_unload(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
|
||||
|
||||
@pytest.mark.usefixtures("entity_registry_enabled_by_default")
|
||||
async def test_hub3_sensor(hass: HomeAssistant) -> None:
|
||||
"""Test setting up creates the sensor for Hub3."""
|
||||
await async_setup_component(hass, DOMAIN, {})
|
||||
inject_bluetooth_service_info(hass, HUB3_SERVICE_INFO)
|
||||
|
||||
entry = MockConfigEntry(
|
||||
domain=DOMAIN,
|
||||
data={
|
||||
CONF_ADDRESS: "AA:BB:CC:DD:EE:FF",
|
||||
CONF_NAME: "test-name",
|
||||
CONF_SENSOR_TYPE: "hub3",
|
||||
},
|
||||
unique_id="aabbccddeeff",
|
||||
)
|
||||
entry.add_to_hass(hass)
|
||||
|
||||
assert await hass.config_entries.async_setup(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
|
||||
assert len(hass.states.async_all("sensor")) == 5
|
||||
|
||||
temperature_sensor = hass.states.get("sensor.test_name_temperature")
|
||||
temperature_sensor_attrs = temperature_sensor.attributes
|
||||
assert temperature_sensor.state == "25.3"
|
||||
assert temperature_sensor_attrs[ATTR_FRIENDLY_NAME] == "test-name Temperature"
|
||||
assert temperature_sensor_attrs[ATTR_UNIT_OF_MEASUREMENT] == "°C"
|
||||
assert temperature_sensor_attrs[ATTR_STATE_CLASS] == "measurement"
|
||||
|
||||
humidity_sensor = hass.states.get("sensor.test_name_humidity")
|
||||
humidity_sensor_attrs = humidity_sensor.attributes
|
||||
assert humidity_sensor.state == "52"
|
||||
assert humidity_sensor_attrs[ATTR_FRIENDLY_NAME] == "test-name Humidity"
|
||||
assert humidity_sensor_attrs[ATTR_UNIT_OF_MEASUREMENT] == "%"
|
||||
assert humidity_sensor_attrs[ATTR_STATE_CLASS] == "measurement"
|
||||
|
||||
rssi_sensor = hass.states.get("sensor.test_name_bluetooth_signal")
|
||||
rssi_sensor_attrs = rssi_sensor.attributes
|
||||
assert rssi_sensor.state == "-60"
|
||||
assert rssi_sensor_attrs[ATTR_FRIENDLY_NAME] == "test-name Bluetooth signal"
|
||||
assert rssi_sensor_attrs[ATTR_UNIT_OF_MEASUREMENT] == "dBm"
|
||||
|
||||
light_level_sensor = hass.states.get("sensor.test_name_light_level")
|
||||
light_level_sensor_attrs = light_level_sensor.attributes
|
||||
assert light_level_sensor.state == "3"
|
||||
assert light_level_sensor_attrs[ATTR_FRIENDLY_NAME] == "test-name Light level"
|
||||
assert light_level_sensor_attrs[ATTR_UNIT_OF_MEASUREMENT] == "Level"
|
||||
assert light_level_sensor_attrs[ATTR_STATE_CLASS] == "measurement"
|
||||
|
||||
illuminance_sensor = hass.states.get("sensor.test_name_illuminance")
|
||||
illuminance_sensor_attrs = illuminance_sensor.attributes
|
||||
assert illuminance_sensor.state == "90"
|
||||
assert illuminance_sensor_attrs[ATTR_FRIENDLY_NAME] == "test-name Illuminance"
|
||||
assert illuminance_sensor_attrs[ATTR_UNIT_OF_MEASUREMENT] == "lx"
|
||||
assert illuminance_sensor_attrs[ATTR_STATE_CLASS] == "measurement"
|
||||
|
||||
assert await hass.config_entries.async_unload(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
|
Loading…
x
Reference in New Issue
Block a user