mirror of
https://github.com/home-assistant/core.git
synced 2025-12-24 21:06:19 +00:00
Upgrade econet to use new API (#44427)
Co-authored-by: Martin Hjelmare <marhje52@gmail.com>
This commit is contained in:
140
tests/components/econet/test_config_flow.py
Normal file
140
tests/components/econet/test_config_flow.py
Normal file
@@ -0,0 +1,140 @@
|
||||
"""Tests for the Econet component."""
|
||||
from unittest.mock import patch
|
||||
|
||||
from pyeconet.api import EcoNetApiInterface
|
||||
from pyeconet.errors import InvalidCredentialsError, PyeconetError
|
||||
|
||||
from homeassistant.components.econet import DOMAIN
|
||||
from homeassistant.config_entries import SOURCE_USER
|
||||
from homeassistant.const import CONF_EMAIL, CONF_PASSWORD
|
||||
from homeassistant.data_entry_flow import (
|
||||
RESULT_TYPE_ABORT,
|
||||
RESULT_TYPE_CREATE_ENTRY,
|
||||
RESULT_TYPE_FORM,
|
||||
)
|
||||
|
||||
from tests.common import MockConfigEntry
|
||||
|
||||
|
||||
async def test_bad_credentials(hass):
|
||||
"""Test when provided credentials are rejected."""
|
||||
|
||||
result = await hass.config_entries.flow.async_init(
|
||||
DOMAIN, context={"source": SOURCE_USER}
|
||||
)
|
||||
assert result["type"] == RESULT_TYPE_FORM
|
||||
assert result["step_id"] == SOURCE_USER
|
||||
|
||||
with patch(
|
||||
"pyeconet.EcoNetApiInterface.login",
|
||||
side_effect=InvalidCredentialsError(),
|
||||
), patch("homeassistant.components.econet.async_setup", return_value=True), patch(
|
||||
"homeassistant.components.econet.async_setup_entry", return_value=True
|
||||
):
|
||||
result = await hass.config_entries.flow.async_configure(
|
||||
result["flow_id"],
|
||||
user_input={
|
||||
CONF_EMAIL: "admin@localhost.com",
|
||||
CONF_PASSWORD: "password0",
|
||||
},
|
||||
)
|
||||
|
||||
assert result["type"] == RESULT_TYPE_FORM
|
||||
assert result["step_id"] == "user"
|
||||
assert result["errors"] == {
|
||||
"base": "invalid_auth",
|
||||
}
|
||||
|
||||
|
||||
async def test_generic_error_from_library(hass):
|
||||
"""Test when connection fails."""
|
||||
|
||||
result = await hass.config_entries.flow.async_init(
|
||||
DOMAIN, context={"source": SOURCE_USER}
|
||||
)
|
||||
assert result["type"] == RESULT_TYPE_FORM
|
||||
assert result["step_id"] == SOURCE_USER
|
||||
|
||||
with patch(
|
||||
"pyeconet.EcoNetApiInterface.login",
|
||||
side_effect=PyeconetError(),
|
||||
), patch("homeassistant.components.econet.async_setup", return_value=True), patch(
|
||||
"homeassistant.components.econet.async_setup_entry", return_value=True
|
||||
):
|
||||
result = await hass.config_entries.flow.async_configure(
|
||||
result["flow_id"],
|
||||
user_input={
|
||||
CONF_EMAIL: "admin@localhost.com",
|
||||
CONF_PASSWORD: "password0",
|
||||
},
|
||||
)
|
||||
|
||||
assert result["type"] == RESULT_TYPE_FORM
|
||||
assert result["step_id"] == "user"
|
||||
assert result["errors"] == {
|
||||
"base": "cannot_connect",
|
||||
}
|
||||
|
||||
|
||||
async def test_auth_worked(hass):
|
||||
"""Test when provided credentials are accepted."""
|
||||
|
||||
result = await hass.config_entries.flow.async_init(
|
||||
DOMAIN, context={"source": SOURCE_USER}
|
||||
)
|
||||
assert result["type"] == RESULT_TYPE_FORM
|
||||
assert result["step_id"] == SOURCE_USER
|
||||
|
||||
with patch(
|
||||
"pyeconet.EcoNetApiInterface.login",
|
||||
return_value=EcoNetApiInterface,
|
||||
), patch("homeassistant.components.econet.async_setup", return_value=True), patch(
|
||||
"homeassistant.components.econet.async_setup_entry", return_value=True
|
||||
):
|
||||
result = await hass.config_entries.flow.async_configure(
|
||||
result["flow_id"],
|
||||
user_input={
|
||||
CONF_EMAIL: "admin@localhost.com",
|
||||
CONF_PASSWORD: "password0",
|
||||
},
|
||||
)
|
||||
|
||||
assert result["type"] == RESULT_TYPE_CREATE_ENTRY
|
||||
assert result["data"] == {
|
||||
CONF_EMAIL: "admin@localhost.com",
|
||||
CONF_PASSWORD: "password0",
|
||||
}
|
||||
|
||||
|
||||
async def test_already_configured(hass):
|
||||
"""Test when provided credentials are already configured."""
|
||||
config = {
|
||||
CONF_EMAIL: "admin@localhost.com",
|
||||
CONF_PASSWORD: "password0",
|
||||
}
|
||||
MockConfigEntry(
|
||||
domain=DOMAIN, data=config, unique_id="admin@localhost.com"
|
||||
).add_to_hass(hass)
|
||||
|
||||
result = await hass.config_entries.flow.async_init(
|
||||
DOMAIN, context={"source": SOURCE_USER}
|
||||
)
|
||||
assert result["type"] == RESULT_TYPE_FORM
|
||||
assert result["step_id"] == SOURCE_USER
|
||||
|
||||
with patch(
|
||||
"pyeconet.EcoNetApiInterface.login",
|
||||
return_value=EcoNetApiInterface,
|
||||
), patch("homeassistant.components.econet.async_setup", return_value=True), patch(
|
||||
"homeassistant.components.econet.async_setup_entry", return_value=True
|
||||
):
|
||||
result = await hass.config_entries.flow.async_configure(
|
||||
result["flow_id"],
|
||||
user_input={
|
||||
CONF_EMAIL: "admin@localhost.com",
|
||||
CONF_PASSWORD: "password0",
|
||||
},
|
||||
)
|
||||
|
||||
assert result["type"] == RESULT_TYPE_ABORT
|
||||
assert result["reason"] == "already_configured"
|
||||
Reference in New Issue
Block a user