2018-11-06 13:27:52 +00:00
|
|
|
"""Define tests for the Luftdaten config flow."""
|
2021-12-19 11:42:52 +00:00
|
|
|
from unittest.mock import MagicMock, patch
|
2020-04-25 21:32:55 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
from luftdaten.exceptions import LuftdatenConnectionError
|
|
|
|
|
|
|
|
from homeassistant.components.luftdaten import DOMAIN
|
2018-11-06 13:27:52 +00:00
|
|
|
from homeassistant.components.luftdaten.const import CONF_SENSOR_ID
|
2021-12-19 11:42:52 +00:00
|
|
|
from homeassistant.config_entries import SOURCE_USER
|
2021-12-22 12:00:51 +00:00
|
|
|
from homeassistant.const import CONF_SHOW_ON_MAP
|
2021-12-19 11:42:52 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
from homeassistant.data_entry_flow import (
|
|
|
|
RESULT_TYPE_ABORT,
|
|
|
|
RESULT_TYPE_CREATE_ENTRY,
|
|
|
|
RESULT_TYPE_FORM,
|
|
|
|
)
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2020-04-25 21:32:55 +00:00
|
|
|
from tests.common import MockConfigEntry
|
2018-11-06 13:27:52 +00:00
|
|
|
|
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
async def test_duplicate_error(
|
|
|
|
hass: HomeAssistant, mock_config_entry: MockConfigEntry
|
|
|
|
) -> None:
|
2018-11-06 13:27:52 +00:00
|
|
|
"""Test that errors are shown when duplicates are added."""
|
2021-12-19 11:42:52 +00:00
|
|
|
mock_config_entry.add_to_hass(hass)
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_USER}
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result.get("type") == RESULT_TYPE_FORM
|
|
|
|
assert result.get("step_id") == SOURCE_USER
|
|
|
|
assert "flow_id" in result
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
user_input={CONF_SENSOR_ID: 12345},
|
|
|
|
)
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
assert result2.get("type") == RESULT_TYPE_ABORT
|
|
|
|
assert result2.get("reason") == "already_configured"
|
2018-11-06 13:27:52 +00:00
|
|
|
|
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
async def test_communication_error(hass: HomeAssistant) -> None:
|
2018-11-06 13:27:52 +00:00
|
|
|
"""Test that no sensor is added while unable to communicate with API."""
|
2021-12-19 11:42:52 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_USER}
|
|
|
|
)
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
assert result.get("type") == RESULT_TYPE_FORM
|
|
|
|
assert result.get("step_id") == SOURCE_USER
|
|
|
|
assert "flow_id" in result
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
with patch("luftdaten.Luftdaten.get_data", side_effect=LuftdatenConnectionError):
|
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
user_input={CONF_SENSOR_ID: 12345},
|
|
|
|
)
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
assert result2.get("type") == RESULT_TYPE_FORM
|
|
|
|
assert result2.get("step_id") == SOURCE_USER
|
|
|
|
assert result2.get("errors") == {CONF_SENSOR_ID: "cannot_connect"}
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-22 12:00:51 +00:00
|
|
|
with patch("luftdaten.Luftdaten.get_data"), patch(
|
|
|
|
"luftdaten.Luftdaten.validate_sensor", return_value=True
|
|
|
|
):
|
|
|
|
result3 = await hass.config_entries.flow.async_configure(
|
|
|
|
result2["flow_id"],
|
|
|
|
user_input={CONF_SENSOR_ID: 12345},
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result3.get("type") == RESULT_TYPE_CREATE_ENTRY
|
|
|
|
assert result3.get("title") == "12345"
|
|
|
|
assert result3.get("data") == {
|
|
|
|
CONF_SENSOR_ID: 12345,
|
|
|
|
CONF_SHOW_ON_MAP: False,
|
|
|
|
}
|
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
|
|
|
|
async def test_invalid_sensor(hass: HomeAssistant) -> None:
|
2018-11-06 13:27:52 +00:00
|
|
|
"""Test that an invalid sensor throws an error."""
|
2021-12-19 11:42:52 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_USER}
|
|
|
|
)
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
assert result.get("type") == RESULT_TYPE_FORM
|
|
|
|
assert result.get("step_id") == SOURCE_USER
|
|
|
|
assert "flow_id" in result
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2020-04-25 21:32:55 +00:00
|
|
|
with patch("luftdaten.Luftdaten.get_data", return_value=False), patch(
|
|
|
|
"luftdaten.Luftdaten.validate_sensor", return_value=False
|
2019-07-31 19:25:30 +00:00
|
|
|
):
|
2021-12-19 11:42:52 +00:00
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
user_input={CONF_SENSOR_ID: 12345},
|
|
|
|
)
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
assert result2.get("type") == RESULT_TYPE_FORM
|
|
|
|
assert result2.get("step_id") == SOURCE_USER
|
|
|
|
assert result2.get("errors") == {CONF_SENSOR_ID: "invalid_sensor"}
|
2021-12-22 12:00:51 +00:00
|
|
|
assert "flow_id" in result2
|
|
|
|
|
|
|
|
with patch("luftdaten.Luftdaten.get_data"), patch(
|
|
|
|
"luftdaten.Luftdaten.validate_sensor", return_value=True
|
|
|
|
):
|
|
|
|
result3 = await hass.config_entries.flow.async_configure(
|
|
|
|
result2["flow_id"],
|
|
|
|
user_input={CONF_SENSOR_ID: 12345},
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result3.get("type") == RESULT_TYPE_CREATE_ENTRY
|
|
|
|
assert result3.get("title") == "12345"
|
|
|
|
assert result3.get("data") == {
|
|
|
|
CONF_SENSOR_ID: 12345,
|
|
|
|
CONF_SHOW_ON_MAP: False,
|
|
|
|
}
|
2018-11-06 13:27:52 +00:00
|
|
|
|
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
async def test_step_user(hass: HomeAssistant, mock_setup_entry: MagicMock) -> None:
|
2018-11-06 13:27:52 +00:00
|
|
|
"""Test that the user step works."""
|
2021-12-19 11:42:52 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": SOURCE_USER}
|
|
|
|
)
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2021-12-19 11:42:52 +00:00
|
|
|
assert result.get("type") == RESULT_TYPE_FORM
|
|
|
|
assert result.get("step_id") == SOURCE_USER
|
|
|
|
assert "flow_id" in result
|
2018-11-06 13:27:52 +00:00
|
|
|
|
2020-04-25 21:32:55 +00:00
|
|
|
with patch("luftdaten.Luftdaten.get_data", return_value=True), patch(
|
|
|
|
"luftdaten.Luftdaten.validate_sensor", return_value=True
|
2019-07-31 19:25:30 +00:00
|
|
|
):
|
2021-12-19 11:42:52 +00:00
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
user_input={
|
|
|
|
CONF_SENSOR_ID: 12345,
|
2021-12-22 12:00:51 +00:00
|
|
|
CONF_SHOW_ON_MAP: True,
|
2021-12-19 11:42:52 +00:00
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
assert result2.get("type") == RESULT_TYPE_CREATE_ENTRY
|
|
|
|
assert result2.get("title") == "12345"
|
|
|
|
assert result2.get("data") == {
|
|
|
|
CONF_SENSOR_ID: 12345,
|
2021-12-22 12:00:51 +00:00
|
|
|
CONF_SHOW_ON_MAP: True,
|
2021-12-19 11:42:52 +00:00
|
|
|
}
|