Strip whitespaces from host in ping config flow (#130970)

pull/131008/head
Jan-Philipp Benecke 2024-11-20 03:57:57 +01:00 committed by GitHub
parent 5daf95ec8f
commit 2a1cdf6ff2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 30 additions and 15 deletions

View File

@ -27,6 +27,12 @@ from .const import CONF_PING_COUNT, DEFAULT_PING_COUNT, DOMAIN
_LOGGER = logging.getLogger(__name__)
def _clean_user_input(user_input: dict[str, Any]) -> dict[str, Any]:
"""Clean up the user input."""
user_input[CONF_HOST] = user_input[CONF_HOST].strip()
return user_input
class PingConfigFlow(ConfigFlow, domain=DOMAIN):
"""Handle a config flow for Ping."""
@ -46,6 +52,7 @@ class PingConfigFlow(ConfigFlow, domain=DOMAIN):
),
)
user_input = _clean_user_input(user_input)
if not is_ip_address(user_input[CONF_HOST]):
self.async_abort(reason="invalid_ip_address")
@ -77,7 +84,7 @@ class OptionsFlowHandler(OptionsFlow):
) -> ConfigFlowResult:
"""Manage the options."""
if user_input is not None:
return self.async_create_entry(title="", data=user_input)
return self.async_create_entry(title="", data=_clean_user_input(user_input))
return self.async_show_form(
step_id="init",

View File

@ -13,11 +13,15 @@ from tests.common import MockConfigEntry
@pytest.mark.parametrize(
("host", "expected_title"),
[("192.618.178.1", "192.618.178.1")],
("host", "expected"),
[
("192.618.178.1", "192.618.178.1"),
(" 192.618.178.1 ", "192.618.178.1"),
(" demo.host ", "demo.host"),
],
)
@pytest.mark.usefixtures("patch_setup")
async def test_form(hass: HomeAssistant, host, expected_title) -> None:
async def test_form(hass: HomeAssistant, host, expected) -> None:
"""Test we get the form."""
result = await hass.config_entries.flow.async_init(
@ -35,21 +39,25 @@ async def test_form(hass: HomeAssistant, host, expected_title) -> None:
await hass.async_block_till_done()
assert result["type"] is FlowResultType.CREATE_ENTRY
assert result["title"] == expected_title
assert result["title"] == expected
assert result["data"] == {}
assert result["options"] == {
"count": 5,
"host": host,
"host": expected,
"consider_home": 180,
}
@pytest.mark.parametrize(
("host", "count", "expected_title"),
[("192.618.178.1", 10, "192.618.178.1")],
("host", "expected_host"),
[
("192.618.178.1", "192.618.178.1"),
(" 192.618.178.1 ", "192.618.178.1"),
(" demo.host ", "demo.host"),
],
)
@pytest.mark.usefixtures("patch_setup")
async def test_options(hass: HomeAssistant, host, count, expected_title) -> None:
async def test_options(hass: HomeAssistant, host: str, expected_host: str) -> None:
"""Test options flow."""
config_entry = MockConfigEntry(
@ -57,8 +65,8 @@ async def test_options(hass: HomeAssistant, host, count, expected_title) -> None
source=config_entries.SOURCE_USER,
data={},
domain=DOMAIN,
options={"count": count, "host": host, "consider_home": 180},
title=expected_title,
options={"count": 1, "host": "192.168.1.1", "consider_home": 180},
title="192.168.1.1",
)
config_entry.add_to_hass(hass)
@ -72,15 +80,15 @@ async def test_options(hass: HomeAssistant, host, count, expected_title) -> None
result = await hass.config_entries.options.async_configure(
result["flow_id"],
{
"host": "10.10.10.1",
"count": count,
"host": host,
"count": 10,
},
)
await hass.async_block_till_done()
assert result["type"] is FlowResultType.CREATE_ENTRY
assert result["data"] == {
"count": count,
"host": "10.10.10.1",
"count": 10,
"host": expected_host,
"consider_home": 180,
}