106 lines
3.8 KiB
Python
106 lines
3.8 KiB
Python
"""
|
|
Test for the SmartThings switch platform.
|
|
|
|
The only mocking required is of the underlying SmartThings API object so
|
|
real HTTP calls are not initiated during testing.
|
|
"""
|
|
from pysmartthings import Attribute, Capability
|
|
|
|
from homeassistant.components.smartthings import switch
|
|
from homeassistant.components.smartthings.const import DOMAIN, SIGNAL_SMARTTHINGS_UPDATE
|
|
from homeassistant.components.switch import (
|
|
ATTR_CURRENT_POWER_W,
|
|
ATTR_TODAY_ENERGY_KWH,
|
|
DOMAIN as SWITCH_DOMAIN,
|
|
)
|
|
from homeassistant.helpers.dispatcher import async_dispatcher_send
|
|
|
|
from .conftest import setup_platform
|
|
|
|
|
|
async def test_async_setup_platform():
|
|
"""Test setup platform does nothing (it uses config entries)."""
|
|
await switch.async_setup_platform(None, None, None)
|
|
|
|
|
|
async def test_entity_and_device_attributes(hass, device_factory):
|
|
"""Test the attributes of the entity are correct."""
|
|
# Arrange
|
|
device = device_factory("Switch_1", [Capability.switch], {Attribute.switch: "on"})
|
|
entity_registry = await hass.helpers.entity_registry.async_get_registry()
|
|
device_registry = await hass.helpers.device_registry.async_get_registry()
|
|
# Act
|
|
await setup_platform(hass, SWITCH_DOMAIN, devices=[device])
|
|
# Assert
|
|
entry = entity_registry.async_get("switch.switch_1")
|
|
assert entry
|
|
assert entry.unique_id == device.device_id
|
|
|
|
entry = device_registry.async_get_device({(DOMAIN, device.device_id)}, [])
|
|
assert entry
|
|
assert entry.name == device.label
|
|
assert entry.model == device.device_type_name
|
|
assert entry.manufacturer == "Unavailable"
|
|
|
|
|
|
async def test_turn_off(hass, device_factory):
|
|
"""Test the switch turns of successfully."""
|
|
# Arrange
|
|
device = device_factory("Switch_1", [Capability.switch], {Attribute.switch: "on"})
|
|
await setup_platform(hass, SWITCH_DOMAIN, devices=[device])
|
|
# Act
|
|
await hass.services.async_call(
|
|
"switch", "turn_off", {"entity_id": "switch.switch_1"}, blocking=True
|
|
)
|
|
# Assert
|
|
state = hass.states.get("switch.switch_1")
|
|
assert state is not None
|
|
assert state.state == "off"
|
|
|
|
|
|
async def test_turn_on(hass, device_factory):
|
|
"""Test the switch turns of successfully."""
|
|
# Arrange
|
|
device = device_factory(
|
|
"Switch_1",
|
|
[Capability.switch, Capability.power_meter, Capability.energy_meter],
|
|
{Attribute.switch: "off", Attribute.power: 355, Attribute.energy: 11.422},
|
|
)
|
|
await setup_platform(hass, SWITCH_DOMAIN, devices=[device])
|
|
# Act
|
|
await hass.services.async_call(
|
|
"switch", "turn_on", {"entity_id": "switch.switch_1"}, blocking=True
|
|
)
|
|
# Assert
|
|
state = hass.states.get("switch.switch_1")
|
|
assert state is not None
|
|
assert state.state == "on"
|
|
assert state.attributes[ATTR_CURRENT_POWER_W] == 355
|
|
assert state.attributes[ATTR_TODAY_ENERGY_KWH] == 11.422
|
|
|
|
|
|
async def test_update_from_signal(hass, device_factory):
|
|
"""Test the switch updates when receiving a signal."""
|
|
# Arrange
|
|
device = device_factory("Switch_1", [Capability.switch], {Attribute.switch: "off"})
|
|
await setup_platform(hass, SWITCH_DOMAIN, devices=[device])
|
|
await device.switch_on(True)
|
|
# Act
|
|
async_dispatcher_send(hass, SIGNAL_SMARTTHINGS_UPDATE, [device.device_id])
|
|
# Assert
|
|
await hass.async_block_till_done()
|
|
state = hass.states.get("switch.switch_1")
|
|
assert state is not None
|
|
assert state.state == "on"
|
|
|
|
|
|
async def test_unload_config_entry(hass, device_factory):
|
|
"""Test the switch is removed when the config entry is unloaded."""
|
|
# Arrange
|
|
device = device_factory("Switch 1", [Capability.switch], {Attribute.switch: "on"})
|
|
config_entry = await setup_platform(hass, SWITCH_DOMAIN, devices=[device])
|
|
# Act
|
|
await hass.config_entries.async_forward_entry_unload(config_entry, "switch")
|
|
# Assert
|
|
assert not hass.states.get("switch.switch_1")
|