2018-08-01 11:03:08 +02:00
|
|
|
"""deCONZ switch platform tests."""
|
2019-09-18 12:47:26 +02:00
|
|
|
from copy import deepcopy
|
|
|
|
|
|
|
|
from asynctest import patch
|
2018-08-01 11:03:08 +02:00
|
|
|
|
|
|
|
from homeassistant import config_entries
|
|
|
|
from homeassistant.components import deconz
|
2018-10-31 22:38:04 +01:00
|
|
|
from homeassistant.setup import async_setup_component
|
|
|
|
|
2018-08-01 11:03:08 +02:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
import homeassistant.components.switch as switch
|
2018-08-01 11:03:08 +02:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
SWITCHES = {
|
2018-08-01 11:03:08 +02:00
|
|
|
"1": {
|
2019-09-18 12:47:26 +02:00
|
|
|
"id": "On off switch id",
|
|
|
|
"name": "On off switch",
|
2018-08-01 11:03:08 +02:00
|
|
|
"type": "On/Off plug-in unit",
|
2018-10-31 22:38:04 +01:00
|
|
|
"state": {"on": True, "reachable": True},
|
2019-07-31 12:25:30 -07:00
|
|
|
"uniqueid": "00:00:00:00:00:00:00:00-00",
|
2018-08-01 11:03:08 +02:00
|
|
|
},
|
|
|
|
"2": {
|
2019-09-18 12:47:26 +02:00
|
|
|
"id": "Smart plug id",
|
|
|
|
"name": "Smart plug",
|
2018-08-01 11:03:08 +02:00
|
|
|
"type": "Smart plug",
|
2019-09-18 12:47:26 +02:00
|
|
|
"state": {"on": False, "reachable": True},
|
|
|
|
"uniqueid": "00:00:00:00:00:00:00:01-00",
|
2018-08-10 19:22:12 +02:00
|
|
|
},
|
|
|
|
"3": {
|
2019-09-18 12:47:26 +02:00
|
|
|
"id": "Warning device id",
|
|
|
|
"name": "Warning device",
|
2018-08-10 19:22:12 +02:00
|
|
|
"type": "Warning device",
|
2019-07-31 12:25:30 -07:00
|
|
|
"state": {"alert": "lselect", "reachable": True},
|
2019-09-18 12:47:26 +02:00
|
|
|
"uniqueid": "00:00:00:00:00:00:00:02-00",
|
2019-07-31 12:25:30 -07:00
|
|
|
},
|
2019-09-18 12:47:26 +02:00
|
|
|
"4": {
|
|
|
|
"id": "Unsupported switch id",
|
2018-08-01 11:03:08 +02:00
|
|
|
"name": "Unsupported switch",
|
|
|
|
"type": "Not a smart plug",
|
2019-09-18 12:47:26 +02:00
|
|
|
"state": {"reachable": True},
|
|
|
|
"uniqueid": "00:00:00:00:00:00:00:03-00",
|
|
|
|
},
|
2018-08-01 11:03:08 +02:00
|
|
|
}
|
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
BRIDGEID = "0123456789"
|
2018-08-01 11:03:08 +02:00
|
|
|
|
2018-10-31 22:38:04 +01:00
|
|
|
ENTRY_CONFIG = {
|
|
|
|
deconz.config_flow.CONF_API_KEY: "ABCDEF",
|
2019-09-18 12:47:26 +02:00
|
|
|
deconz.config_flow.CONF_BRIDGEID: BRIDGEID,
|
2018-10-31 22:38:04 +01:00
|
|
|
deconz.config_flow.CONF_HOST: "1.2.3.4",
|
2019-07-31 12:25:30 -07:00
|
|
|
deconz.config_flow.CONF_PORT: 80,
|
2018-10-31 22:38:04 +01:00
|
|
|
}
|
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
DECONZ_CONFIG = {
|
|
|
|
"bridgeid": BRIDGEID,
|
|
|
|
"mac": "00:11:22:33:44:55",
|
|
|
|
"name": "deCONZ mock gateway",
|
|
|
|
"sw_version": "2.05.69",
|
|
|
|
"websocketport": 1234,
|
|
|
|
}
|
2018-10-31 22:38:04 +01:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
DECONZ_WEB_REQUEST = {"config": DECONZ_CONFIG}
|
2019-07-31 12:25:30 -07:00
|
|
|
|
2018-10-31 22:38:04 +01:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
async def setup_deconz_integration(hass, config, options, get_state_response):
|
|
|
|
"""Create the deCONZ gateway."""
|
2018-08-01 11:03:08 +02:00
|
|
|
config_entry = config_entries.ConfigEntry(
|
2019-09-18 12:47:26 +02:00
|
|
|
version=1,
|
|
|
|
domain=deconz.DOMAIN,
|
|
|
|
title="Mock Title",
|
|
|
|
data=config,
|
|
|
|
source="test",
|
|
|
|
connection_class=config_entries.CONN_CLASS_LOCAL_PUSH,
|
2019-08-18 06:34:11 +02:00
|
|
|
system_options={},
|
2019-09-18 12:47:26 +02:00
|
|
|
options=options,
|
|
|
|
entry_id="1",
|
2019-07-31 12:25:30 -07:00
|
|
|
)
|
2018-10-31 22:38:04 +01:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
with patch(
|
|
|
|
"pydeconz.DeconzSession.async_get_state", return_value=get_state_response
|
|
|
|
), patch("pydeconz.DeconzSession.start", return_value=True):
|
|
|
|
await deconz.async_setup_entry(hass, config_entry)
|
2018-08-01 11:03:08 +02:00
|
|
|
await hass.async_block_till_done()
|
2019-09-18 12:47:26 +02:00
|
|
|
|
|
|
|
hass.config_entries._entries.append(config_entry)
|
|
|
|
|
|
|
|
return hass.data[deconz.DOMAIN][config[deconz.CONF_BRIDGEID]]
|
2018-08-01 11:03:08 +02:00
|
|
|
|
|
|
|
|
2018-10-31 22:38:04 +01:00
|
|
|
async def test_platform_manually_configured(hass):
|
|
|
|
"""Test that we do not discover anything or try to set up a gateway."""
|
2019-07-31 12:25:30 -07:00
|
|
|
assert (
|
|
|
|
await async_setup_component(
|
|
|
|
hass, switch.DOMAIN, {"switch": {"platform": deconz.DOMAIN}}
|
|
|
|
)
|
|
|
|
is True
|
|
|
|
)
|
2018-10-31 22:38:04 +01:00
|
|
|
assert deconz.DOMAIN not in hass.data
|
|
|
|
|
|
|
|
|
2018-08-01 11:03:08 +02:00
|
|
|
async def test_no_switches(hass):
|
|
|
|
"""Test that no switch entities are created."""
|
2019-09-18 12:47:26 +02:00
|
|
|
data = deepcopy(DECONZ_WEB_REQUEST)
|
|
|
|
gateway = await setup_deconz_integration(
|
|
|
|
hass, ENTRY_CONFIG, options={}, get_state_response=data
|
|
|
|
)
|
|
|
|
assert len(gateway.deconz_ids) == 0
|
2018-08-01 11:03:08 +02:00
|
|
|
assert len(hass.states.async_all()) == 0
|
|
|
|
|
|
|
|
|
2018-10-31 22:38:04 +01:00
|
|
|
async def test_switches(hass):
|
2018-09-21 19:59:20 +02:00
|
|
|
"""Test that all supported switch entities are created."""
|
2019-09-18 12:47:26 +02:00
|
|
|
data = deepcopy(DECONZ_WEB_REQUEST)
|
|
|
|
data["lights"] = deepcopy(SWITCHES)
|
|
|
|
gateway = await setup_deconz_integration(
|
|
|
|
hass, ENTRY_CONFIG, options={}, get_state_response=data
|
2019-07-31 12:25:30 -07:00
|
|
|
)
|
2019-09-18 12:47:26 +02:00
|
|
|
assert "switch.on_off_switch" in gateway.deconz_ids
|
|
|
|
assert "switch.smart_plug" in gateway.deconz_ids
|
|
|
|
assert "switch.warning_device" in gateway.deconz_ids
|
|
|
|
assert "switch.unsupported_switch" not in gateway.deconz_ids
|
|
|
|
assert len(hass.states.async_all()) == 6
|
2018-10-31 22:38:04 +01:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
on_off_switch = hass.states.get("switch.on_off_switch")
|
|
|
|
assert on_off_switch.state == "on"
|
2018-08-01 11:03:08 +02:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
smart_plug = hass.states.get("switch.smart_plug")
|
|
|
|
assert smart_plug.state == "off"
|
2018-08-01 11:03:08 +02:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
warning_device = hass.states.get("switch.warning_device")
|
|
|
|
assert warning_device.state == "on"
|
2018-08-01 11:03:08 +02:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
on_off_switch_device = gateway.api.lights["1"]
|
|
|
|
warning_device_device = gateway.api.lights["3"]
|
2018-10-31 22:38:04 +01:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
on_off_switch_device.async_update({"state": {"on": False}})
|
|
|
|
warning_device_device.async_update({"state": {"alert": None}})
|
|
|
|
await hass.async_block_till_done()
|
2018-10-31 22:38:04 +01:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
on_off_switch = hass.states.get("switch.on_off_switch")
|
|
|
|
assert on_off_switch.state == "off"
|
2018-10-31 22:38:04 +01:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
warning_device = hass.states.get("switch.warning_device")
|
|
|
|
assert warning_device.state == "off"
|
2018-10-31 22:38:04 +01:00
|
|
|
|
2019-09-18 12:47:26 +02:00
|
|
|
with patch.object(
|
|
|
|
on_off_switch_device, "_async_set_callback", return_value=True
|
|
|
|
) as set_callback:
|
|
|
|
await hass.services.async_call(
|
|
|
|
switch.DOMAIN,
|
|
|
|
switch.SERVICE_TURN_ON,
|
|
|
|
{"entity_id": "switch.on_off_switch"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
set_callback.assert_called_with("/lights/1/state", {"on": True})
|
|
|
|
|
|
|
|
with patch.object(
|
|
|
|
on_off_switch_device, "_async_set_callback", return_value=True
|
|
|
|
) as set_callback:
|
|
|
|
await hass.services.async_call(
|
|
|
|
switch.DOMAIN,
|
|
|
|
switch.SERVICE_TURN_OFF,
|
|
|
|
{"entity_id": "switch.on_off_switch"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
set_callback.assert_called_with("/lights/1/state", {"on": False})
|
|
|
|
|
|
|
|
with patch.object(
|
|
|
|
warning_device_device, "_async_set_callback", return_value=True
|
|
|
|
) as set_callback:
|
|
|
|
await hass.services.async_call(
|
|
|
|
switch.DOMAIN,
|
|
|
|
switch.SERVICE_TURN_ON,
|
|
|
|
{"entity_id": "switch.warning_device"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
set_callback.assert_called_with("/lights/3/state", {"alert": "lselect"})
|
|
|
|
|
|
|
|
with patch.object(
|
|
|
|
warning_device_device, "_async_set_callback", return_value=True
|
|
|
|
) as set_callback:
|
|
|
|
await hass.services.async_call(
|
|
|
|
switch.DOMAIN,
|
|
|
|
switch.SERVICE_TURN_OFF,
|
|
|
|
{"entity_id": "switch.warning_device"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
set_callback.assert_called_with("/lights/3/state", {"alert": "none"})
|