"""Test the LaCrosse View initialization.""" from datetime import timedelta from unittest.mock import patch from freezegun.api import FrozenDateTimeFactory from lacrosse_view import HTTPError, LoginError from homeassistant.components.lacrosse_view.const import DOMAIN from homeassistant.config_entries import ConfigEntryState from homeassistant.core import HomeAssistant from . import MOCK_ENTRY_DATA, TEST_SENSOR from tests.common import MockConfigEntry, async_fire_time_changed async def test_unload_entry(hass: HomeAssistant) -> None: """Test the unload entry.""" config_entry = MockConfigEntry(domain=DOMAIN, data=MOCK_ENTRY_DATA) config_entry.add_to_hass(hass) sensor = TEST_SENSOR.model_copy() status = sensor.data sensor.data = None with ( patch("lacrosse_view.LaCrosse.login", return_value=True), patch( "lacrosse_view.LaCrosse.get_devices", return_value=[sensor], ), patch("lacrosse_view.LaCrosse.get_sensor_status", return_value=status), ): assert await hass.config_entries.async_setup(config_entry.entry_id) await hass.async_block_till_done() entries = hass.config_entries.async_entries(DOMAIN) assert entries assert len(entries) == 1 assert entries[0].state is ConfigEntryState.LOADED await hass.config_entries.async_unload(entries[0].entry_id) await hass.async_block_till_done() assert entries[0].state is ConfigEntryState.NOT_LOADED async def test_login_error(hass: HomeAssistant) -> None: """Test login error.""" config_entry = MockConfigEntry(domain=DOMAIN, data=MOCK_ENTRY_DATA) config_entry.add_to_hass(hass) with patch("lacrosse_view.LaCrosse.login", side_effect=LoginError("Test")): assert not await hass.config_entries.async_setup(config_entry.entry_id) await hass.async_block_till_done() entries = hass.config_entries.async_entries(DOMAIN) assert entries assert len(entries) == 1 assert entries[0].state is ConfigEntryState.SETUP_ERROR flows = hass.config_entries.flow.async_progress_by_handler(DOMAIN) assert flows assert len(flows) == 1 assert flows[0]["context"]["source"] == "reauth" async def test_http_error(hass: HomeAssistant) -> None: """Test http error.""" config_entry = MockConfigEntry(domain=DOMAIN, data=MOCK_ENTRY_DATA) config_entry.add_to_hass(hass) with ( patch("lacrosse_view.LaCrosse.login", return_value=True), patch("lacrosse_view.LaCrosse.get_devices", side_effect=HTTPError), ): assert not await hass.config_entries.async_setup(config_entry.entry_id) await hass.async_block_till_done() entries = hass.config_entries.async_entries(DOMAIN) assert entries assert len(entries) == 1 assert entries[0].state is ConfigEntryState.SETUP_RETRY config_entry_2 = MockConfigEntry(domain=DOMAIN, data=MOCK_ENTRY_DATA) config_entry_2.add_to_hass(hass) # Start over, let get_devices succeed but get_sensor_status fail with ( patch("lacrosse_view.LaCrosse.login", return_value=True), patch("lacrosse_view.LaCrosse.get_devices", return_value=[TEST_SENSOR]), patch("lacrosse_view.LaCrosse.get_sensor_status", side_effect=HTTPError), ): assert not await hass.config_entries.async_setup(config_entry_2.entry_id) await hass.async_block_till_done() entries = hass.config_entries.async_entries(DOMAIN) assert entries assert len(entries) == 2 assert entries[1].state is ConfigEntryState.SETUP_RETRY async def test_new_token(hass: HomeAssistant, freezer: FrozenDateTimeFactory) -> None: """Test new token.""" config_entry = MockConfigEntry(domain=DOMAIN, data=MOCK_ENTRY_DATA) config_entry.add_to_hass(hass) sensor = TEST_SENSOR.model_copy() status = sensor.data sensor.data = None with ( patch("lacrosse_view.LaCrosse.login", return_value=True) as login, patch( "lacrosse_view.LaCrosse.get_devices", return_value=[sensor], ), patch("lacrosse_view.LaCrosse.get_sensor_status", return_value=status), ): assert await hass.config_entries.async_setup(config_entry.entry_id) await hass.async_block_till_done() login.assert_called_once() entries = hass.config_entries.async_entries(DOMAIN) assert entries assert len(entries) == 1 assert entries[0].state is ConfigEntryState.LOADED with ( patch("lacrosse_view.LaCrosse.login", return_value=True) as login, patch( "lacrosse_view.LaCrosse.get_devices", return_value=[TEST_SENSOR], ), ): freezer.tick(timedelta(hours=1)) async_fire_time_changed(hass) await hass.async_block_till_done() login.assert_called_once() async def test_failed_token( hass: HomeAssistant, freezer: FrozenDateTimeFactory ) -> None: """Test if a reauth flow occurs when token refresh fails.""" config_entry = MockConfigEntry(domain=DOMAIN, data=MOCK_ENTRY_DATA) config_entry.add_to_hass(hass) sensor = TEST_SENSOR.model_copy() status = sensor.data sensor.data = None with ( patch("lacrosse_view.LaCrosse.login", return_value=True) as login, patch( "lacrosse_view.LaCrosse.get_devices", return_value=[sensor], ), patch("lacrosse_view.LaCrosse.get_sensor_status", return_value=status), ): assert await hass.config_entries.async_setup(config_entry.entry_id) await hass.async_block_till_done() login.assert_called_once() entries = hass.config_entries.async_entries(DOMAIN) assert entries assert len(entries) == 1 assert entries[0].state is ConfigEntryState.LOADED with patch("lacrosse_view.LaCrosse.login", side_effect=LoginError("Test")): freezer.tick(timedelta(hours=1)) async_fire_time_changed(hass) await hass.async_block_till_done() entries = hass.config_entries.async_entries(DOMAIN) assert entries assert len(entries) == 1 assert entries[0].state is ConfigEntryState.LOADED flows = hass.config_entries.flow.async_progress_by_handler(DOMAIN) assert flows assert len(flows) == 1 assert flows[0]["context"]["source"] == "reauth"