2019-03-24 15:16:50 +00:00
|
|
|
"""Test Axis config flow."""
|
2021-01-01 21:31:56 +00:00
|
|
|
from unittest.mock import patch
|
|
|
|
|
2021-01-13 13:03:54 +00:00
|
|
|
import respx
|
|
|
|
|
2020-06-01 16:45:38 +00:00
|
|
|
from homeassistant import data_entry_flow
|
2019-03-24 15:16:50 +00:00
|
|
|
from homeassistant.components.axis import config_flow
|
2020-06-01 16:45:38 +00:00
|
|
|
from homeassistant.components.axis.const import (
|
|
|
|
CONF_EVENTS,
|
|
|
|
CONF_MODEL,
|
|
|
|
CONF_STREAM_PROFILE,
|
|
|
|
DEFAULT_STREAM_PROFILE,
|
|
|
|
DOMAIN as AXIS_DOMAIN,
|
|
|
|
)
|
2021-01-16 10:03:56 +00:00
|
|
|
from homeassistant.components.dhcp import HOSTNAME, IP_ADDRESS, MAC_ADDRESS
|
|
|
|
from homeassistant.config_entries import (
|
|
|
|
SOURCE_DHCP,
|
|
|
|
SOURCE_IGNORE,
|
|
|
|
SOURCE_USER,
|
|
|
|
SOURCE_ZEROCONF,
|
|
|
|
)
|
2020-05-14 08:49:27 +00:00
|
|
|
from homeassistant.const import (
|
|
|
|
CONF_HOST,
|
|
|
|
CONF_NAME,
|
|
|
|
CONF_PASSWORD,
|
|
|
|
CONF_PORT,
|
|
|
|
CONF_USERNAME,
|
|
|
|
)
|
2020-10-22 07:29:53 +00:00
|
|
|
from homeassistant.data_entry_flow import (
|
|
|
|
RESULT_TYPE_ABORT,
|
|
|
|
RESULT_TYPE_CREATE_ENTRY,
|
|
|
|
RESULT_TYPE_FORM,
|
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2021-01-13 13:03:54 +00:00
|
|
|
from .test_device import (
|
|
|
|
MAC,
|
|
|
|
MODEL,
|
|
|
|
NAME,
|
|
|
|
mock_default_vapix_requests,
|
|
|
|
setup_axis_integration,
|
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2020-04-25 21:32:55 +00:00
|
|
|
from tests.common import MockConfigEntry
|
2019-03-24 15:16:50 +00:00
|
|
|
|
|
|
|
|
2020-01-05 09:11:17 +00:00
|
|
|
async def test_flow_manual_configuration(hass):
|
2019-03-24 15:16:50 +00:00
|
|
|
"""Test that config flow works."""
|
2020-12-09 16:48:16 +00:00
|
|
|
MockConfigEntry(domain=AXIS_DOMAIN, source=SOURCE_IGNORE).add_to_hass(hass)
|
|
|
|
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-10-22 07:29:53 +00:00
|
|
|
AXIS_DOMAIN, context={"source": SOURCE_USER}
|
2020-01-05 09:11:17 +00:00
|
|
|
)
|
2019-07-31 19:25:30 +00:00
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == SOURCE_USER
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2021-01-13 13:03:54 +00:00
|
|
|
with respx.mock:
|
|
|
|
mock_default_vapix_requests(respx)
|
2019-04-15 22:06:45 +00:00
|
|
|
result = await hass.config_entries.flow.async_configure(
|
2019-07-31 19:25:30 +00:00
|
|
|
result["flow_id"],
|
2019-04-15 22:06:45 +00:00
|
|
|
user_input={
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2019-07-31 19:25:30 +00:00
|
|
|
},
|
2019-04-15 22:06:45 +00:00
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_CREATE_ENTRY
|
2021-01-16 17:59:57 +00:00
|
|
|
assert result["title"] == f"M1065-LW - {MAC}"
|
2019-07-31 19:25:30 +00:00
|
|
|
assert result["data"] == {
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-05-31 18:00:15 +00:00
|
|
|
CONF_MODEL: "M1065-LW",
|
|
|
|
CONF_NAME: "M1065-LW 0",
|
2019-03-24 15:16:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-05 09:11:17 +00:00
|
|
|
async def test_manual_configuration_update_configuration(hass):
|
|
|
|
"""Test that config flow fails on already configured device."""
|
2020-10-22 07:29:53 +00:00
|
|
|
config_entry = await setup_axis_integration(hass)
|
|
|
|
device = hass.data[AXIS_DOMAIN][config_entry.unique_id]
|
2020-01-05 09:11:17 +00:00
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-10-22 07:29:53 +00:00
|
|
|
AXIS_DOMAIN, context={"source": SOURCE_USER}
|
2020-01-05 09:11:17 +00:00
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == SOURCE_USER
|
2020-01-05 09:11:17 +00:00
|
|
|
|
2020-08-08 18:23:56 +00:00
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.axis.async_setup_entry",
|
|
|
|
return_value=True,
|
2021-01-13 13:03:54 +00:00
|
|
|
) as mock_setup_entry, respx.mock:
|
|
|
|
mock_default_vapix_requests(respx, "2.3.4.5")
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
user_input={
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "2.3.4.5",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-01-05 09:11:17 +00:00
|
|
|
},
|
|
|
|
)
|
2020-08-08 18:23:56 +00:00
|
|
|
await hass.async_block_till_done()
|
2020-01-05 09:11:17 +00:00
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
2020-01-30 21:20:30 +00:00
|
|
|
assert result["reason"] == "already_configured"
|
2020-05-14 08:49:27 +00:00
|
|
|
assert device.host == "2.3.4.5"
|
2020-08-08 18:23:56 +00:00
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
2020-01-05 09:11:17 +00:00
|
|
|
|
|
|
|
|
2019-03-24 15:16:50 +00:00
|
|
|
async def test_flow_fails_already_configured(hass):
|
|
|
|
"""Test that config flow fails on already configured device."""
|
2020-01-04 07:58:18 +00:00
|
|
|
await setup_axis_integration(hass)
|
|
|
|
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-10-22 07:29:53 +00:00
|
|
|
AXIS_DOMAIN, context={"source": SOURCE_USER}
|
2020-01-05 09:11:17 +00:00
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == SOURCE_USER
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2021-01-13 13:03:54 +00:00
|
|
|
with respx.mock:
|
|
|
|
mock_default_vapix_requests(respx)
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
2019-07-31 19:25:30 +00:00
|
|
|
user_input={
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-01-05 09:11:17 +00:00
|
|
|
},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
2020-01-05 09:11:17 +00:00
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
|
2019-03-24 15:16:50 +00:00
|
|
|
|
|
|
|
async def test_flow_fails_faulty_credentials(hass):
|
|
|
|
"""Test that config flow fails on faulty credentials."""
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-10-22 07:29:53 +00:00
|
|
|
AXIS_DOMAIN, context={"source": SOURCE_USER}
|
2020-01-05 09:11:17 +00:00
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == SOURCE_USER
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.axis.config_flow.get_device",
|
|
|
|
side_effect=config_flow.AuthenticationRequired,
|
|
|
|
):
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
2019-07-31 19:25:30 +00:00
|
|
|
user_input={
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-01-05 09:11:17 +00:00
|
|
|
},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2020-10-06 14:54:18 +00:00
|
|
|
assert result["errors"] == {"base": "invalid_auth"}
|
2019-03-24 15:16:50 +00:00
|
|
|
|
|
|
|
|
2020-10-06 14:54:18 +00:00
|
|
|
async def test_flow_fails_cannot_connect(hass):
|
|
|
|
"""Test that config flow fails on cannot connect."""
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-10-22 07:29:53 +00:00
|
|
|
AXIS_DOMAIN, context={"source": SOURCE_USER}
|
2020-01-05 09:11:17 +00:00
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == SOURCE_USER
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.axis.config_flow.get_device",
|
|
|
|
side_effect=config_flow.CannotConnect,
|
|
|
|
):
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
2019-07-31 19:25:30 +00:00
|
|
|
user_input={
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-01-05 09:11:17 +00:00
|
|
|
},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2020-10-06 14:54:18 +00:00
|
|
|
assert result["errors"] == {"base": "cannot_connect"}
|
2019-03-24 15:16:50 +00:00
|
|
|
|
|
|
|
|
2020-01-05 09:11:17 +00:00
|
|
|
async def test_flow_create_entry_multiple_existing_entries_of_same_model(hass):
|
2019-03-24 15:16:50 +00:00
|
|
|
"""Test that create entry can generate a name with other entries."""
|
|
|
|
entry = MockConfigEntry(
|
2020-08-27 11:56:20 +00:00
|
|
|
domain=AXIS_DOMAIN,
|
|
|
|
data={CONF_NAME: "M1065-LW 0", CONF_MODEL: "M1065-LW"},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
entry.add_to_hass(hass)
|
|
|
|
entry2 = MockConfigEntry(
|
2020-08-27 11:56:20 +00:00
|
|
|
domain=AXIS_DOMAIN,
|
|
|
|
data={CONF_NAME: "M1065-LW 1", CONF_MODEL: "M1065-LW"},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
entry2.add_to_hass(hass)
|
|
|
|
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-10-22 07:29:53 +00:00
|
|
|
AXIS_DOMAIN, context={"source": SOURCE_USER}
|
2020-01-05 09:11:17 +00:00
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == SOURCE_USER
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2021-01-13 13:03:54 +00:00
|
|
|
with respx.mock:
|
|
|
|
mock_default_vapix_requests(respx)
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
user_input={
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-01-05 09:11:17 +00:00
|
|
|
},
|
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_CREATE_ENTRY
|
2021-01-16 17:59:57 +00:00
|
|
|
assert result["title"] == f"M1065-LW - {MAC}"
|
2020-01-05 09:11:17 +00:00
|
|
|
assert result["data"] == {
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-05-31 18:00:15 +00:00
|
|
|
CONF_MODEL: "M1065-LW",
|
|
|
|
CONF_NAME: "M1065-LW 2",
|
2020-01-05 09:11:17 +00:00
|
|
|
}
|
|
|
|
|
2020-05-31 18:00:15 +00:00
|
|
|
assert result["data"][CONF_NAME] == "M1065-LW 2"
|
2019-03-24 15:16:50 +00:00
|
|
|
|
|
|
|
|
2021-01-16 10:03:56 +00:00
|
|
|
async def test_dhcp_flow(hass):
|
|
|
|
"""Test that DHCP discovery for new devices work."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
AXIS_DOMAIN,
|
|
|
|
data={
|
|
|
|
HOSTNAME: "axis-123",
|
|
|
|
IP_ADDRESS: "1.2.3.4",
|
|
|
|
MAC_ADDRESS: MAC,
|
|
|
|
},
|
|
|
|
context={"source": SOURCE_DHCP},
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result["type"] == RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == SOURCE_USER
|
|
|
|
|
|
|
|
with respx.mock:
|
|
|
|
mock_default_vapix_requests(respx)
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
user_input={
|
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result["type"] == RESULT_TYPE_CREATE_ENTRY
|
2021-01-16 17:59:57 +00:00
|
|
|
assert result["title"] == f"M1065-LW - {MAC}"
|
2021-01-16 10:03:56 +00:00
|
|
|
assert result["data"] == {
|
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
|
|
|
CONF_MODEL: "M1065-LW",
|
|
|
|
CONF_NAME: "M1065-LW 0",
|
|
|
|
}
|
|
|
|
|
|
|
|
assert result["data"][CONF_NAME] == "M1065-LW 0"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_dhcp_flow_already_configured(hass):
|
|
|
|
"""Test that DHCP doesn't setup already configured devices."""
|
|
|
|
config_entry = await setup_axis_integration(hass)
|
|
|
|
device = hass.data[AXIS_DOMAIN][config_entry.unique_id]
|
|
|
|
assert device.host == "1.2.3.4"
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
AXIS_DOMAIN,
|
|
|
|
data={
|
|
|
|
HOSTNAME: "axis-123",
|
|
|
|
IP_ADDRESS: "1.2.3.4",
|
|
|
|
MAC_ADDRESS: MAC,
|
|
|
|
},
|
|
|
|
context={"source": SOURCE_DHCP},
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
assert device.host == "1.2.3.4"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_dhcp_flow_updated_configuration(hass):
|
|
|
|
"""Test that DHCP update configuration with new parameters."""
|
|
|
|
config_entry = await setup_axis_integration(hass)
|
|
|
|
device = hass.data[AXIS_DOMAIN][config_entry.unique_id]
|
|
|
|
assert device.host == "1.2.3.4"
|
|
|
|
assert device.config_entry.data == {
|
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_PORT: 80,
|
|
|
|
CONF_USERNAME: "root",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_MODEL: MODEL,
|
|
|
|
CONF_NAME: NAME,
|
|
|
|
}
|
|
|
|
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.axis.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry, respx.mock:
|
|
|
|
mock_default_vapix_requests(respx, "2.3.4.5")
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
AXIS_DOMAIN,
|
|
|
|
data={
|
|
|
|
HOSTNAME: "axis-123",
|
|
|
|
IP_ADDRESS: "2.3.4.5",
|
|
|
|
MAC_ADDRESS: MAC,
|
|
|
|
},
|
|
|
|
context={"source": SOURCE_DHCP},
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
assert device.config_entry.data == {
|
|
|
|
CONF_HOST: "2.3.4.5",
|
|
|
|
CONF_PORT: 80,
|
|
|
|
CONF_USERNAME: "root",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_MODEL: MODEL,
|
|
|
|
CONF_NAME: NAME,
|
|
|
|
}
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
|
|
|
|
|
|
|
|
async def test_dhcp_flow_ignore_non_axis_device(hass):
|
|
|
|
"""Test that DHCP doesn't setup devices with link local addresses."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
AXIS_DOMAIN,
|
|
|
|
data={
|
|
|
|
HOSTNAME: "axis-123",
|
|
|
|
IP_ADDRESS: "169.254.3.4",
|
|
|
|
MAC_ADDRESS: "01234567890",
|
|
|
|
},
|
|
|
|
context={"source": SOURCE_DHCP},
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
|
|
|
assert result["reason"] == "not_axis_device"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_dhcp_flow_ignore_link_local_address(hass):
|
|
|
|
"""Test that DHCP doesn't setup devices with link local addresses."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
AXIS_DOMAIN,
|
|
|
|
data={HOSTNAME: "axis-123", IP_ADDRESS: "169.254.3.4", MAC_ADDRESS: MAC},
|
|
|
|
context={"source": SOURCE_DHCP},
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
|
|
|
assert result["reason"] == "link_local_address"
|
|
|
|
|
|
|
|
|
2019-05-21 22:36:26 +00:00
|
|
|
async def test_zeroconf_flow(hass):
|
|
|
|
"""Test that zeroconf discovery for new devices work."""
|
2020-05-31 18:00:15 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
AXIS_DOMAIN,
|
|
|
|
data={
|
2021-01-16 17:59:57 +00:00
|
|
|
"host": "1.2.3.4",
|
|
|
|
"port": 80,
|
|
|
|
"hostname": f"axis-{MAC.lower()}.local.",
|
|
|
|
"type": "_axis-video._tcp.local.",
|
|
|
|
"name": f"AXIS M1065-L - {MAC}._axis-video._tcp.local.",
|
|
|
|
"properties": {
|
|
|
|
"_raw": {"macaddress": MAC.encode()},
|
|
|
|
"macaddress": MAC,
|
|
|
|
},
|
2020-05-31 18:00:15 +00:00
|
|
|
},
|
2020-10-22 07:29:53 +00:00
|
|
|
context={"source": SOURCE_ZEROCONF},
|
2020-05-31 18:00:15 +00:00
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == SOURCE_USER
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2021-01-13 13:03:54 +00:00
|
|
|
with respx.mock:
|
|
|
|
mock_default_vapix_requests(respx)
|
2020-01-05 09:11:17 +00:00
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
user_input={
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-01-05 09:11:17 +00:00
|
|
|
},
|
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_CREATE_ENTRY
|
2021-01-16 17:59:57 +00:00
|
|
|
assert result["title"] == f"M1065-LW - {MAC}"
|
2020-01-05 09:11:17 +00:00
|
|
|
assert result["data"] == {
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_USERNAME: "user",
|
|
|
|
CONF_PASSWORD: "pass",
|
|
|
|
CONF_PORT: 80,
|
2020-05-31 18:00:15 +00:00
|
|
|
CONF_MODEL: "M1065-LW",
|
|
|
|
CONF_NAME: "M1065-LW 0",
|
2020-01-05 09:11:17 +00:00
|
|
|
}
|
|
|
|
|
2020-05-31 18:00:15 +00:00
|
|
|
assert result["data"][CONF_NAME] == "M1065-LW 0"
|
2020-01-05 09:11:17 +00:00
|
|
|
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2019-05-21 22:36:26 +00:00
|
|
|
async def test_zeroconf_flow_already_configured(hass):
|
|
|
|
"""Test that zeroconf doesn't setup already configured devices."""
|
2020-10-22 07:29:53 +00:00
|
|
|
config_entry = await setup_axis_integration(hass)
|
|
|
|
device = hass.data[AXIS_DOMAIN][config_entry.unique_id]
|
2020-01-04 07:58:18 +00:00
|
|
|
assert device.host == "1.2.3.4"
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2019-04-15 22:06:45 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-05-14 08:49:27 +00:00
|
|
|
AXIS_DOMAIN,
|
2019-04-15 22:06:45 +00:00
|
|
|
data={
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_PORT: 80,
|
2021-01-16 17:59:57 +00:00
|
|
|
"name": "name",
|
2020-01-05 09:11:17 +00:00
|
|
|
"properties": {"macaddress": MAC},
|
2019-04-15 22:06:45 +00:00
|
|
|
},
|
2020-10-22 07:29:53 +00:00
|
|
|
context={"source": SOURCE_ZEROCONF},
|
2019-04-15 22:06:45 +00:00
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
2019-07-31 19:25:30 +00:00
|
|
|
assert result["reason"] == "already_configured"
|
2020-01-04 07:58:18 +00:00
|
|
|
assert device.host == "1.2.3.4"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_zeroconf_flow_updated_configuration(hass):
|
|
|
|
"""Test that zeroconf update configuration with new parameters."""
|
2020-10-22 07:29:53 +00:00
|
|
|
config_entry = await setup_axis_integration(hass)
|
|
|
|
device = hass.data[AXIS_DOMAIN][config_entry.unique_id]
|
2020-01-04 07:58:18 +00:00
|
|
|
assert device.host == "1.2.3.4"
|
2020-01-30 21:20:30 +00:00
|
|
|
assert device.config_entry.data == {
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "1.2.3.4",
|
|
|
|
CONF_PORT: 80,
|
2020-06-01 16:45:38 +00:00
|
|
|
CONF_USERNAME: "root",
|
|
|
|
CONF_PASSWORD: "pass",
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_MODEL: MODEL,
|
|
|
|
CONF_NAME: NAME,
|
2020-01-30 21:20:30 +00:00
|
|
|
}
|
2020-01-04 07:58:18 +00:00
|
|
|
|
2020-08-08 18:23:56 +00:00
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.axis.async_setup_entry",
|
|
|
|
return_value=True,
|
2021-01-13 13:03:54 +00:00
|
|
|
) as mock_setup_entry, respx.mock:
|
|
|
|
mock_default_vapix_requests(respx, "2.3.4.5")
|
2020-08-08 18:23:56 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
AXIS_DOMAIN,
|
|
|
|
data={
|
|
|
|
CONF_HOST: "2.3.4.5",
|
|
|
|
CONF_PORT: 8080,
|
2021-01-16 17:59:57 +00:00
|
|
|
"name": "name",
|
2020-08-08 18:23:56 +00:00
|
|
|
"properties": {"macaddress": MAC},
|
|
|
|
},
|
2020-10-22 07:29:53 +00:00
|
|
|
context={"source": SOURCE_ZEROCONF},
|
2020-08-08 18:23:56 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2020-01-04 07:58:18 +00:00
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
2020-01-30 21:20:30 +00:00
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
assert device.config_entry.data == {
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_HOST: "2.3.4.5",
|
|
|
|
CONF_PORT: 8080,
|
2020-06-01 16:45:38 +00:00
|
|
|
CONF_USERNAME: "root",
|
|
|
|
CONF_PASSWORD: "pass",
|
2020-05-14 08:49:27 +00:00
|
|
|
CONF_MODEL: MODEL,
|
|
|
|
CONF_NAME: NAME,
|
2020-01-30 21:20:30 +00:00
|
|
|
}
|
2020-08-08 18:23:56 +00:00
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
2019-03-24 15:16:50 +00:00
|
|
|
|
|
|
|
|
2019-06-10 16:12:17 +00:00
|
|
|
async def test_zeroconf_flow_ignore_non_axis_device(hass):
|
|
|
|
"""Test that zeroconf doesn't setup devices with link local addresses."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-05-14 08:49:27 +00:00
|
|
|
AXIS_DOMAIN,
|
2021-01-16 10:03:56 +00:00
|
|
|
data={
|
|
|
|
CONF_HOST: "169.254.3.4",
|
|
|
|
CONF_PORT: 80,
|
2021-01-16 17:59:57 +00:00
|
|
|
"name": "",
|
2021-01-16 10:03:56 +00:00
|
|
|
"properties": {"macaddress": "01234567890"},
|
|
|
|
},
|
2020-10-22 07:29:53 +00:00
|
|
|
context={"source": SOURCE_ZEROCONF},
|
2019-06-10 16:12:17 +00:00
|
|
|
)
|
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
2019-07-31 19:25:30 +00:00
|
|
|
assert result["reason"] == "not_axis_device"
|
2019-06-10 16:12:17 +00:00
|
|
|
|
|
|
|
|
2019-05-21 22:36:26 +00:00
|
|
|
async def test_zeroconf_flow_ignore_link_local_address(hass):
|
|
|
|
"""Test that zeroconf doesn't setup devices with link local addresses."""
|
2019-04-15 22:06:45 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2020-05-14 08:49:27 +00:00
|
|
|
AXIS_DOMAIN,
|
2021-01-16 10:03:56 +00:00
|
|
|
data={
|
|
|
|
CONF_HOST: "169.254.3.4",
|
|
|
|
CONF_PORT: 80,
|
2021-01-16 17:59:57 +00:00
|
|
|
"name": "",
|
2021-01-16 10:03:56 +00:00
|
|
|
"properties": {"macaddress": MAC},
|
|
|
|
},
|
2020-10-22 07:29:53 +00:00
|
|
|
context={"source": SOURCE_ZEROCONF},
|
2019-04-15 22:06:45 +00:00
|
|
|
)
|
2019-03-24 15:16:50 +00:00
|
|
|
|
2020-10-22 07:29:53 +00:00
|
|
|
assert result["type"] == RESULT_TYPE_ABORT
|
2019-07-31 19:25:30 +00:00
|
|
|
assert result["reason"] == "link_local_address"
|
2020-06-01 16:45:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_option_flow(hass):
|
|
|
|
"""Test config flow options."""
|
2020-10-22 07:29:53 +00:00
|
|
|
config_entry = await setup_axis_integration(hass)
|
|
|
|
device = hass.data[AXIS_DOMAIN][config_entry.unique_id]
|
2020-06-01 16:45:38 +00:00
|
|
|
assert device.option_stream_profile == DEFAULT_STREAM_PROFILE
|
|
|
|
|
|
|
|
result = await hass.config_entries.options.async_init(device.config_entry.entry_id)
|
|
|
|
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == "configure_stream"
|
|
|
|
assert set(result["data_schema"].schema[CONF_STREAM_PROFILE].container) == {
|
|
|
|
DEFAULT_STREAM_PROFILE,
|
|
|
|
"profile_1",
|
|
|
|
"profile_2",
|
|
|
|
}
|
|
|
|
|
|
|
|
result = await hass.config_entries.options.async_configure(
|
2020-08-27 11:56:20 +00:00
|
|
|
result["flow_id"],
|
|
|
|
user_input={CONF_STREAM_PROFILE: "profile_1"},
|
2020-06-01 16:45:38 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
|
|
|
assert result["data"] == {
|
|
|
|
CONF_EVENTS: True,
|
|
|
|
CONF_STREAM_PROFILE: "profile_1",
|
|
|
|
}
|
|
|
|
assert device.option_stream_profile == "profile_1"
|