mirror of
https://github.com/home-assistant/core.git
synced 2025-07-16 01:37:08 +00:00
Add illuminance sensor to SwitchBot integration (#141382)
* Add illuminance sensor to SwitchBot integration * Add WoHub2 sensor tests
This commit is contained in:
parent
0920d7d82d
commit
1772348eef
@ -11,6 +11,7 @@ from homeassistant.components.sensor import (
|
||||
)
|
||||
from homeassistant.const import (
|
||||
CONCENTRATION_PARTS_PER_MILLION,
|
||||
LIGHT_LUX,
|
||||
PERCENTAGE,
|
||||
SIGNAL_STRENGTH_DECIBELS_MILLIWATT,
|
||||
EntityCategory,
|
||||
@ -71,6 +72,12 @@ SENSOR_TYPES: dict[str, SensorEntityDescription] = {
|
||||
state_class=SensorStateClass.MEASUREMENT,
|
||||
device_class=SensorDeviceClass.HUMIDITY,
|
||||
),
|
||||
"illuminance": SensorEntityDescription(
|
||||
key="illuminance",
|
||||
native_unit_of_measurement=LIGHT_LUX,
|
||||
state_class=SensorStateClass.MEASUREMENT,
|
||||
device_class=SensorDeviceClass.ILLUMINANCE,
|
||||
),
|
||||
"temperature": SensorEntityDescription(
|
||||
key="temperature",
|
||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||
|
@ -294,3 +294,28 @@ REMOTE_SERVICE_INFO = BluetoothServiceInfoBleak(
|
||||
connectable=False,
|
||||
tx_power=-127,
|
||||
)
|
||||
|
||||
|
||||
WOHUB2_SERVICE_INFO = BluetoothServiceInfoBleak(
|
||||
name="WoHub2",
|
||||
manufacturer_data={
|
||||
2409: b"\xe7\x06\x1dx\x99y\x00\xffg\xe2\xbf]\x84\x04\x9a,\x00",
|
||||
},
|
||||
service_data={"0000fd3d-0000-1000-8000-00805f9b34fb": 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="WoHub2",
|
||||
manufacturer_data={
|
||||
2409: b"\xe7\x06\x1dx\x99y\x00\xffg\xe2\xbf]\x84\x04\x9a,\x00",
|
||||
},
|
||||
service_data={"0000fd3d-0000-1000-8000-00805f9b34fb": b"v\x00"},
|
||||
service_uuids=["cba20d00-224d-11e6-9fb8-0002a5d5c51b"],
|
||||
),
|
||||
device=generate_ble_device("AA:BB:CC:DD:EE:FF", "WoHub2"),
|
||||
time=0,
|
||||
connectable=True,
|
||||
tx_power=-127,
|
||||
)
|
||||
|
@ -25,6 +25,7 @@ from . import (
|
||||
LEAK_SERVICE_INFO,
|
||||
REMOTE_SERVICE_INFO,
|
||||
WOHAND_SERVICE_INFO,
|
||||
WOHUB2_SERVICE_INFO,
|
||||
WOMETERTHPC_SERVICE_INFO,
|
||||
WORELAY_SWITCH_1PM_SERVICE_INFO,
|
||||
)
|
||||
@ -234,3 +235,61 @@ async def test_remote(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_hub2_sensor(hass: HomeAssistant) -> None:
|
||||
"""Test setting up creates the sensor for WoHub2."""
|
||||
await async_setup_component(hass, DOMAIN, {})
|
||||
inject_bluetooth_service_info(hass, WOHUB2_SERVICE_INFO)
|
||||
|
||||
entry = MockConfigEntry(
|
||||
domain=DOMAIN,
|
||||
data={
|
||||
CONF_ADDRESS: "AA:BB:CC:DD:EE:FF",
|
||||
CONF_NAME: "test-name",
|
||||
CONF_SENSOR_TYPE: "hub2",
|
||||
},
|
||||
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 == "26.4"
|
||||
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 == "44"
|
||||
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"
|
||||
|
||||
light_level_sensor = hass.states.get("sensor.test_name_light_level")
|
||||
light_level_sensor_attrs = light_level_sensor.attributes
|
||||
assert light_level_sensor.state == "4"
|
||||
assert light_level_sensor_attrs[ATTR_FRIENDLY_NAME] == "test-name Light level"
|
||||
assert light_level_sensor_attrs[ATTR_UNIT_OF_MEASUREMENT] == "Level"
|
||||
|
||||
light_level_sensor = hass.states.get("sensor.test_name_illuminance")
|
||||
light_level_sensor_attrs = light_level_sensor.attributes
|
||||
assert light_level_sensor.state == "30"
|
||||
assert light_level_sensor_attrs[ATTR_FRIENDLY_NAME] == "test-name Illuminance"
|
||||
assert light_level_sensor_attrs[ATTR_UNIT_OF_MEASUREMENT] == "lx"
|
||||
|
||||
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