2020-07-02 00:14:54 +00:00
|
|
|
"""Test the Dexcom config flow."""
|
2021-01-01 21:31:56 +00:00
|
|
|
from unittest.mock import patch
|
|
|
|
|
2020-07-02 00:14:54 +00:00
|
|
|
from pydexcom import AccountError, SessionError
|
|
|
|
|
|
|
|
from homeassistant import config_entries, data_entry_flow, setup
|
|
|
|
from homeassistant.components.dexcom.const import DOMAIN, MG_DL, MMOL_L
|
|
|
|
from homeassistant.const import CONF_UNIT_OF_MEASUREMENT, CONF_USERNAME
|
|
|
|
|
|
|
|
from tests.common import MockConfigEntry
|
|
|
|
from tests.components.dexcom import CONFIG
|
|
|
|
|
|
|
|
|
|
|
|
async def test_form(hass):
|
|
|
|
"""Test we get the form."""
|
|
|
|
await setup.async_setup_component(hass, "persistent_notification", {})
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result["errors"] == {}
|
|
|
|
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.dexcom.config_flow.Dexcom.create_session",
|
|
|
|
return_value="test_session_id",
|
|
|
|
), patch(
|
|
|
|
"homeassistant.components.dexcom.async_setup", return_value=True
|
|
|
|
) as mock_setup, patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.dexcom.async_setup_entry",
|
|
|
|
return_value=True,
|
2020-07-02 00:14:54 +00:00
|
|
|
) as mock_setup_entry:
|
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
2020-08-27 11:56:20 +00:00
|
|
|
result["flow_id"],
|
|
|
|
CONFIG,
|
2020-07-02 00:14:54 +00:00
|
|
|
)
|
2020-10-24 14:20:56 +00:00
|
|
|
await hass.async_block_till_done()
|
2020-07-02 00:14:54 +00:00
|
|
|
|
|
|
|
assert result2["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
|
|
|
assert result2["title"] == CONFIG[CONF_USERNAME]
|
|
|
|
assert result2["data"] == CONFIG
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
|
|
|
|
|
|
|
|
async def test_form_account_error(hass):
|
|
|
|
"""Test we handle account error."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
|
|
|
)
|
|
|
|
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.dexcom.config_flow.Dexcom",
|
|
|
|
side_effect=AccountError,
|
2020-07-02 00:14:54 +00:00
|
|
|
):
|
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
2020-08-27 11:56:20 +00:00
|
|
|
result["flow_id"],
|
|
|
|
CONFIG,
|
2020-07-02 00:14:54 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
assert result2["type"] == data_entry_flow.RESULT_TYPE_FORM
|
2020-10-02 18:48:12 +00:00
|
|
|
assert result2["errors"] == {"base": "invalid_auth"}
|
2020-07-02 00:14:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_form_session_error(hass):
|
|
|
|
"""Test we handle session error."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
|
|
|
)
|
|
|
|
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.dexcom.config_flow.Dexcom",
|
|
|
|
side_effect=SessionError,
|
2020-07-02 00:14:54 +00:00
|
|
|
):
|
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
2020-08-27 11:56:20 +00:00
|
|
|
result["flow_id"],
|
|
|
|
CONFIG,
|
2020-07-02 00:14:54 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
assert result2["type"] == data_entry_flow.RESULT_TYPE_FORM
|
2020-10-02 18:48:12 +00:00
|
|
|
assert result2["errors"] == {"base": "cannot_connect"}
|
2020-07-02 00:14:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_form_unknown_error(hass):
|
|
|
|
"""Test we handle unknown error."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
|
|
|
)
|
|
|
|
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.dexcom.config_flow.Dexcom",
|
|
|
|
side_effect=Exception,
|
2020-07-02 00:14:54 +00:00
|
|
|
):
|
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
2020-08-27 11:56:20 +00:00
|
|
|
result["flow_id"],
|
|
|
|
CONFIG,
|
2020-07-02 00:14:54 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
assert result2["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result2["errors"] == {"base": "unknown"}
|
|
|
|
|
|
|
|
|
|
|
|
async def test_option_flow_default(hass):
|
|
|
|
"""Test config flow options."""
|
2020-08-27 11:56:20 +00:00
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=CONFIG,
|
|
|
|
options=None,
|
|
|
|
)
|
2020-07-02 00:14:54 +00:00
|
|
|
entry.add_to_hass(hass)
|
|
|
|
|
|
|
|
result = await hass.config_entries.options.async_init(entry.entry_id)
|
|
|
|
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == "init"
|
|
|
|
|
|
|
|
result2 = await hass.config_entries.options.async_configure(
|
2020-08-27 11:56:20 +00:00
|
|
|
result["flow_id"],
|
|
|
|
user_input={},
|
2020-07-02 00:14:54 +00:00
|
|
|
)
|
|
|
|
assert result2["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
|
|
|
assert result2["data"] == {
|
|
|
|
CONF_UNIT_OF_MEASUREMENT: MG_DL,
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async def test_option_flow(hass):
|
|
|
|
"""Test config flow options."""
|
|
|
|
entry = MockConfigEntry(
|
2020-08-27 11:56:20 +00:00
|
|
|
domain=DOMAIN,
|
|
|
|
data=CONFIG,
|
|
|
|
options={CONF_UNIT_OF_MEASUREMENT: MG_DL},
|
2020-07-02 00:14:54 +00:00
|
|
|
)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
|
|
|
|
result = await hass.config_entries.options.async_init(entry.entry_id)
|
|
|
|
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
|
|
assert result["step_id"] == "init"
|
|
|
|
|
|
|
|
result = await hass.config_entries.options.async_configure(
|
2020-08-27 11:56:20 +00:00
|
|
|
result["flow_id"],
|
|
|
|
user_input={CONF_UNIT_OF_MEASUREMENT: MMOL_L},
|
2020-07-02 00:14:54 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
|
|
|
assert result["data"] == {
|
|
|
|
CONF_UNIT_OF_MEASUREMENT: MMOL_L,
|
|
|
|
}
|