2020-05-26 13:47:25 +00:00
|
|
|
"""Define tests for the Elexa Guardian config flow."""
|
2021-01-01 21:31:56 +00:00
|
|
|
from unittest.mock import patch
|
|
|
|
|
2020-05-26 13:47:25 +00:00
|
|
|
from aioguardian.errors import GuardianError
|
|
|
|
|
|
|
|
from homeassistant import data_entry_flow
|
2021-05-11 02:26:15 +00:00
|
|
|
from homeassistant.components.dhcp import HOSTNAME, IP_ADDRESS, MAC_ADDRESS
|
2020-05-26 13:47:25 +00:00
|
|
|
from homeassistant.components.guardian import CONF_UID, DOMAIN
|
2020-05-27 22:45:28 +00:00
|
|
|
from homeassistant.components.guardian.config_flow import (
|
|
|
|
async_get_pin_from_discovery_hostname,
|
|
|
|
async_get_pin_from_uid,
|
|
|
|
)
|
2021-05-11 02:26:15 +00:00
|
|
|
from homeassistant.config_entries import SOURCE_DHCP, SOURCE_USER, SOURCE_ZEROCONF
|
2020-05-26 13:47:25 +00:00
|
|
|
from homeassistant.const import CONF_IP_ADDRESS, CONF_PORT
|
|
|
|
|
|
|
|
from tests.common import MockConfigEntry
|
|
|
|
|
|
|
|
|
2020-05-27 22:45:28 +00:00
|
|
|
async def test_duplicate_error(hass, ping_client):
|
2020-05-26 13:47:25 +00:00
|
|
|
"""Test that errors are shown when duplicate entries are added."""
|
|
|
|
conf = {CONF_IP_ADDRESS: "192.168.1.100", CONF_PORT: 7777}
|
|
|
|
|
2020-05-27 22:45:28 +00:00
|
|
|
MockConfigEntry(domain=DOMAIN, unique_id="guardian_3456", data=conf).add_to_hass(
|
2020-05-26 13:47:25 +00:00
|
|
|
hass
|
|
|
|
)
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_USER}, data=conf
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_ABORT
|
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_connect_error(hass):
|
|
|
|
"""Test that the config entry errors out if the device cannot connect."""
|
|
|
|
conf = {CONF_IP_ADDRESS: "192.168.1.100", CONF_PORT: 7777}
|
|
|
|
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"aioguardian.client.Client.connect",
|
|
|
|
side_effect=GuardianError,
|
2020-05-26 13:47:25 +00:00
|
|
|
):
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_USER}, data=conf
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result["errors"] == {CONF_IP_ADDRESS: "cannot_connect"}
|
|
|
|
|
|
|
|
|
2020-05-27 22:45:28 +00:00
|
|
|
async def test_get_pin_from_discovery_hostname():
|
|
|
|
"""Test getting a device PIN from the zeroconf-discovered hostname."""
|
|
|
|
pin = async_get_pin_from_discovery_hostname("GVC1-3456.local.")
|
|
|
|
assert pin == "3456"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_get_pin_from_uid():
|
|
|
|
"""Test getting a device PIN from its UID."""
|
|
|
|
pin = async_get_pin_from_uid("ABCDEF123456")
|
|
|
|
assert pin == "3456"
|
|
|
|
|
|
|
|
|
2020-05-26 13:47:25 +00:00
|
|
|
async def test_step_user(hass, ping_client):
|
|
|
|
"""Test the user step."""
|
|
|
|
conf = {CONF_IP_ADDRESS: "192.168.1.100", CONF_PORT: 7777}
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_USER}
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == "user"
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_USER}, data=conf
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
2020-05-27 22:45:28 +00:00
|
|
|
assert result["title"] == "ABCDEF123456"
|
2020-05-26 13:47:25 +00:00
|
|
|
assert result["data"] == {
|
|
|
|
CONF_IP_ADDRESS: "192.168.1.100",
|
|
|
|
CONF_PORT: 7777,
|
|
|
|
CONF_UID: "ABCDEF123456",
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async def test_step_zeroconf(hass, ping_client):
|
|
|
|
"""Test the zeroconf step."""
|
|
|
|
zeroconf_data = {
|
|
|
|
"host": "192.168.1.100",
|
|
|
|
"port": 7777,
|
|
|
|
"hostname": "GVC1-ABCD.local.",
|
|
|
|
"type": "_api._udp.local.",
|
|
|
|
"name": "Guardian Valve Controller API._api._udp.local.",
|
|
|
|
"properties": {"_raw": {}},
|
|
|
|
}
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_ZEROCONF}, data=zeroconf_data
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
2021-05-11 02:26:15 +00:00
|
|
|
assert result["step_id"] == "discovery_confirm"
|
2020-05-26 13:47:25 +00:00
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input={}
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
2020-05-27 22:45:28 +00:00
|
|
|
assert result["title"] == "ABCDEF123456"
|
2020-05-26 13:47:25 +00:00
|
|
|
assert result["data"] == {
|
|
|
|
CONF_IP_ADDRESS: "192.168.1.100",
|
|
|
|
CONF_PORT: 7777,
|
|
|
|
CONF_UID: "ABCDEF123456",
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async def test_step_zeroconf_already_in_progress(hass):
|
|
|
|
"""Test the zeroconf step aborting because it's already in progress."""
|
|
|
|
zeroconf_data = {
|
|
|
|
"host": "192.168.1.100",
|
|
|
|
"port": 7777,
|
|
|
|
"hostname": "GVC1-ABCD.local.",
|
|
|
|
"type": "_api._udp.local.",
|
|
|
|
"name": "Guardian Valve Controller API._api._udp.local.",
|
|
|
|
"properties": {"_raw": {}},
|
|
|
|
}
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_ZEROCONF}, data=zeroconf_data
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
2021-05-11 02:26:15 +00:00
|
|
|
assert result["step_id"] == "discovery_confirm"
|
2020-05-26 13:47:25 +00:00
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_ZEROCONF}, data=zeroconf_data
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_in_progress"
|
|
|
|
|
|
|
|
|
2021-05-11 02:26:15 +00:00
|
|
|
async def test_step_dhcp(hass, ping_client):
|
|
|
|
"""Test the dhcp step."""
|
|
|
|
dhcp_data = {
|
|
|
|
IP_ADDRESS: "192.168.1.100",
|
|
|
|
HOSTNAME: "GVC1-ABCD.local.",
|
|
|
|
MAC_ADDRESS: "aa:bb:cc:dd:ee:ff",
|
|
|
|
}
|
|
|
|
|
2020-05-26 13:47:25 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-05-11 02:26:15 +00:00
|
|
|
DOMAIN, context={"source": SOURCE_DHCP}, data=dhcp_data
|
2020-05-26 13:47:25 +00:00
|
|
|
)
|
2021-05-11 02:26:15 +00:00
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == "discovery_confirm"
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input={}
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
|
|
|
assert result["title"] == "ABCDEF123456"
|
|
|
|
assert result["data"] == {
|
|
|
|
CONF_IP_ADDRESS: "192.168.1.100",
|
|
|
|
CONF_PORT: 7777,
|
|
|
|
CONF_UID: "ABCDEF123456",
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async def test_step_dhcp_already_in_progress(hass):
|
|
|
|
"""Test the zeroconf step aborting because it's already in progress."""
|
|
|
|
dhcp_data = {
|
|
|
|
IP_ADDRESS: "192.168.1.100",
|
|
|
|
HOSTNAME: "GVC1-ABCD.local.",
|
|
|
|
MAC_ADDRESS: "aa:bb:cc:dd:ee:ff",
|
|
|
|
}
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_DHCP}, data=dhcp_data
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == "discovery_confirm"
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_DHCP}, data=dhcp_data
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_in_progress"
|