mirror of
https://github.com/home-assistant/core.git
synced 2025-07-19 11:17:21 +00:00
Add MockDeviceListener to tuya tests
This commit is contained in:
parent
412035b970
commit
31a5c064f5
@ -2,11 +2,12 @@
|
|||||||
|
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from typing import Any
|
||||||
from unittest.mock import patch
|
from unittest.mock import patch
|
||||||
|
|
||||||
from tuya_sharing import CustomerDevice
|
from tuya_sharing import CustomerDevice
|
||||||
|
|
||||||
from homeassistant.components.tuya import ManagerCompat
|
from homeassistant.components.tuya import DeviceListener, ManagerCompat
|
||||||
from homeassistant.const import Platform
|
from homeassistant.const import Platform
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
|
|
||||||
@ -162,6 +163,29 @@ DEVICE_MOCKS = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class MockDeviceListener(DeviceListener):
|
||||||
|
"""Mocked DeviceListener for testing."""
|
||||||
|
|
||||||
|
async def async_send_device_update(
|
||||||
|
self,
|
||||||
|
hass: HomeAssistant,
|
||||||
|
device: CustomerDevice,
|
||||||
|
updated_status_properties: dict[str, Any] | None = None,
|
||||||
|
) -> None:
|
||||||
|
"""Mock update device method."""
|
||||||
|
property_list: list[str] = []
|
||||||
|
if updated_status_properties:
|
||||||
|
for key, value in updated_status_properties.items():
|
||||||
|
if key not in device.status:
|
||||||
|
raise ValueError(
|
||||||
|
f"Property {key} not found in device status: {device.status}"
|
||||||
|
)
|
||||||
|
device.status[key] = value
|
||||||
|
property_list.append(key)
|
||||||
|
self.update_device(device, property_list)
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
|
||||||
async def initialize_entry(
|
async def initialize_entry(
|
||||||
hass: HomeAssistant,
|
hass: HomeAssistant,
|
||||||
mock_manager: ManagerCompat,
|
mock_manager: ManagerCompat,
|
||||||
|
@ -21,6 +21,8 @@ from homeassistant.core import HomeAssistant
|
|||||||
from homeassistant.helpers.json import json_dumps
|
from homeassistant.helpers.json import json_dumps
|
||||||
from homeassistant.util import dt as dt_util
|
from homeassistant.util import dt as dt_util
|
||||||
|
|
||||||
|
from . import MockDeviceListener
|
||||||
|
|
||||||
from tests.common import MockConfigEntry, async_load_json_object_fixture
|
from tests.common import MockConfigEntry, async_load_json_object_fixture
|
||||||
|
|
||||||
|
|
||||||
@ -181,3 +183,13 @@ async def mock_device(hass: HomeAssistant, mock_device_code: str) -> CustomerDev
|
|||||||
}
|
}
|
||||||
device.status = details["status"]
|
device.status = details["status"]
|
||||||
return device
|
return device
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def mock_listener(
|
||||||
|
hass: HomeAssistant, mock_manager: ManagerCompat
|
||||||
|
) -> MockDeviceListener:
|
||||||
|
"""Create a DeviceListener for testing."""
|
||||||
|
listener = MockDeviceListener(hass, mock_manager)
|
||||||
|
mock_manager.add_device_listener(listener)
|
||||||
|
return listener
|
||||||
|
@ -13,7 +13,7 @@ from homeassistant.const import Platform
|
|||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.helpers import entity_registry as er
|
from homeassistant.helpers import entity_registry as er
|
||||||
|
|
||||||
from . import DEVICE_MOCKS, initialize_entry
|
from . import DEVICE_MOCKS, MockDeviceListener, initialize_entry
|
||||||
|
|
||||||
from tests.common import MockConfigEntry, snapshot_platform
|
from tests.common import MockConfigEntry, snapshot_platform
|
||||||
|
|
||||||
@ -78,16 +78,23 @@ async def test_bitmap(
|
|||||||
mock_manager: ManagerCompat,
|
mock_manager: ManagerCompat,
|
||||||
mock_config_entry: MockConfigEntry,
|
mock_config_entry: MockConfigEntry,
|
||||||
mock_device: CustomerDevice,
|
mock_device: CustomerDevice,
|
||||||
|
mock_listener: MockDeviceListener,
|
||||||
fault_value: int,
|
fault_value: int,
|
||||||
tankfull: str,
|
tankfull: str,
|
||||||
defrost: str,
|
defrost: str,
|
||||||
wet: str,
|
wet: str,
|
||||||
) -> None:
|
) -> None:
|
||||||
"""Test BITMAP fault sensor on cs_arete_two_12l_dehumidifier_air_purifier."""
|
"""Test BITMAP fault sensor on cs_arete_two_12l_dehumidifier_air_purifier."""
|
||||||
mock_device.status["fault"] = fault_value
|
|
||||||
|
|
||||||
await initialize_entry(hass, mock_manager, mock_config_entry, mock_device)
|
await initialize_entry(hass, mock_manager, mock_config_entry, mock_device)
|
||||||
|
|
||||||
|
assert hass.states.get("binary_sensor.dehumidifier_tank_full").state == "off"
|
||||||
|
assert hass.states.get("binary_sensor.dehumidifier_defrost").state == "off"
|
||||||
|
assert hass.states.get("binary_sensor.dehumidifier_wet").state == "off"
|
||||||
|
|
||||||
|
await mock_listener.async_send_device_update(
|
||||||
|
hass, mock_device, {"fault": fault_value}
|
||||||
|
)
|
||||||
|
|
||||||
assert hass.states.get("binary_sensor.dehumidifier_tank_full").state == tankfull
|
assert hass.states.get("binary_sensor.dehumidifier_tank_full").state == tankfull
|
||||||
assert hass.states.get("binary_sensor.dehumidifier_defrost").state == defrost
|
assert hass.states.get("binary_sensor.dehumidifier_defrost").state == defrost
|
||||||
assert hass.states.get("binary_sensor.dehumidifier_wet").state == wet
|
assert hass.states.get("binary_sensor.dehumidifier_wet").state == wet
|
||||||
|
Loading…
x
Reference in New Issue
Block a user