Add prusalink test cases and fix config flow (#77544)
parent
b0a05530b0
commit
c11925f7a9
|
@ -22,18 +22,9 @@ from .const import DOMAIN
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
def add_protocol(value: str) -> str:
|
|
||||||
"""Validate URL has a scheme."""
|
|
||||||
value = value.rstrip("/")
|
|
||||||
if value.startswith(("http://", "https://")):
|
|
||||||
return value
|
|
||||||
|
|
||||||
return f"http://{value}"
|
|
||||||
|
|
||||||
|
|
||||||
STEP_USER_DATA_SCHEMA = vol.Schema(
|
STEP_USER_DATA_SCHEMA = vol.Schema(
|
||||||
{
|
{
|
||||||
vol.Required("host"): vol.All(str, add_protocol),
|
vol.Required("host"): str,
|
||||||
vol.Required("api_key"): str,
|
vol.Required("api_key"): str,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
@ -77,10 +68,18 @@ class ConfigFlow(config_entries.ConfigFlow, domain=DOMAIN):
|
||||||
step_id="user", data_schema=STEP_USER_DATA_SCHEMA
|
step_id="user", data_schema=STEP_USER_DATA_SCHEMA
|
||||||
)
|
)
|
||||||
|
|
||||||
|
host = user_input["host"].rstrip("/")
|
||||||
|
if not host.startswith(("http://", "https://")):
|
||||||
|
host = f"http://{host}"
|
||||||
|
|
||||||
|
data = {
|
||||||
|
"host": host,
|
||||||
|
"api_key": user_input["api_key"],
|
||||||
|
}
|
||||||
errors = {}
|
errors = {}
|
||||||
|
|
||||||
try:
|
try:
|
||||||
info = await validate_input(self.hass, user_input)
|
info = await validate_input(self.hass, data)
|
||||||
except CannotConnect:
|
except CannotConnect:
|
||||||
errors["base"] = "cannot_connect"
|
errors["base"] = "cannot_connect"
|
||||||
except NotSupported:
|
except NotSupported:
|
||||||
|
@ -91,7 +90,7 @@ class ConfigFlow(config_entries.ConfigFlow, domain=DOMAIN):
|
||||||
_LOGGER.exception("Unexpected exception")
|
_LOGGER.exception("Unexpected exception")
|
||||||
errors["base"] = "unknown"
|
errors["base"] = "unknown"
|
||||||
else:
|
else:
|
||||||
return self.async_create_entry(title=info["title"], data=user_input)
|
return self.async_create_entry(title=info["title"], data=data)
|
||||||
|
|
||||||
return self.async_show_form(
|
return self.async_show_form(
|
||||||
step_id="user", data_schema=STEP_USER_DATA_SCHEMA, errors=errors
|
step_id="user", data_schema=STEP_USER_DATA_SCHEMA, errors=errors
|
||||||
|
|
|
@ -20,6 +20,7 @@ async def test_camera_no_job(
|
||||||
hass: HomeAssistant,
|
hass: HomeAssistant,
|
||||||
mock_config_entry,
|
mock_config_entry,
|
||||||
mock_api,
|
mock_api,
|
||||||
|
hass_client,
|
||||||
) -> None:
|
) -> None:
|
||||||
"""Test sensors while no job active."""
|
"""Test sensors while no job active."""
|
||||||
assert await async_setup_component(hass, "prusalink", {})
|
assert await async_setup_component(hass, "prusalink", {})
|
||||||
|
@ -27,6 +28,10 @@ async def test_camera_no_job(
|
||||||
assert state is not None
|
assert state is not None
|
||||||
assert state.state == "unavailable"
|
assert state.state == "unavailable"
|
||||||
|
|
||||||
|
client = await hass_client()
|
||||||
|
resp = await client.get("/api/camera_proxy/camera.mock_title_job_preview")
|
||||||
|
assert resp.status == 500
|
||||||
|
|
||||||
|
|
||||||
async def test_camera_active_job(
|
async def test_camera_active_job(
|
||||||
hass: HomeAssistant, mock_config_entry, mock_api, mock_job_api_active, hass_client
|
hass: HomeAssistant, mock_config_entry, mock_api, mock_job_api_active, hass_client
|
||||||
|
|
|
@ -83,8 +83,8 @@ async def test_form_unknown(hass: HomeAssistant) -> None:
|
||||||
assert result2["errors"] == {"base": "unknown"}
|
assert result2["errors"] == {"base": "unknown"}
|
||||||
|
|
||||||
|
|
||||||
async def test_form_invalid_version(hass: HomeAssistant, mock_version_api) -> None:
|
async def test_form_too_low_version(hass: HomeAssistant, mock_version_api) -> None:
|
||||||
"""Test we handle invalid auth."""
|
"""Test we handle too low API version."""
|
||||||
result = await hass.config_entries.flow.async_init(
|
result = await hass.config_entries.flow.async_init(
|
||||||
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
||||||
)
|
)
|
||||||
|
@ -103,6 +103,26 @@ async def test_form_invalid_version(hass: HomeAssistant, mock_version_api) -> No
|
||||||
assert result2["errors"] == {"base": "not_supported"}
|
assert result2["errors"] == {"base": "not_supported"}
|
||||||
|
|
||||||
|
|
||||||
|
async def test_form_invalid_version_2(hass: HomeAssistant, mock_version_api) -> None:
|
||||||
|
"""Test we handle invalid version."""
|
||||||
|
result = await hass.config_entries.flow.async_init(
|
||||||
|
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
||||||
|
)
|
||||||
|
|
||||||
|
mock_version_api["api"] = "i am not a version"
|
||||||
|
|
||||||
|
result2 = await hass.config_entries.flow.async_configure(
|
||||||
|
result["flow_id"],
|
||||||
|
{
|
||||||
|
"host": "1.1.1.1",
|
||||||
|
"api_key": "abcdefg",
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
assert result2["type"] == FlowResultType.FORM
|
||||||
|
assert result2["errors"] == {"base": "not_supported"}
|
||||||
|
|
||||||
|
|
||||||
async def test_form_cannot_connect(hass: HomeAssistant) -> None:
|
async def test_form_cannot_connect(hass: HomeAssistant) -> None:
|
||||||
"""Test we handle cannot connect error."""
|
"""Test we handle cannot connect error."""
|
||||||
result = await hass.config_entries.flow.async_init(
|
result = await hass.config_entries.flow.async_init(
|
||||||
|
|
|
@ -1,16 +1,23 @@
|
||||||
"""Test setting up and unloading PrusaLink."""
|
"""Test setting up and unloading PrusaLink."""
|
||||||
|
from datetime import timedelta
|
||||||
|
from unittest.mock import patch
|
||||||
|
|
||||||
|
from pyprusalink import InvalidAuth, PrusaLinkError
|
||||||
|
import pytest
|
||||||
|
|
||||||
from homeassistant.config_entries import ConfigEntry, ConfigEntryState
|
from homeassistant.config_entries import ConfigEntry, ConfigEntryState
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
|
from homeassistant.util.dt import utcnow
|
||||||
|
|
||||||
|
from tests.common import async_fire_time_changed
|
||||||
|
|
||||||
|
|
||||||
async def test_sensors_no_job(
|
async def test_unloading(
|
||||||
hass: HomeAssistant,
|
hass: HomeAssistant,
|
||||||
mock_config_entry: ConfigEntry,
|
mock_config_entry: ConfigEntry,
|
||||||
mock_api,
|
mock_api,
|
||||||
):
|
):
|
||||||
"""Test sensors while no job active."""
|
"""Test unloading prusalink."""
|
||||||
assert await hass.config_entries.async_setup(mock_config_entry.entry_id)
|
assert await hass.config_entries.async_setup(mock_config_entry.entry_id)
|
||||||
assert mock_config_entry.state == ConfigEntryState.LOADED
|
assert mock_config_entry.state == ConfigEntryState.LOADED
|
||||||
|
|
||||||
|
@ -21,3 +28,25 @@ async def test_sensors_no_job(
|
||||||
|
|
||||||
for state in hass.states.async_all():
|
for state in hass.states.async_all():
|
||||||
assert state.state == "unavailable"
|
assert state.state == "unavailable"
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.parametrize("exception", [InvalidAuth, PrusaLinkError])
|
||||||
|
async def test_failed_update(
|
||||||
|
hass: HomeAssistant, mock_config_entry: ConfigEntry, mock_api, exception
|
||||||
|
):
|
||||||
|
"""Test failed update marks prusalink unavailable."""
|
||||||
|
assert await hass.config_entries.async_setup(mock_config_entry.entry_id)
|
||||||
|
assert mock_config_entry.state == ConfigEntryState.LOADED
|
||||||
|
|
||||||
|
with patch(
|
||||||
|
"homeassistant.components.prusalink.PrusaLink.get_printer",
|
||||||
|
side_effect=exception,
|
||||||
|
), patch(
|
||||||
|
"homeassistant.components.prusalink.PrusaLink.get_job",
|
||||||
|
side_effect=exception,
|
||||||
|
):
|
||||||
|
async_fire_time_changed(hass, utcnow() + timedelta(seconds=30), fire_all=True)
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
for state in hass.states.async_all():
|
||||||
|
assert state.state == "unavailable"
|
||||||
|
|
Loading…
Reference in New Issue