mirror of
https://github.com/home-assistant/core.git
synced 2026-05-30 12:14:20 +01:00
cca6965cd1
Co-authored-by: Robert Resch <robert@resch.dev>
149 lines
4.2 KiB
Python
149 lines
4.2 KiB
Python
"""The tests for evohome."""
|
|
|
|
from __future__ import annotations
|
|
|
|
from http import HTTPStatus
|
|
import logging
|
|
from unittest.mock import patch
|
|
|
|
from evohomeasync2 import exceptions as exc
|
|
from evohomeasync2.broker import _ERR_MSG_LOOKUP_AUTH, _ERR_MSG_LOOKUP_BASE
|
|
from freezegun.api import FrozenDateTimeFactory
|
|
import pytest
|
|
from syrupy import SnapshotAssertion
|
|
|
|
from homeassistant.components.evohome import DOMAIN
|
|
from homeassistant.core import HomeAssistant
|
|
from homeassistant.setup import async_setup_component
|
|
|
|
from .conftest import setup_evohome
|
|
from .const import TEST_INSTALLS
|
|
|
|
|
|
@pytest.mark.parametrize("install", [*TEST_INSTALLS, "botched"])
|
|
async def test_entities(
|
|
hass: HomeAssistant,
|
|
config: dict[str, str],
|
|
install: str,
|
|
snapshot: SnapshotAssertion,
|
|
freezer: FrozenDateTimeFactory,
|
|
) -> None:
|
|
"""Test entities and state after setup of a Honeywell TCC-compatible system."""
|
|
|
|
# some extended state attrs are relative the current time
|
|
freezer.move_to("2024-07-10T12:00:00Z")
|
|
|
|
async for _ in setup_evohome(hass, config, install=install):
|
|
pass
|
|
|
|
assert hass.states.async_all() == snapshot
|
|
|
|
|
|
SETUP_FAILED_ANTICIPATED = (
|
|
"homeassistant.setup",
|
|
logging.ERROR,
|
|
"Setup failed for 'evohome': Integration failed to initialize.",
|
|
)
|
|
SETUP_FAILED_UNEXPECTED = (
|
|
"homeassistant.setup",
|
|
logging.ERROR,
|
|
"Error during setup of component evohome",
|
|
)
|
|
AUTHENTICATION_FAILED = (
|
|
"homeassistant.components.evohome.helpers",
|
|
logging.ERROR,
|
|
"Failed to authenticate with the vendor's server. Check your username"
|
|
" and password. NB: Some special password characters that work"
|
|
" correctly via the website will not work via the web API. Message"
|
|
" is: ",
|
|
)
|
|
REQUEST_FAILED_NONE = (
|
|
"homeassistant.components.evohome.helpers",
|
|
logging.WARNING,
|
|
"Unable to connect with the vendor's server. "
|
|
"Check your network and the vendor's service status page. "
|
|
"Message is: ",
|
|
)
|
|
REQUEST_FAILED_503 = (
|
|
"homeassistant.components.evohome.helpers",
|
|
logging.WARNING,
|
|
"The vendor says their server is currently unavailable. "
|
|
"Check the vendor's service status page",
|
|
)
|
|
REQUEST_FAILED_429 = (
|
|
"homeassistant.components.evohome.helpers",
|
|
logging.WARNING,
|
|
"The vendor's API rate limit has been exceeded. "
|
|
"If this message persists, consider increasing the scan_interval",
|
|
)
|
|
|
|
REQUEST_FAILED_LOOKUP = {
|
|
None: [
|
|
REQUEST_FAILED_NONE,
|
|
SETUP_FAILED_ANTICIPATED,
|
|
],
|
|
HTTPStatus.SERVICE_UNAVAILABLE: [
|
|
REQUEST_FAILED_503,
|
|
SETUP_FAILED_ANTICIPATED,
|
|
],
|
|
HTTPStatus.TOO_MANY_REQUESTS: [
|
|
REQUEST_FAILED_429,
|
|
SETUP_FAILED_ANTICIPATED,
|
|
],
|
|
}
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"status", [*sorted([*_ERR_MSG_LOOKUP_AUTH, HTTPStatus.BAD_GATEWAY]), None]
|
|
)
|
|
async def test_authentication_failure_v2(
|
|
hass: HomeAssistant,
|
|
config: dict[str, str],
|
|
status: HTTPStatus,
|
|
caplog: pytest.LogCaptureFixture,
|
|
) -> None:
|
|
"""Test failure to setup an evohome-compatible system.
|
|
|
|
In this instance, the failure occurs in the v2 API.
|
|
"""
|
|
|
|
with patch("evohomeasync2.broker.Broker.get") as mock_fcn:
|
|
mock_fcn.side_effect = exc.AuthenticationFailed("", status=status)
|
|
|
|
with caplog.at_level(logging.WARNING):
|
|
result = await async_setup_component(hass, DOMAIN, {DOMAIN: config})
|
|
|
|
assert result is False
|
|
|
|
assert caplog.record_tuples == [
|
|
AUTHENTICATION_FAILED,
|
|
SETUP_FAILED_ANTICIPATED,
|
|
]
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"status", [*sorted([*_ERR_MSG_LOOKUP_BASE, HTTPStatus.BAD_GATEWAY]), None]
|
|
)
|
|
async def test_client_request_failure_v2(
|
|
hass: HomeAssistant,
|
|
config: dict[str, str],
|
|
status: HTTPStatus,
|
|
caplog: pytest.LogCaptureFixture,
|
|
) -> None:
|
|
"""Test failure to setup an evohome-compatible system.
|
|
|
|
In this instance, the failure occurs in the v2 API.
|
|
"""
|
|
|
|
with patch("evohomeasync2.broker.Broker.get") as mock_fcn:
|
|
mock_fcn.side_effect = exc.RequestFailed("", status=status)
|
|
|
|
with caplog.at_level(logging.WARNING):
|
|
result = await async_setup_component(hass, DOMAIN, {DOMAIN: config})
|
|
|
|
assert result is False
|
|
|
|
assert caplog.record_tuples == REQUEST_FAILED_LOOKUP.get(
|
|
status, [SETUP_FAILED_UNEXPECTED]
|
|
)
|