Change litterrobot integration to cloud_push (#77741)
Co-authored-by: J. Nick Koston <nick@koston.org>
This commit is contained in:
parent
0b4e4e81d4
commit
cc51052be5
11 changed files with 77 additions and 167 deletions
|
@ -1,10 +1,9 @@
|
|||
"""Test the Litter-Robot switch entity."""
|
||||
from datetime import timedelta
|
||||
from unittest.mock import MagicMock
|
||||
|
||||
from pylitterbot import Robot
|
||||
import pytest
|
||||
|
||||
from homeassistant.components.litterrobot.entity import REFRESH_WAIT_TIME_SECONDS
|
||||
from homeassistant.components.switch import (
|
||||
DOMAIN as PLATFORM_DOMAIN,
|
||||
SERVICE_TURN_OFF,
|
||||
|
@ -14,12 +13,9 @@ from homeassistant.const import ATTR_ENTITY_ID, STATE_OFF, STATE_ON
|
|||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.helpers import entity_registry
|
||||
from homeassistant.helpers.entity import EntityCategory
|
||||
from homeassistant.util.dt import utcnow
|
||||
|
||||
from .conftest import setup_integration
|
||||
|
||||
from tests.common import async_fire_time_changed
|
||||
|
||||
NIGHT_LIGHT_MODE_ENTITY_ID = "switch.test_night_light_mode"
|
||||
PANEL_LOCKOUT_ENTITY_ID = "switch.test_panel_lockout"
|
||||
|
||||
|
@ -39,17 +35,22 @@ async def test_switch(hass: HomeAssistant, mock_account: MagicMock):
|
|||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"entity_id,robot_command",
|
||||
"entity_id,robot_command,updated_field",
|
||||
[
|
||||
(NIGHT_LIGHT_MODE_ENTITY_ID, "set_night_light"),
|
||||
(PANEL_LOCKOUT_ENTITY_ID, "set_panel_lockout"),
|
||||
(NIGHT_LIGHT_MODE_ENTITY_ID, "set_night_light", "nightLightActive"),
|
||||
(PANEL_LOCKOUT_ENTITY_ID, "set_panel_lockout", "panelLockActive"),
|
||||
],
|
||||
)
|
||||
async def test_on_off_commands(
|
||||
hass: HomeAssistant, mock_account: MagicMock, entity_id: str, robot_command: str
|
||||
hass: HomeAssistant,
|
||||
mock_account: MagicMock,
|
||||
entity_id: str,
|
||||
robot_command: str,
|
||||
updated_field: str,
|
||||
):
|
||||
"""Test sending commands to the switch."""
|
||||
await setup_integration(hass, mock_account, PLATFORM_DOMAIN)
|
||||
robot: Robot = mock_account.robots[0]
|
||||
|
||||
state = hass.states.get(entity_id)
|
||||
assert state
|
||||
|
@ -57,19 +58,17 @@ async def test_on_off_commands(
|
|||
data = {ATTR_ENTITY_ID: entity_id}
|
||||
|
||||
count = 0
|
||||
for service in [SERVICE_TURN_ON, SERVICE_TURN_OFF]:
|
||||
for service in (SERVICE_TURN_ON, SERVICE_TURN_OFF):
|
||||
count += 1
|
||||
|
||||
await hass.services.async_call(
|
||||
PLATFORM_DOMAIN,
|
||||
service,
|
||||
data,
|
||||
blocking=True,
|
||||
)
|
||||
robot._update_data({updated_field: 1 if service == SERVICE_TURN_ON else 0})
|
||||
|
||||
future = utcnow() + timedelta(seconds=REFRESH_WAIT_TIME_SECONDS)
|
||||
async_fire_time_changed(hass, future)
|
||||
assert getattr(mock_account.robots[0], robot_command).call_count == count
|
||||
assert getattr(robot, robot_command).call_count == count
|
||||
state = hass.states.get(entity_id)
|
||||
assert state
|
||||
assert state.state == STATE_ON if service == SERVICE_TURN_ON else STATE_OFF
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue