2018-11-06 09:34:24 +00:00
|
|
|
"""Test deCONZ gateway."""
|
|
|
|
from unittest.mock import Mock, patch
|
|
|
|
|
2019-02-14 04:36:06 +00:00
|
|
|
import pytest
|
|
|
|
|
|
|
|
from homeassistant.exceptions import ConfigEntryNotReady
|
2019-03-24 18:27:32 +00:00
|
|
|
from homeassistant.components.deconz import errors, gateway
|
2018-11-06 09:34:24 +00:00
|
|
|
|
|
|
|
from tests.common import mock_coro
|
|
|
|
|
2019-03-24 18:27:32 +00:00
|
|
|
import pydeconz
|
|
|
|
|
|
|
|
|
2018-11-06 09:34:24 +00:00
|
|
|
ENTRY_CONFIG = {
|
|
|
|
"host": "1.2.3.4",
|
|
|
|
"port": 80,
|
|
|
|
"api_key": "1234567890ABCDEF",
|
|
|
|
"bridgeid": "0123456789ABCDEF",
|
|
|
|
"allow_clip_sensor": True,
|
|
|
|
"allow_deconz_groups": True,
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async def test_gateway_setup():
|
|
|
|
"""Successful setup."""
|
|
|
|
hass = Mock()
|
|
|
|
entry = Mock()
|
|
|
|
entry.data = ENTRY_CONFIG
|
|
|
|
api = Mock()
|
|
|
|
api.async_add_remote.return_value = Mock()
|
|
|
|
api.sensors = {}
|
|
|
|
|
|
|
|
deconz_gateway = gateway.DeconzGateway(hass, entry)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch.object(
|
|
|
|
gateway, "get_gateway", return_value=mock_coro(api)
|
|
|
|
), patch.object(gateway, "async_dispatcher_connect", return_value=Mock()):
|
2018-11-06 09:34:24 +00:00
|
|
|
assert await deconz_gateway.async_setup() is True
|
|
|
|
|
|
|
|
assert deconz_gateway.api is api
|
2019-02-18 16:43:22 +00:00
|
|
|
assert len(hass.config_entries.async_forward_entry_setup.mock_calls) == 7
|
2019-07-31 19:25:30 +00:00
|
|
|
assert hass.config_entries.async_forward_entry_setup.mock_calls[0][1] == (
|
|
|
|
entry,
|
|
|
|
"binary_sensor",
|
|
|
|
)
|
|
|
|
assert hass.config_entries.async_forward_entry_setup.mock_calls[1][1] == (
|
|
|
|
entry,
|
|
|
|
"climate",
|
|
|
|
)
|
|
|
|
assert hass.config_entries.async_forward_entry_setup.mock_calls[2][1] == (
|
|
|
|
entry,
|
|
|
|
"cover",
|
|
|
|
)
|
|
|
|
assert hass.config_entries.async_forward_entry_setup.mock_calls[3][1] == (
|
|
|
|
entry,
|
|
|
|
"light",
|
|
|
|
)
|
|
|
|
assert hass.config_entries.async_forward_entry_setup.mock_calls[4][1] == (
|
|
|
|
entry,
|
|
|
|
"scene",
|
|
|
|
)
|
|
|
|
assert hass.config_entries.async_forward_entry_setup.mock_calls[5][1] == (
|
|
|
|
entry,
|
|
|
|
"sensor",
|
|
|
|
)
|
|
|
|
assert hass.config_entries.async_forward_entry_setup.mock_calls[6][1] == (
|
|
|
|
entry,
|
|
|
|
"switch",
|
|
|
|
)
|
2018-11-06 09:34:24 +00:00
|
|
|
assert len(api.start.mock_calls) == 1
|
|
|
|
|
|
|
|
|
|
|
|
async def test_gateway_retry():
|
|
|
|
"""Retry setup."""
|
|
|
|
hass = Mock()
|
|
|
|
entry = Mock()
|
|
|
|
entry.data = ENTRY_CONFIG
|
|
|
|
|
|
|
|
deconz_gateway = gateway.DeconzGateway(hass, entry)
|
|
|
|
|
2019-02-14 04:36:06 +00:00
|
|
|
with patch.object(
|
2019-07-31 19:25:30 +00:00
|
|
|
gateway, "get_gateway", side_effect=errors.CannotConnect
|
|
|
|
), pytest.raises(ConfigEntryNotReady):
|
2019-02-14 04:36:06 +00:00
|
|
|
await deconz_gateway.async_setup()
|
2018-11-06 09:34:24 +00:00
|
|
|
|
|
|
|
|
2019-03-24 18:27:32 +00:00
|
|
|
async def test_gateway_setup_fails():
|
|
|
|
"""Retry setup."""
|
|
|
|
hass = Mock()
|
|
|
|
entry = Mock()
|
|
|
|
entry.data = ENTRY_CONFIG
|
|
|
|
|
|
|
|
deconz_gateway = gateway.DeconzGateway(hass, entry)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch.object(gateway, "get_gateway", side_effect=Exception):
|
2019-03-24 18:27:32 +00:00
|
|
|
result = await deconz_gateway.async_setup()
|
|
|
|
|
|
|
|
assert not result
|
|
|
|
|
|
|
|
|
2018-11-06 09:34:24 +00:00
|
|
|
async def test_connection_status(hass):
|
|
|
|
"""Make sure that connection status triggers a dispatcher send."""
|
|
|
|
entry = Mock()
|
|
|
|
entry.data = ENTRY_CONFIG
|
|
|
|
|
|
|
|
deconz_gateway = gateway.DeconzGateway(hass, entry)
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch.object(gateway, "async_dispatcher_send") as mock_dispatch_send:
|
2018-11-06 09:34:24 +00:00
|
|
|
deconz_gateway.async_connection_status_callback(True)
|
|
|
|
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_dispatch_send.mock_calls) == 1
|
|
|
|
assert len(mock_dispatch_send.mock_calls[0]) == 3
|
|
|
|
|
|
|
|
|
|
|
|
async def test_add_device(hass):
|
|
|
|
"""Successful retry setup."""
|
|
|
|
entry = Mock()
|
|
|
|
entry.data = ENTRY_CONFIG
|
|
|
|
|
|
|
|
deconz_gateway = gateway.DeconzGateway(hass, entry)
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch.object(gateway, "async_dispatcher_send") as mock_dispatch_send:
|
|
|
|
deconz_gateway.async_add_device_callback("sensor", Mock())
|
2018-11-06 09:34:24 +00:00
|
|
|
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_dispatch_send.mock_calls) == 1
|
|
|
|
assert len(mock_dispatch_send.mock_calls[0]) == 3
|
|
|
|
|
|
|
|
|
|
|
|
async def test_shutdown():
|
|
|
|
"""Successful shutdown."""
|
|
|
|
hass = Mock()
|
|
|
|
entry = Mock()
|
|
|
|
entry.data = ENTRY_CONFIG
|
|
|
|
|
|
|
|
deconz_gateway = gateway.DeconzGateway(hass, entry)
|
|
|
|
deconz_gateway.api = Mock()
|
|
|
|
deconz_gateway.shutdown(None)
|
|
|
|
|
|
|
|
assert len(deconz_gateway.api.close.mock_calls) == 1
|
|
|
|
|
|
|
|
|
|
|
|
async def test_reset_after_successful_setup():
|
|
|
|
"""Verify that reset works on a setup component."""
|
|
|
|
hass = Mock()
|
|
|
|
entry = Mock()
|
|
|
|
entry.data = ENTRY_CONFIG
|
|
|
|
api = Mock()
|
|
|
|
api.async_add_remote.return_value = Mock()
|
|
|
|
api.sensors = {}
|
|
|
|
|
|
|
|
deconz_gateway = gateway.DeconzGateway(hass, entry)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch.object(
|
|
|
|
gateway, "get_gateway", return_value=mock_coro(api)
|
|
|
|
), patch.object(gateway, "async_dispatcher_connect", return_value=Mock()):
|
2018-11-06 09:34:24 +00:00
|
|
|
assert await deconz_gateway.async_setup() is True
|
|
|
|
|
|
|
|
listener = Mock()
|
|
|
|
deconz_gateway.listeners = [listener]
|
|
|
|
event = Mock()
|
|
|
|
event.async_will_remove_from_hass = Mock()
|
|
|
|
deconz_gateway.events = [event]
|
2019-07-31 19:25:30 +00:00
|
|
|
deconz_gateway.deconz_ids = {"key": "value"}
|
2018-11-06 09:34:24 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
hass.config_entries.async_forward_entry_unload.return_value = mock_coro(True)
|
2018-11-06 09:34:24 +00:00
|
|
|
assert await deconz_gateway.async_reset() is True
|
|
|
|
|
2019-02-18 16:43:22 +00:00
|
|
|
assert len(hass.config_entries.async_forward_entry_unload.mock_calls) == 7
|
2018-11-06 09:34:24 +00:00
|
|
|
|
|
|
|
assert len(listener.mock_calls) == 1
|
|
|
|
assert len(deconz_gateway.listeners) == 0
|
|
|
|
|
|
|
|
assert len(event.async_will_remove_from_hass.mock_calls) == 1
|
|
|
|
assert len(deconz_gateway.events) == 0
|
|
|
|
|
|
|
|
assert len(deconz_gateway.deconz_ids) == 0
|
|
|
|
|
|
|
|
|
|
|
|
async def test_get_gateway(hass):
|
|
|
|
"""Successful call."""
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch(
|
|
|
|
"pydeconz.DeconzSession.async_load_parameters", return_value=mock_coro(True)
|
|
|
|
):
|
2018-11-06 09:34:24 +00:00
|
|
|
assert await gateway.get_gateway(hass, ENTRY_CONFIG, Mock(), Mock())
|
|
|
|
|
|
|
|
|
2019-03-24 18:27:32 +00:00
|
|
|
async def test_get_gateway_fails_unauthorized(hass):
|
|
|
|
"""Failed call."""
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch(
|
|
|
|
"pydeconz.DeconzSession.async_load_parameters",
|
|
|
|
side_effect=pydeconz.errors.Unauthorized,
|
|
|
|
), pytest.raises(errors.AuthenticationRequired):
|
|
|
|
assert await gateway.get_gateway(hass, ENTRY_CONFIG, Mock(), Mock()) is False
|
2019-03-24 18:27:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_get_gateway_fails_cannot_connect(hass):
|
2018-11-06 09:34:24 +00:00
|
|
|
"""Failed call."""
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch(
|
|
|
|
"pydeconz.DeconzSession.async_load_parameters",
|
|
|
|
side_effect=pydeconz.errors.RequestError,
|
|
|
|
), pytest.raises(errors.CannotConnect):
|
|
|
|
assert await gateway.get_gateway(hass, ENTRY_CONFIG, Mock(), Mock()) is False
|