Add prusalink test cases and fix config flow (#77544)

pull/77551/head^2
Paulus Schoutsen 2022-08-30 11:04:14 -04:00 committed by GitHub
parent b0a05530b0
commit c11925f7a9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 69 additions and 16 deletions

View File

@ -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

View File

@ -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

View File

@ -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(

View File

@ -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"