mirror of
https://github.com/home-assistant/core.git
synced 2025-07-22 04:37:06 +00:00
Small test improvements to Tailwind tests (#133051)
This commit is contained in:
parent
dc18e62e1e
commit
f05d18ea70
@ -1,89 +0,0 @@
|
|||||||
# serializer version: 1
|
|
||||||
# name: test_user_flow
|
|
||||||
FlowResultSnapshot({
|
|
||||||
'context': dict({
|
|
||||||
'source': 'user',
|
|
||||||
'unique_id': '3c:e9:0e:6d:21:84',
|
|
||||||
}),
|
|
||||||
'data': dict({
|
|
||||||
'host': '127.0.0.1',
|
|
||||||
'token': '987654',
|
|
||||||
}),
|
|
||||||
'description': None,
|
|
||||||
'description_placeholders': None,
|
|
||||||
'flow_id': <ANY>,
|
|
||||||
'handler': 'tailwind',
|
|
||||||
'minor_version': 1,
|
|
||||||
'options': dict({
|
|
||||||
}),
|
|
||||||
'result': ConfigEntrySnapshot({
|
|
||||||
'data': dict({
|
|
||||||
'host': '127.0.0.1',
|
|
||||||
'token': '987654',
|
|
||||||
}),
|
|
||||||
'disabled_by': None,
|
|
||||||
'discovery_keys': dict({
|
|
||||||
}),
|
|
||||||
'domain': 'tailwind',
|
|
||||||
'entry_id': <ANY>,
|
|
||||||
'minor_version': 1,
|
|
||||||
'options': dict({
|
|
||||||
}),
|
|
||||||
'pref_disable_new_entities': False,
|
|
||||||
'pref_disable_polling': False,
|
|
||||||
'source': 'user',
|
|
||||||
'title': 'Tailwind iQ3',
|
|
||||||
'unique_id': '3c:e9:0e:6d:21:84',
|
|
||||||
'version': 1,
|
|
||||||
}),
|
|
||||||
'title': 'Tailwind iQ3',
|
|
||||||
'type': <FlowResultType.CREATE_ENTRY: 'create_entry'>,
|
|
||||||
'version': 1,
|
|
||||||
})
|
|
||||||
# ---
|
|
||||||
# name: test_zeroconf_flow
|
|
||||||
FlowResultSnapshot({
|
|
||||||
'context': dict({
|
|
||||||
'configuration_url': 'https://web.gotailwind.com/client/integration/local-control-key',
|
|
||||||
'source': 'zeroconf',
|
|
||||||
'title_placeholders': dict({
|
|
||||||
'name': 'Tailwind iQ3',
|
|
||||||
}),
|
|
||||||
'unique_id': '3c:e9:0e:6d:21:84',
|
|
||||||
}),
|
|
||||||
'data': dict({
|
|
||||||
'host': '127.0.0.1',
|
|
||||||
'token': '987654',
|
|
||||||
}),
|
|
||||||
'description': None,
|
|
||||||
'description_placeholders': None,
|
|
||||||
'flow_id': <ANY>,
|
|
||||||
'handler': 'tailwind',
|
|
||||||
'minor_version': 1,
|
|
||||||
'options': dict({
|
|
||||||
}),
|
|
||||||
'result': ConfigEntrySnapshot({
|
|
||||||
'data': dict({
|
|
||||||
'host': '127.0.0.1',
|
|
||||||
'token': '987654',
|
|
||||||
}),
|
|
||||||
'disabled_by': None,
|
|
||||||
'discovery_keys': dict({
|
|
||||||
}),
|
|
||||||
'domain': 'tailwind',
|
|
||||||
'entry_id': <ANY>,
|
|
||||||
'minor_version': 1,
|
|
||||||
'options': dict({
|
|
||||||
}),
|
|
||||||
'pref_disable_new_entities': False,
|
|
||||||
'pref_disable_polling': False,
|
|
||||||
'source': 'zeroconf',
|
|
||||||
'title': 'Tailwind iQ3',
|
|
||||||
'unique_id': '3c:e9:0e:6d:21:84',
|
|
||||||
'version': 1,
|
|
||||||
}),
|
|
||||||
'title': 'Tailwind iQ3',
|
|
||||||
'type': <FlowResultType.CREATE_ENTRY: 'create_entry'>,
|
|
||||||
'version': 1,
|
|
||||||
})
|
|
||||||
# ---
|
|
@ -25,20 +25,17 @@ pytestmark = pytest.mark.usefixtures("mock_setup_entry")
|
|||||||
|
|
||||||
|
|
||||||
@pytest.mark.usefixtures("mock_tailwind")
|
@pytest.mark.usefixtures("mock_tailwind")
|
||||||
async def test_user_flow(
|
async def test_user_flow(hass: HomeAssistant) -> None:
|
||||||
hass: HomeAssistant,
|
|
||||||
snapshot: SnapshotAssertion,
|
|
||||||
) -> None:
|
|
||||||
"""Test the full happy path user flow from start to finish."""
|
"""Test the full happy path user flow from start to finish."""
|
||||||
result = await hass.config_entries.flow.async_init(
|
result = await hass.config_entries.flow.async_init(
|
||||||
DOMAIN,
|
DOMAIN,
|
||||||
context={"source": SOURCE_USER},
|
context={"source": SOURCE_USER},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("type") is FlowResultType.FORM
|
assert result["type"] is FlowResultType.FORM
|
||||||
assert result.get("step_id") == "user"
|
assert result["step_id"] == "user"
|
||||||
|
|
||||||
result2 = await hass.config_entries.flow.async_configure(
|
result = await hass.config_entries.flow.async_configure(
|
||||||
result["flow_id"],
|
result["flow_id"],
|
||||||
user_input={
|
user_input={
|
||||||
CONF_HOST: "127.0.0.1",
|
CONF_HOST: "127.0.0.1",
|
||||||
@ -46,8 +43,15 @@ async def test_user_flow(
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result2.get("type") is FlowResultType.CREATE_ENTRY
|
assert result["type"] is FlowResultType.CREATE_ENTRY
|
||||||
assert result2 == snapshot
|
|
||||||
|
config_entry = result["result"]
|
||||||
|
assert config_entry.unique_id == "3c:e9:0e:6d:21:84"
|
||||||
|
assert config_entry.data == {
|
||||||
|
CONF_HOST: "127.0.0.1",
|
||||||
|
CONF_TOKEN: "987654",
|
||||||
|
}
|
||||||
|
assert not config_entry.options
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
@ -76,19 +80,27 @@ async def test_user_flow_errors(
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("type") is FlowResultType.FORM
|
assert result["type"] is FlowResultType.FORM
|
||||||
assert result.get("step_id") == "user"
|
assert result["step_id"] == "user"
|
||||||
assert result.get("errors") == expected_error
|
assert result["errors"] == expected_error
|
||||||
|
|
||||||
mock_tailwind.status.side_effect = None
|
mock_tailwind.status.side_effect = None
|
||||||
result2 = await hass.config_entries.flow.async_configure(
|
result = await hass.config_entries.flow.async_configure(
|
||||||
result["flow_id"],
|
result["flow_id"],
|
||||||
user_input={
|
user_input={
|
||||||
CONF_HOST: "127.0.0.2",
|
CONF_HOST: "127.0.0.2",
|
||||||
CONF_TOKEN: "123456",
|
CONF_TOKEN: "123456",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
assert result2.get("type") is FlowResultType.CREATE_ENTRY
|
assert result["type"] is FlowResultType.CREATE_ENTRY
|
||||||
|
|
||||||
|
config_entry = result["result"]
|
||||||
|
assert config_entry.unique_id == "3c:e9:0e:6d:21:84"
|
||||||
|
assert config_entry.data == {
|
||||||
|
CONF_HOST: "127.0.0.2",
|
||||||
|
CONF_TOKEN: "123456",
|
||||||
|
}
|
||||||
|
assert not config_entry.options
|
||||||
|
|
||||||
|
|
||||||
async def test_user_flow_unsupported_firmware_version(
|
async def test_user_flow_unsupported_firmware_version(
|
||||||
@ -105,8 +117,8 @@ async def test_user_flow_unsupported_firmware_version(
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("type") is FlowResultType.ABORT
|
assert result["type"] is FlowResultType.ABORT
|
||||||
assert result.get("reason") == "unsupported_firmware"
|
assert result["reason"] == "unsupported_firmware"
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.usefixtures("mock_tailwind")
|
@pytest.mark.usefixtures("mock_tailwind")
|
||||||
@ -129,8 +141,8 @@ async def test_user_flow_already_configured(
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("type") is FlowResultType.ABORT
|
assert result["type"] is FlowResultType.ABORT
|
||||||
assert result.get("reason") == "already_configured"
|
assert result["reason"] == "already_configured"
|
||||||
assert mock_config_entry.data[CONF_HOST] == "127.0.0.1"
|
assert mock_config_entry.data[CONF_HOST] == "127.0.0.1"
|
||||||
assert mock_config_entry.data[CONF_TOKEN] == "987654"
|
assert mock_config_entry.data[CONF_TOKEN] == "987654"
|
||||||
|
|
||||||
@ -160,19 +172,26 @@ async def test_zeroconf_flow(
|
|||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("step_id") == "zeroconf_confirm"
|
assert result["step_id"] == "zeroconf_confirm"
|
||||||
assert result.get("type") is FlowResultType.FORM
|
assert result["type"] is FlowResultType.FORM
|
||||||
|
|
||||||
progress = hass.config_entries.flow.async_progress()
|
progress = hass.config_entries.flow.async_progress()
|
||||||
assert len(progress) == 1
|
assert len(progress) == 1
|
||||||
assert progress[0].get("flow_id") == result["flow_id"]
|
assert progress[0].get("flow_id") == result["flow_id"]
|
||||||
|
|
||||||
result2 = await hass.config_entries.flow.async_configure(
|
result = await hass.config_entries.flow.async_configure(
|
||||||
result["flow_id"], user_input={CONF_TOKEN: "987654"}
|
result["flow_id"], user_input={CONF_TOKEN: "987654"}
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result2.get("type") is FlowResultType.CREATE_ENTRY
|
assert result["type"] is FlowResultType.CREATE_ENTRY
|
||||||
assert result2 == snapshot
|
|
||||||
|
config_entry = result["result"]
|
||||||
|
assert config_entry.unique_id == "3c:e9:0e:6d:21:84"
|
||||||
|
assert config_entry.data == {
|
||||||
|
CONF_HOST: "127.0.0.1",
|
||||||
|
CONF_TOKEN: "987654",
|
||||||
|
}
|
||||||
|
assert not config_entry.options
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
@ -200,8 +219,8 @@ async def test_zeroconf_flow_abort_incompatible_properties(
|
|||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("type") is FlowResultType.ABORT
|
assert result["type"] is FlowResultType.ABORT
|
||||||
assert result.get("reason") == expected_reason
|
assert result["reason"] == expected_reason
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
@ -240,25 +259,33 @@ async def test_zeroconf_flow_errors(
|
|||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
result2 = await hass.config_entries.flow.async_configure(
|
result = await hass.config_entries.flow.async_configure(
|
||||||
result["flow_id"],
|
result["flow_id"],
|
||||||
user_input={
|
user_input={
|
||||||
CONF_TOKEN: "123456",
|
CONF_TOKEN: "123456",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result2.get("type") is FlowResultType.FORM
|
assert result["type"] is FlowResultType.FORM
|
||||||
assert result2.get("step_id") == "zeroconf_confirm"
|
assert result["step_id"] == "zeroconf_confirm"
|
||||||
assert result2.get("errors") == expected_error
|
assert result["errors"] == expected_error
|
||||||
|
|
||||||
mock_tailwind.status.side_effect = None
|
mock_tailwind.status.side_effect = None
|
||||||
result3 = await hass.config_entries.flow.async_configure(
|
result = await hass.config_entries.flow.async_configure(
|
||||||
result["flow_id"],
|
result["flow_id"],
|
||||||
user_input={
|
user_input={
|
||||||
CONF_TOKEN: "123456",
|
CONF_TOKEN: "123456",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
assert result3.get("type") is FlowResultType.CREATE_ENTRY
|
assert result["type"] is FlowResultType.CREATE_ENTRY
|
||||||
|
|
||||||
|
config_entry = result["result"]
|
||||||
|
assert config_entry.unique_id == "3c:e9:0e:6d:21:84"
|
||||||
|
assert config_entry.data == {
|
||||||
|
CONF_HOST: "127.0.0.1",
|
||||||
|
CONF_TOKEN: "123456",
|
||||||
|
}
|
||||||
|
assert not config_entry.options
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.usefixtures("mock_tailwind")
|
@pytest.mark.usefixtures("mock_tailwind")
|
||||||
@ -292,8 +319,8 @@ async def test_zeroconf_flow_not_discovered_again(
|
|||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("type") is FlowResultType.ABORT
|
assert result["type"] is FlowResultType.ABORT
|
||||||
assert result.get("reason") == "already_configured"
|
assert result["reason"] == "already_configured"
|
||||||
assert mock_config_entry.data[CONF_HOST] == "127.0.0.1"
|
assert mock_config_entry.data[CONF_HOST] == "127.0.0.1"
|
||||||
|
|
||||||
|
|
||||||
@ -307,17 +334,17 @@ async def test_reauth_flow(
|
|||||||
assert mock_config_entry.data[CONF_TOKEN] == "123456"
|
assert mock_config_entry.data[CONF_TOKEN] == "123456"
|
||||||
|
|
||||||
result = await mock_config_entry.start_reauth_flow(hass)
|
result = await mock_config_entry.start_reauth_flow(hass)
|
||||||
assert result.get("type") is FlowResultType.FORM
|
assert result["type"] is FlowResultType.FORM
|
||||||
assert result.get("step_id") == "reauth_confirm"
|
assert result["step_id"] == "reauth_confirm"
|
||||||
|
|
||||||
result2 = await hass.config_entries.flow.async_configure(
|
result = await hass.config_entries.flow.async_configure(
|
||||||
result["flow_id"],
|
result["flow_id"],
|
||||||
{CONF_TOKEN: "987654"},
|
{CONF_TOKEN: "987654"},
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result2.get("type") is FlowResultType.ABORT
|
assert result["type"] is FlowResultType.ABORT
|
||||||
assert result2.get("reason") == "reauth_successful"
|
assert result["reason"] == "reauth_successful"
|
||||||
|
|
||||||
assert mock_config_entry.data[CONF_TOKEN] == "987654"
|
assert mock_config_entry.data[CONF_TOKEN] == "987654"
|
||||||
|
|
||||||
@ -343,27 +370,27 @@ async def test_reauth_flow_errors(
|
|||||||
|
|
||||||
result = await mock_config_entry.start_reauth_flow(hass)
|
result = await mock_config_entry.start_reauth_flow(hass)
|
||||||
|
|
||||||
result2 = await hass.config_entries.flow.async_configure(
|
result = await hass.config_entries.flow.async_configure(
|
||||||
result["flow_id"],
|
result["flow_id"],
|
||||||
user_input={
|
user_input={
|
||||||
CONF_TOKEN: "123456",
|
CONF_TOKEN: "123456",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result2.get("type") is FlowResultType.FORM
|
assert result["type"] is FlowResultType.FORM
|
||||||
assert result2.get("step_id") == "reauth_confirm"
|
assert result["step_id"] == "reauth_confirm"
|
||||||
assert result2.get("errors") == expected_error
|
assert result["errors"] == expected_error
|
||||||
|
|
||||||
mock_tailwind.status.side_effect = None
|
mock_tailwind.status.side_effect = None
|
||||||
result3 = await hass.config_entries.flow.async_configure(
|
result = await hass.config_entries.flow.async_configure(
|
||||||
result["flow_id"],
|
result["flow_id"],
|
||||||
user_input={
|
user_input={
|
||||||
CONF_TOKEN: "123456",
|
CONF_TOKEN: "123456",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result3.get("type") is FlowResultType.ABORT
|
assert result["type"] is FlowResultType.ABORT
|
||||||
assert result3.get("reason") == "reauth_successful"
|
assert result["reason"] == "reauth_successful"
|
||||||
|
|
||||||
|
|
||||||
async def test_dhcp_discovery_updates_entry(
|
async def test_dhcp_discovery_updates_entry(
|
||||||
@ -384,8 +411,8 @@ async def test_dhcp_discovery_updates_entry(
|
|||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("type") is FlowResultType.ABORT
|
assert result["type"] is FlowResultType.ABORT
|
||||||
assert result.get("reason") == "already_configured"
|
assert result["reason"] == "already_configured"
|
||||||
assert mock_config_entry.data[CONF_HOST] == "127.0.0.1"
|
assert mock_config_entry.data[CONF_HOST] == "127.0.0.1"
|
||||||
|
|
||||||
|
|
||||||
@ -404,5 +431,5 @@ async def test_dhcp_discovery_ignores_unknown(hass: HomeAssistant) -> None:
|
|||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
assert result.get("type") is FlowResultType.ABORT
|
assert result["type"] is FlowResultType.ABORT
|
||||||
assert result.get("reason") == "unknown"
|
assert result["reason"] == "unknown"
|
||||||
|
@ -66,8 +66,8 @@ async def test_config_entry_authentication_failed(
|
|||||||
assert len(flows) == 1
|
assert len(flows) == 1
|
||||||
|
|
||||||
flow = flows[0]
|
flow = flows[0]
|
||||||
assert flow.get("step_id") == "reauth_confirm"
|
assert flow["step_id"] == "reauth_confirm"
|
||||||
assert flow.get("handler") == DOMAIN
|
assert flow["handler"] == DOMAIN
|
||||||
|
|
||||||
assert "context" in flow
|
assert "context" in flow
|
||||||
assert flow["context"].get("source") == SOURCE_REAUTH
|
assert flow["context"].get("source") == SOURCE_REAUTH
|
||||||
|
Loading…
x
Reference in New Issue
Block a user