2018-07-06 21:05:34 +00:00
|
|
|
"""Test HomematicIP Cloud setup process."""
|
|
|
|
|
2020-01-27 20:34:15 +00:00
|
|
|
from asynctest import CoroutineMock, Mock, patch
|
2020-02-16 09:09:26 +00:00
|
|
|
from homematicip.base.base_connection import HmipConnectionError
|
2020-01-27 20:34:15 +00:00
|
|
|
|
|
|
|
from homeassistant.components.homematicip_cloud.const import (
|
|
|
|
CONF_ACCESSPOINT,
|
|
|
|
CONF_AUTHTOKEN,
|
|
|
|
DOMAIN as HMIPC_DOMAIN,
|
|
|
|
HMIPC_AUTHTOKEN,
|
|
|
|
HMIPC_HAPID,
|
|
|
|
HMIPC_NAME,
|
|
|
|
)
|
|
|
|
from homeassistant.components.homematicip_cloud.hap import HomematicipHAP
|
2020-02-16 09:09:26 +00:00
|
|
|
from homeassistant.config_entries import (
|
|
|
|
ENTRY_STATE_LOADED,
|
|
|
|
ENTRY_STATE_NOT_LOADED,
|
|
|
|
ENTRY_STATE_SETUP_ERROR,
|
|
|
|
ENTRY_STATE_SETUP_RETRY,
|
|
|
|
)
|
2020-01-27 20:34:15 +00:00
|
|
|
from homeassistant.const import CONF_NAME
|
2019-10-06 09:54:26 +00:00
|
|
|
from homeassistant.setup import async_setup_component
|
2018-07-06 21:05:34 +00:00
|
|
|
|
2020-01-27 20:34:15 +00:00
|
|
|
from tests.common import MockConfigEntry
|
2018-07-06 21:05:34 +00:00
|
|
|
|
|
|
|
|
2020-03-14 18:35:15 +00:00
|
|
|
async def test_config_with_accesspoint_passed_to_config_entry(
|
|
|
|
hass, mock_connection, simple_mock_home
|
|
|
|
):
|
2018-07-06 21:05:34 +00:00
|
|
|
"""Test that config for a accesspoint are loaded via config entry."""
|
|
|
|
|
2020-01-26 13:54:33 +00:00
|
|
|
entry_config = {
|
2020-01-27 20:34:15 +00:00
|
|
|
CONF_ACCESSPOINT: "ABC123",
|
|
|
|
CONF_AUTHTOKEN: "123",
|
|
|
|
CONF_NAME: "name",
|
2020-01-26 13:54:33 +00:00
|
|
|
}
|
|
|
|
# no config_entry exists
|
2020-01-27 20:34:15 +00:00
|
|
|
assert len(hass.config_entries.async_entries(HMIPC_DOMAIN)) == 0
|
2020-01-26 13:54:33 +00:00
|
|
|
# no acccesspoint exists
|
2020-01-27 20:34:15 +00:00
|
|
|
assert not hass.data.get(HMIPC_DOMAIN)
|
2020-01-26 13:54:33 +00:00
|
|
|
|
2020-03-29 04:01:53 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.homematicip_cloud.hap.HomematicipHAP.async_connect",
|
|
|
|
):
|
|
|
|
assert await async_setup_component(
|
|
|
|
hass, HMIPC_DOMAIN, {HMIPC_DOMAIN: entry_config}
|
|
|
|
)
|
2020-01-26 13:54:33 +00:00
|
|
|
|
|
|
|
# config_entry created for access point
|
2020-01-27 20:34:15 +00:00
|
|
|
config_entries = hass.config_entries.async_entries(HMIPC_DOMAIN)
|
2020-01-26 13:54:33 +00:00
|
|
|
assert len(config_entries) == 1
|
|
|
|
assert config_entries[0].data == {
|
|
|
|
"authtoken": "123",
|
|
|
|
"hapid": "ABC123",
|
|
|
|
"name": "name",
|
|
|
|
}
|
|
|
|
# defined access_point created for config_entry
|
2020-01-27 20:34:15 +00:00
|
|
|
assert isinstance(hass.data[HMIPC_DOMAIN]["ABC123"], HomematicipHAP)
|
2018-07-06 21:05:34 +00:00
|
|
|
|
|
|
|
|
2020-03-14 18:35:15 +00:00
|
|
|
async def test_config_already_registered_not_passed_to_config_entry(
|
|
|
|
hass, simple_mock_home
|
|
|
|
):
|
2018-07-06 21:05:34 +00:00
|
|
|
"""Test that an already registered accesspoint does not get imported."""
|
|
|
|
|
2020-01-27 20:34:15 +00:00
|
|
|
mock_config = {HMIPC_AUTHTOKEN: "123", HMIPC_HAPID: "ABC123", HMIPC_NAME: "name"}
|
|
|
|
MockConfigEntry(domain=HMIPC_DOMAIN, data=mock_config).add_to_hass(hass)
|
2020-01-26 13:54:33 +00:00
|
|
|
|
|
|
|
# one config_entry exists
|
2020-01-27 20:34:15 +00:00
|
|
|
config_entries = hass.config_entries.async_entries(HMIPC_DOMAIN)
|
2020-01-26 13:54:33 +00:00
|
|
|
assert len(config_entries) == 1
|
|
|
|
assert config_entries[0].data == {
|
|
|
|
"authtoken": "123",
|
|
|
|
"hapid": "ABC123",
|
|
|
|
"name": "name",
|
|
|
|
}
|
|
|
|
# config_enty has no unique_id
|
|
|
|
assert not config_entries[0].unique_id
|
2018-07-06 21:05:34 +00:00
|
|
|
|
2020-01-26 13:54:33 +00:00
|
|
|
entry_config = {
|
2020-01-27 20:34:15 +00:00
|
|
|
CONF_ACCESSPOINT: "ABC123",
|
|
|
|
CONF_AUTHTOKEN: "123",
|
|
|
|
CONF_NAME: "name",
|
2020-01-26 13:54:33 +00:00
|
|
|
}
|
2020-03-29 04:01:53 +00:00
|
|
|
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.homematicip_cloud.hap.HomematicipHAP.async_connect",
|
|
|
|
):
|
|
|
|
assert await async_setup_component(
|
|
|
|
hass, HMIPC_DOMAIN, {HMIPC_DOMAIN: entry_config}
|
|
|
|
)
|
2018-07-06 21:05:34 +00:00
|
|
|
|
2020-01-26 13:54:33 +00:00
|
|
|
# no new config_entry created / still one config_entry
|
2020-01-27 20:34:15 +00:00
|
|
|
config_entries = hass.config_entries.async_entries(HMIPC_DOMAIN)
|
2020-01-26 13:54:33 +00:00
|
|
|
assert len(config_entries) == 1
|
|
|
|
assert config_entries[0].data == {
|
|
|
|
"authtoken": "123",
|
|
|
|
"hapid": "ABC123",
|
|
|
|
"name": "name",
|
2018-07-06 21:05:34 +00:00
|
|
|
}
|
2020-01-26 13:54:33 +00:00
|
|
|
# config_enty updated with unique_id
|
|
|
|
assert config_entries[0].unique_id == "ABC123"
|
2018-07-06 21:05:34 +00:00
|
|
|
|
|
|
|
|
2020-03-14 18:35:15 +00:00
|
|
|
async def test_load_entry_fails_due_to_connection_error(
|
|
|
|
hass, hmip_config_entry, mock_connection_init
|
|
|
|
):
|
2020-02-16 09:09:26 +00:00
|
|
|
"""Test load entry fails due to connection error."""
|
|
|
|
hmip_config_entry.add_to_hass(hass)
|
|
|
|
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.homematicip_cloud.hap.AsyncHome.get_current_state",
|
|
|
|
side_effect=HmipConnectionError,
|
|
|
|
):
|
|
|
|
assert await async_setup_component(hass, HMIPC_DOMAIN, {})
|
|
|
|
|
|
|
|
assert hass.data[HMIPC_DOMAIN][hmip_config_entry.unique_id]
|
|
|
|
assert hmip_config_entry.state == ENTRY_STATE_SETUP_RETRY
|
|
|
|
|
|
|
|
|
2020-03-29 04:01:53 +00:00
|
|
|
async def test_load_entry_fails_due_to_generic_exception(hass, hmip_config_entry):
|
2020-02-16 09:09:26 +00:00
|
|
|
"""Test load entry fails due to generic exception."""
|
|
|
|
hmip_config_entry.add_to_hass(hass)
|
|
|
|
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.homematicip_cloud.hap.AsyncHome.get_current_state",
|
|
|
|
side_effect=Exception,
|
2020-03-29 04:01:53 +00:00
|
|
|
), patch("homematicip.aio.connection.AsyncConnection.init",):
|
2020-02-16 09:09:26 +00:00
|
|
|
assert await async_setup_component(hass, HMIPC_DOMAIN, {})
|
|
|
|
|
|
|
|
assert hass.data[HMIPC_DOMAIN][hmip_config_entry.unique_id]
|
|
|
|
assert hmip_config_entry.state == ENTRY_STATE_SETUP_ERROR
|
|
|
|
|
|
|
|
|
2018-07-06 21:05:34 +00:00
|
|
|
async def test_unload_entry(hass):
|
|
|
|
"""Test being able to unload an entry."""
|
2020-01-27 20:34:15 +00:00
|
|
|
mock_config = {HMIPC_AUTHTOKEN: "123", HMIPC_HAPID: "ABC123", HMIPC_NAME: "name"}
|
|
|
|
MockConfigEntry(domain=HMIPC_DOMAIN, data=mock_config).add_to_hass(hass)
|
2018-07-06 21:05:34 +00:00
|
|
|
|
2020-01-27 20:34:15 +00:00
|
|
|
with patch("homeassistant.components.homematicip_cloud.HomematicipHAP") as mock_hap:
|
2019-08-12 14:42:12 +00:00
|
|
|
instance = mock_hap.return_value
|
2020-01-26 13:54:33 +00:00
|
|
|
instance.async_setup = CoroutineMock(return_value=True)
|
2019-08-12 14:42:12 +00:00
|
|
|
instance.home.id = "1"
|
|
|
|
instance.home.modelType = "mock-type"
|
|
|
|
instance.home.name = "mock-name"
|
|
|
|
instance.home.currentAPVersion = "mock-ap-version"
|
2020-01-26 13:54:33 +00:00
|
|
|
instance.async_reset = CoroutineMock(return_value=True)
|
2019-08-12 14:42:12 +00:00
|
|
|
|
2020-02-16 09:09:26 +00:00
|
|
|
assert await async_setup_component(hass, HMIPC_DOMAIN, {})
|
2018-07-06 21:05:34 +00:00
|
|
|
|
2020-01-26 13:54:33 +00:00
|
|
|
assert mock_hap.return_value.mock_calls[0][0] == "async_setup"
|
|
|
|
|
2020-01-27 20:34:15 +00:00
|
|
|
assert hass.data[HMIPC_DOMAIN]["ABC123"]
|
|
|
|
config_entries = hass.config_entries.async_entries(HMIPC_DOMAIN)
|
2020-01-26 13:54:33 +00:00
|
|
|
assert len(config_entries) == 1
|
2020-01-27 20:34:15 +00:00
|
|
|
assert config_entries[0].state == ENTRY_STATE_LOADED
|
2020-01-26 13:54:33 +00:00
|
|
|
await hass.config_entries.async_unload(config_entries[0].entry_id)
|
2020-01-27 20:34:15 +00:00
|
|
|
assert config_entries[0].state == ENTRY_STATE_NOT_LOADED
|
|
|
|
assert mock_hap.return_value.mock_calls[3][0] == "async_reset"
|
2020-01-26 13:54:33 +00:00
|
|
|
# entry is unloaded
|
2020-01-27 20:34:15 +00:00
|
|
|
assert hass.data[HMIPC_DOMAIN] == {}
|
2019-11-04 08:55:12 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_hmip_dump_hap_config_services(hass, mock_hap_with_service):
|
|
|
|
"""Test dump configuration services."""
|
|
|
|
|
|
|
|
with patch("pathlib.Path.write_text", return_value=Mock()) as write_mock:
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud", "dump_hap_config", {"anonymize": True}, blocking=True
|
|
|
|
)
|
|
|
|
home = mock_hap_with_service.home
|
|
|
|
assert home.mock_calls[-1][0] == "download_configuration"
|
2019-11-15 08:55:40 +00:00
|
|
|
assert home.mock_calls
|
|
|
|
assert write_mock.mock_calls
|
2020-02-16 09:09:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_setup_services_and_unload_services(hass):
|
|
|
|
"""Test setup services and unload services."""
|
|
|
|
mock_config = {HMIPC_AUTHTOKEN: "123", HMIPC_HAPID: "ABC123", HMIPC_NAME: "name"}
|
|
|
|
MockConfigEntry(domain=HMIPC_DOMAIN, data=mock_config).add_to_hass(hass)
|
|
|
|
|
|
|
|
with patch("homeassistant.components.homematicip_cloud.HomematicipHAP") as mock_hap:
|
|
|
|
instance = mock_hap.return_value
|
|
|
|
instance.async_setup = CoroutineMock(return_value=True)
|
|
|
|
instance.home.id = "1"
|
|
|
|
instance.home.modelType = "mock-type"
|
|
|
|
instance.home.name = "mock-name"
|
|
|
|
instance.home.currentAPVersion = "mock-ap-version"
|
|
|
|
instance.async_reset = CoroutineMock(return_value=True)
|
|
|
|
|
|
|
|
assert await async_setup_component(hass, HMIPC_DOMAIN, {})
|
|
|
|
|
|
|
|
# Check services are created
|
|
|
|
hmipc_services = hass.services.async_services()[HMIPC_DOMAIN]
|
|
|
|
assert len(hmipc_services) == 8
|
|
|
|
|
|
|
|
config_entries = hass.config_entries.async_entries(HMIPC_DOMAIN)
|
|
|
|
assert len(config_entries) == 1
|
|
|
|
|
|
|
|
await hass.config_entries.async_unload(config_entries[0].entry_id)
|
|
|
|
# Check services are removed
|
|
|
|
assert not hass.services.async_services().get(HMIPC_DOMAIN)
|
|
|
|
|
|
|
|
|
|
|
|
async def test_setup_two_haps_unload_one_by_one(hass):
|
|
|
|
"""Test setup two access points and unload one by one and check services."""
|
|
|
|
|
|
|
|
# Setup AP1
|
|
|
|
mock_config = {HMIPC_AUTHTOKEN: "123", HMIPC_HAPID: "ABC123", HMIPC_NAME: "name"}
|
|
|
|
MockConfigEntry(domain=HMIPC_DOMAIN, data=mock_config).add_to_hass(hass)
|
|
|
|
# Setup AP2
|
|
|
|
mock_config2 = {HMIPC_AUTHTOKEN: "123", HMIPC_HAPID: "ABC1234", HMIPC_NAME: "name2"}
|
|
|
|
MockConfigEntry(domain=HMIPC_DOMAIN, data=mock_config2).add_to_hass(hass)
|
|
|
|
|
|
|
|
with patch("homeassistant.components.homematicip_cloud.HomematicipHAP") as mock_hap:
|
|
|
|
instance = mock_hap.return_value
|
|
|
|
instance.async_setup = CoroutineMock(return_value=True)
|
|
|
|
instance.home.id = "1"
|
|
|
|
instance.home.modelType = "mock-type"
|
|
|
|
instance.home.name = "mock-name"
|
|
|
|
instance.home.currentAPVersion = "mock-ap-version"
|
|
|
|
instance.async_reset = CoroutineMock(return_value=True)
|
|
|
|
|
|
|
|
assert await async_setup_component(hass, HMIPC_DOMAIN, {})
|
|
|
|
|
|
|
|
hmipc_services = hass.services.async_services()[HMIPC_DOMAIN]
|
|
|
|
assert len(hmipc_services) == 8
|
|
|
|
|
|
|
|
config_entries = hass.config_entries.async_entries(HMIPC_DOMAIN)
|
|
|
|
assert len(config_entries) == 2
|
|
|
|
# unload the first AP
|
|
|
|
await hass.config_entries.async_unload(config_entries[0].entry_id)
|
|
|
|
|
|
|
|
# services still exists
|
|
|
|
hmipc_services = hass.services.async_services()[HMIPC_DOMAIN]
|
|
|
|
assert len(hmipc_services) == 8
|
|
|
|
|
|
|
|
# unload the second AP
|
|
|
|
await hass.config_entries.async_unload(config_entries[1].entry_id)
|
|
|
|
|
|
|
|
# Check services are removed
|
|
|
|
assert not hass.services.async_services().get(HMIPC_DOMAIN)
|