Refactor AdGuard config flow tests (#50566)
This commit is contained in:
parent
ca2b3fcc9e
commit
42df6750e2
1 changed files with 65 additions and 48 deletions
|
@ -2,8 +2,8 @@
|
||||||
import aiohttp
|
import aiohttp
|
||||||
|
|
||||||
from homeassistant import config_entries, data_entry_flow
|
from homeassistant import config_entries, data_entry_flow
|
||||||
from homeassistant.components.adguard import config_flow
|
|
||||||
from homeassistant.components.adguard.const import DOMAIN
|
from homeassistant.components.adguard.const import DOMAIN
|
||||||
|
from homeassistant.config_entries import SOURCE_USER
|
||||||
from homeassistant.const import (
|
from homeassistant.const import (
|
||||||
CONF_HOST,
|
CONF_HOST,
|
||||||
CONF_PASSWORD,
|
CONF_PASSWORD,
|
||||||
|
@ -30,9 +30,9 @@ FIXTURE_USER_INPUT = {
|
||||||
|
|
||||||
async def test_show_authenticate_form(hass: HomeAssistant) -> None:
|
async def test_show_authenticate_form(hass: HomeAssistant) -> None:
|
||||||
"""Test that the setup form is served."""
|
"""Test that the setup form is served."""
|
||||||
flow = config_flow.AdGuardHomeFlowHandler()
|
result = await hass.config_entries.flow.async_init(
|
||||||
flow.hass = hass
|
DOMAIN, context={"source": SOURCE_USER}
|
||||||
result = await flow.async_step_user(user_input=None)
|
)
|
||||||
|
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
||||||
assert result["step_id"] == "user"
|
assert result["step_id"] == "user"
|
||||||
|
@ -49,13 +49,14 @@ async def test_connection_error(
|
||||||
exc=aiohttp.ClientError,
|
exc=aiohttp.ClientError,
|
||||||
)
|
)
|
||||||
|
|
||||||
flow = config_flow.AdGuardHomeFlowHandler()
|
result = await hass.config_entries.flow.async_init(
|
||||||
flow.hass = hass
|
DOMAIN, context={"source": SOURCE_USER}, data=FIXTURE_USER_INPUT
|
||||||
result = await flow.async_step_user(user_input=FIXTURE_USER_INPUT)
|
)
|
||||||
|
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
assert result
|
||||||
assert result["step_id"] == "user"
|
assert result.get("type") == data_entry_flow.RESULT_TYPE_FORM
|
||||||
assert result["errors"] == {"base": "cannot_connect"}
|
assert result.get("step_id") == "user"
|
||||||
|
assert result.get("errors") == {"base": "cannot_connect"}
|
||||||
|
|
||||||
|
|
||||||
async def test_full_flow_implementation(
|
async def test_full_flow_implementation(
|
||||||
|
@ -70,21 +71,30 @@ async def test_full_flow_implementation(
|
||||||
headers={"Content-Type": CONTENT_TYPE_JSON},
|
headers={"Content-Type": CONTENT_TYPE_JSON},
|
||||||
)
|
)
|
||||||
|
|
||||||
flow = config_flow.AdGuardHomeFlowHandler()
|
result = await hass.config_entries.flow.async_init(
|
||||||
flow.hass = hass
|
DOMAIN, context={"source": SOURCE_USER}
|
||||||
result = await flow.async_step_user(user_input=None)
|
)
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
|
||||||
assert result["step_id"] == "user"
|
|
||||||
|
|
||||||
result = await flow.async_step_user(user_input=FIXTURE_USER_INPUT)
|
assert result
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
assert result.get("flow_id")
|
||||||
assert result["title"] == FIXTURE_USER_INPUT[CONF_HOST]
|
assert result.get("type") == data_entry_flow.RESULT_TYPE_FORM
|
||||||
assert result["data"][CONF_HOST] == FIXTURE_USER_INPUT[CONF_HOST]
|
assert result.get("step_id") == "user"
|
||||||
assert result["data"][CONF_PASSWORD] == FIXTURE_USER_INPUT[CONF_PASSWORD]
|
|
||||||
assert result["data"][CONF_PORT] == FIXTURE_USER_INPUT[CONF_PORT]
|
result2 = await hass.config_entries.flow.async_configure(
|
||||||
assert result["data"][CONF_SSL] == FIXTURE_USER_INPUT[CONF_SSL]
|
result["flow_id"], user_input=FIXTURE_USER_INPUT
|
||||||
assert result["data"][CONF_USERNAME] == FIXTURE_USER_INPUT[CONF_USERNAME]
|
)
|
||||||
assert result["data"][CONF_VERIFY_SSL] == FIXTURE_USER_INPUT[CONF_VERIFY_SSL]
|
assert result2
|
||||||
|
assert result2.get("type") == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
||||||
|
assert result2.get("title") == FIXTURE_USER_INPUT[CONF_HOST]
|
||||||
|
|
||||||
|
data = result2.get("data")
|
||||||
|
assert data
|
||||||
|
assert data[CONF_HOST] == FIXTURE_USER_INPUT[CONF_HOST]
|
||||||
|
assert data[CONF_PASSWORD] == FIXTURE_USER_INPUT[CONF_PASSWORD]
|
||||||
|
assert data[CONF_PORT] == FIXTURE_USER_INPUT[CONF_PORT]
|
||||||
|
assert data[CONF_SSL] == FIXTURE_USER_INPUT[CONF_SSL]
|
||||||
|
assert data[CONF_USERNAME] == FIXTURE_USER_INPUT[CONF_USERNAME]
|
||||||
|
assert data[CONF_VERIFY_SSL] == FIXTURE_USER_INPUT[CONF_VERIFY_SSL]
|
||||||
|
|
||||||
|
|
||||||
async def test_integration_already_exists(hass: HomeAssistant) -> None:
|
async def test_integration_already_exists(hass: HomeAssistant) -> None:
|
||||||
|
@ -98,8 +108,9 @@ async def test_integration_already_exists(hass: HomeAssistant) -> None:
|
||||||
data={"host": "mock-adguard", "port": "3000"},
|
data={"host": "mock-adguard", "port": "3000"},
|
||||||
context={"source": config_entries.SOURCE_USER},
|
context={"source": config_entries.SOURCE_USER},
|
||||||
)
|
)
|
||||||
assert result["type"] == "abort"
|
assert result
|
||||||
assert result["reason"] == "already_configured"
|
assert result.get("type") == "abort"
|
||||||
|
assert result.get("reason") == "already_configured"
|
||||||
|
|
||||||
|
|
||||||
async def test_hassio_already_configured(hass: HomeAssistant) -> None:
|
async def test_hassio_already_configured(hass: HomeAssistant) -> None:
|
||||||
|
@ -113,8 +124,9 @@ async def test_hassio_already_configured(hass: HomeAssistant) -> None:
|
||||||
data={"addon": "AdGuard Home Addon", "host": "mock-adguard", "port": "3000"},
|
data={"addon": "AdGuard Home Addon", "host": "mock-adguard", "port": "3000"},
|
||||||
context={"source": config_entries.SOURCE_HASSIO},
|
context={"source": config_entries.SOURCE_HASSIO},
|
||||||
)
|
)
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_ABORT
|
assert result
|
||||||
assert result["reason"] == "already_configured"
|
assert result.get("type") == data_entry_flow.RESULT_TYPE_ABORT
|
||||||
|
assert result.get("reason") == "already_configured"
|
||||||
|
|
||||||
|
|
||||||
async def test_hassio_ignored(hass: HomeAssistant) -> None:
|
async def test_hassio_ignored(hass: HomeAssistant) -> None:
|
||||||
|
@ -128,11 +140,9 @@ async def test_hassio_ignored(hass: HomeAssistant) -> None:
|
||||||
data={"addon": "AdGuard Home Addon", "host": "mock-adguard", "port": "3000"},
|
data={"addon": "AdGuard Home Addon", "host": "mock-adguard", "port": "3000"},
|
||||||
context={"source": config_entries.SOURCE_HASSIO},
|
context={"source": config_entries.SOURCE_HASSIO},
|
||||||
)
|
)
|
||||||
|
assert result
|
||||||
assert "type" in result
|
assert result.get("type") == data_entry_flow.RESULT_TYPE_ABORT
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_ABORT
|
assert result.get("reason") == "already_configured"
|
||||||
assert "reason" in result
|
|
||||||
assert result["reason"] == "already_configured"
|
|
||||||
|
|
||||||
|
|
||||||
async def test_hassio_confirm(
|
async def test_hassio_confirm(
|
||||||
|
@ -150,19 +160,25 @@ async def test_hassio_confirm(
|
||||||
data={"addon": "AdGuard Home Addon", "host": "mock-adguard", "port": 3000},
|
data={"addon": "AdGuard Home Addon", "host": "mock-adguard", "port": 3000},
|
||||||
context={"source": config_entries.SOURCE_HASSIO},
|
context={"source": config_entries.SOURCE_HASSIO},
|
||||||
)
|
)
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
assert result
|
||||||
assert result["step_id"] == "hassio_confirm"
|
assert result.get("type") == data_entry_flow.RESULT_TYPE_FORM
|
||||||
assert result["description_placeholders"] == {"addon": "AdGuard Home Addon"}
|
assert result.get("step_id") == "hassio_confirm"
|
||||||
|
assert result.get("description_placeholders") == {"addon": "AdGuard Home Addon"}
|
||||||
|
|
||||||
result = await hass.config_entries.flow.async_configure(result["flow_id"], {})
|
result2 = await hass.config_entries.flow.async_configure(result["flow_id"], {})
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
|
||||||
assert result["title"] == "AdGuard Home Addon"
|
assert result2
|
||||||
assert result["data"][CONF_HOST] == "mock-adguard"
|
assert result2.get("type") == data_entry_flow.RESULT_TYPE_CREATE_ENTRY
|
||||||
assert result["data"][CONF_PASSWORD] is None
|
assert result2.get("title") == "AdGuard Home Addon"
|
||||||
assert result["data"][CONF_PORT] == 3000
|
|
||||||
assert result["data"][CONF_SSL] is False
|
data = result2.get("data")
|
||||||
assert result["data"][CONF_USERNAME] is None
|
assert data
|
||||||
assert result["data"][CONF_VERIFY_SSL]
|
assert data[CONF_HOST] == "mock-adguard"
|
||||||
|
assert data[CONF_PASSWORD] is None
|
||||||
|
assert data[CONF_PORT] == 3000
|
||||||
|
assert data[CONF_SSL] is False
|
||||||
|
assert data[CONF_USERNAME] is None
|
||||||
|
assert data[CONF_VERIFY_SSL]
|
||||||
|
|
||||||
|
|
||||||
async def test_hassio_connection_error(
|
async def test_hassio_connection_error(
|
||||||
|
@ -181,6 +197,7 @@ async def test_hassio_connection_error(
|
||||||
|
|
||||||
result = await hass.config_entries.flow.async_configure(result["flow_id"], {})
|
result = await hass.config_entries.flow.async_configure(result["flow_id"], {})
|
||||||
|
|
||||||
assert result["type"] == data_entry_flow.RESULT_TYPE_FORM
|
assert result
|
||||||
assert result["step_id"] == "hassio_confirm"
|
assert result.get("type") == data_entry_flow.RESULT_TYPE_FORM
|
||||||
assert result["errors"] == {"base": "cannot_connect"}
|
assert result.get("step_id") == "hassio_confirm"
|
||||||
|
assert result.get("errors") == {"base": "cannot_connect"}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue