mirror of https://github.com/home-assistant/core
70 lines
2.3 KiB
Python
70 lines
2.3 KiB
Python
"""Test the APSystem setup."""
|
|
|
|
import datetime
|
|
from unittest.mock import AsyncMock
|
|
|
|
from APsystemsEZ1 import InverterReturnedError
|
|
from freezegun.api import FrozenDateTimeFactory
|
|
import pytest
|
|
|
|
from homeassistant.components.apsystems.const import DOMAIN
|
|
from homeassistant.config_entries import ConfigEntryState
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
from . import setup_integration
|
|
|
|
from tests.common import MockConfigEntry, async_fire_time_changed
|
|
|
|
SCAN_INTERVAL = datetime.timedelta(seconds=12)
|
|
|
|
|
|
@pytest.mark.usefixtures("mock_apsystems")
|
|
async def test_load_unload_entry(
|
|
hass: HomeAssistant,
|
|
mock_config_entry: MockConfigEntry,
|
|
) -> None:
|
|
"""Test load and unload entry."""
|
|
await setup_integration(hass, mock_config_entry)
|
|
assert mock_config_entry.state is ConfigEntryState.LOADED
|
|
|
|
await hass.config_entries.async_remove(mock_config_entry.entry_id)
|
|
await hass.async_block_till_done()
|
|
assert mock_config_entry.state is ConfigEntryState.NOT_LOADED
|
|
|
|
|
|
async def test_setup_failed(
|
|
hass: HomeAssistant,
|
|
mock_apsystems: AsyncMock,
|
|
mock_config_entry: MockConfigEntry,
|
|
) -> None:
|
|
"""Test update failed."""
|
|
mock_apsystems.get_device_info.side_effect = TimeoutError
|
|
await setup_integration(hass, mock_config_entry)
|
|
entry = hass.config_entries.async_entries(DOMAIN)[0]
|
|
assert entry.state is ConfigEntryState.SETUP_RETRY
|
|
|
|
|
|
async def test_update(
|
|
hass: HomeAssistant,
|
|
mock_apsystems: AsyncMock,
|
|
mock_config_entry: MockConfigEntry,
|
|
caplog: pytest.LogCaptureFixture,
|
|
freezer: FrozenDateTimeFactory,
|
|
) -> None:
|
|
"""Test update data with an inverter error and recover."""
|
|
await setup_integration(hass, mock_config_entry)
|
|
|
|
assert mock_config_entry.state is ConfigEntryState.LOADED
|
|
assert "Inverter returned an error" not in caplog.text
|
|
mock_apsystems.get_output_data.side_effect = InverterReturnedError
|
|
freezer.tick(SCAN_INTERVAL)
|
|
async_fire_time_changed(hass)
|
|
await hass.async_block_till_done()
|
|
assert "Error fetching APSystems Data data:" in caplog.text
|
|
caplog.clear()
|
|
mock_apsystems.get_output_data.side_effect = None
|
|
freezer.tick(SCAN_INTERVAL)
|
|
async_fire_time_changed(hass)
|
|
await hass.async_block_till_done()
|
|
assert "Fetching APSystems Data data recovered" in caplog.text
|