mirror of
https://github.com/home-assistant/core.git
synced 2025-06-06 06:07:07 +00:00
Add support for Switchbot Remote (#137443)
This commit is contained in:
parent
830636df07
commit
c9ab75a02d
@ -65,6 +65,7 @@ PLATFORMS_BY_TYPE = {
|
||||
SupportedModels.RELAY_SWITCH_1PM.value: [Platform.SWITCH, Platform.SENSOR],
|
||||
SupportedModels.RELAY_SWITCH_1.value: [Platform.SWITCH],
|
||||
SupportedModels.LEAK.value: [Platform.BINARY_SENSOR, Platform.SENSOR],
|
||||
SupportedModels.REMOTE.value: [Platform.SENSOR],
|
||||
}
|
||||
CLASS_BY_DEVICE = {
|
||||
SupportedModels.CEILING_LIGHT.value: switchbot.SwitchbotCeilingLight,
|
||||
|
@ -34,6 +34,7 @@ class SupportedModels(StrEnum):
|
||||
RELAY_SWITCH_1PM = "relay_switch_1pm"
|
||||
RELAY_SWITCH_1 = "relay_switch_1"
|
||||
LEAK = "leak"
|
||||
REMOTE = "remote"
|
||||
|
||||
|
||||
CONNECTABLE_SUPPORTED_MODEL_TYPES = {
|
||||
@ -60,6 +61,7 @@ NON_CONNECTABLE_SUPPORTED_MODEL_TYPES = {
|
||||
SwitchbotModel.CONTACT_SENSOR: SupportedModels.CONTACT,
|
||||
SwitchbotModel.MOTION_SENSOR: SupportedModels.MOTION,
|
||||
SwitchbotModel.LEAK: SupportedModels.LEAK,
|
||||
SwitchbotModel.REMOTE: SupportedModels.REMOTE,
|
||||
}
|
||||
|
||||
SUPPORTED_MODEL_TYPES = (
|
||||
|
@ -274,3 +274,23 @@ LEAK_SERVICE_INFO = BluetoothServiceInfoBleak(
|
||||
connectable=False,
|
||||
tx_power=-127,
|
||||
)
|
||||
|
||||
REMOTE_SERVICE_INFO = BluetoothServiceInfoBleak(
|
||||
name="Any",
|
||||
manufacturer_data={89: b"\xaa\xbb\xcc\xdd\xee\xff"},
|
||||
service_data={"00000d00-0000-1000-8000-00805f9b34fb": b"b V\x00"},
|
||||
service_uuids=["cba20d00-224d-11e6-9fb8-0002a5d5c51b"],
|
||||
address="AA:BB:CC:DD:EE:FF",
|
||||
rssi=-60,
|
||||
source="local",
|
||||
advertisement=generate_advertisement_data(
|
||||
local_name="Any",
|
||||
manufacturer_data={89: b"\xaa\xbb\xcc\xdd\xee\xff"},
|
||||
service_data={"00000d00-0000-1000-8000-00805f9b34fb": b"b V\x00"},
|
||||
service_uuids=["cba20d00-224d-11e6-9fb8-0002a5d5c51b"],
|
||||
),
|
||||
device=generate_ble_device("AA:BB:CC:DD:EE:FF", "Any"),
|
||||
time=0,
|
||||
connectable=False,
|
||||
tx_power=-127,
|
||||
)
|
||||
|
@ -23,6 +23,7 @@ from homeassistant.setup import async_setup_component
|
||||
|
||||
from . import (
|
||||
LEAK_SERVICE_INFO,
|
||||
REMOTE_SERVICE_INFO,
|
||||
WOHAND_SERVICE_INFO,
|
||||
WOMETERTHPC_SERVICE_INFO,
|
||||
WORELAY_SWITCH_1PM_SERVICE_INFO,
|
||||
@ -194,3 +195,42 @@ async def test_leak_sensor(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_remote(hass: HomeAssistant) -> None:
|
||||
"""Test setting up the remote sensor."""
|
||||
await async_setup_component(hass, DOMAIN, {})
|
||||
inject_bluetooth_service_info(hass, REMOTE_SERVICE_INFO)
|
||||
|
||||
entry = MockConfigEntry(
|
||||
domain=DOMAIN,
|
||||
data={
|
||||
CONF_ADDRESS: "aa:bb:cc:dd:ee:ff",
|
||||
CONF_NAME: "test-name",
|
||||
CONF_SENSOR_TYPE: "remote",
|
||||
},
|
||||
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")) == 2
|
||||
|
||||
battery_sensor = hass.states.get("sensor.test_name_battery")
|
||||
battery_sensor_attrs = battery_sensor.attributes
|
||||
assert battery_sensor.state == "86"
|
||||
assert battery_sensor_attrs[ATTR_FRIENDLY_NAME] == "test-name Battery"
|
||||
assert battery_sensor_attrs[ATTR_UNIT_OF_MEASUREMENT] == "%"
|
||||
assert battery_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"
|
||||
|
||||
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