"""Tests for the Withings component.""" from datetime import timedelta from unittest.mock import AsyncMock, patch from aiowithings import Goals, MeasurementGroup from freezegun.api import FrozenDateTimeFactory import pytest from syrupy import SnapshotAssertion from homeassistant.const import STATE_UNAVAILABLE, Platform from homeassistant.core import HomeAssistant from homeassistant.helpers import entity_registry as er from . import setup_integration from tests.common import ( MockConfigEntry, async_fire_time_changed, load_json_array_fixture, load_json_object_fixture, ) @pytest.mark.usefixtures("entity_registry_enabled_by_default") async def test_all_entities( hass: HomeAssistant, snapshot: SnapshotAssertion, withings: AsyncMock, polling_config_entry: MockConfigEntry, ) -> None: """Test all entities.""" with patch("homeassistant.components.withings.PLATFORMS", [Platform.SENSOR]): await setup_integration(hass, polling_config_entry) entity_registry = er.async_get(hass) entity_entries = er.async_entries_for_config_entry( entity_registry, polling_config_entry.entry_id ) assert entity_entries for entity_entry in entity_entries: assert hass.states.get(entity_entry.entity_id) == snapshot( name=entity_entry.entity_id ) async def test_update_failed( hass: HomeAssistant, snapshot: SnapshotAssertion, withings: AsyncMock, polling_config_entry: MockConfigEntry, freezer: FrozenDateTimeFactory, ) -> None: """Test all entities.""" await setup_integration(hass, polling_config_entry, False) withings.get_measurement_since.side_effect = Exception freezer.tick(timedelta(minutes=10)) async_fire_time_changed(hass) await hass.async_block_till_done() state = hass.states.get("sensor.henk_weight") assert state is not None assert state.state == STATE_UNAVAILABLE async def test_update_updates_incrementally( hass: HomeAssistant, snapshot: SnapshotAssertion, withings: AsyncMock, polling_config_entry: MockConfigEntry, freezer: FrozenDateTimeFactory, ) -> None: """Test fetching new data updates since the last valid update.""" await setup_integration(hass, polling_config_entry, False) async def _skip_10_minutes() -> None: freezer.tick(timedelta(minutes=10)) async_fire_time_changed(hass) await hass.async_block_till_done() meas_json = load_json_array_fixture("withings/get_meas_1.json") measurement_groups = [ MeasurementGroup.from_api(measurement) for measurement in meas_json ] assert withings.get_measurement_since.call_args_list == [] await _skip_10_minutes() assert ( str(withings.get_measurement_since.call_args_list[0].args[0]) == "2019-08-01 12:00:00+00:00" ) withings.get_measurement_since.return_value = measurement_groups await _skip_10_minutes() assert ( str(withings.get_measurement_since.call_args_list[1].args[0]) == "2019-08-01 12:00:00+00:00" ) await _skip_10_minutes() assert ( str(withings.get_measurement_since.call_args_list[2].args[0]) == "2021-04-16 20:30:55+00:00" ) state = hass.states.get("sensor.henk_weight") assert state is not None assert state.state == "71" assert len(withings.get_measurement_in_period.call_args_list) == 1 async def test_update_new_measurement_creates_new_sensor( hass: HomeAssistant, withings: AsyncMock, polling_config_entry: MockConfigEntry, freezer: FrozenDateTimeFactory, ) -> None: """Test fetching a new measurement will add a new sensor.""" meas_json = load_json_array_fixture("withings/get_meas_1.json") measurement_groups = [ MeasurementGroup.from_api(measurement) for measurement in meas_json ] withings.get_measurement_in_period.return_value = measurement_groups await setup_integration(hass, polling_config_entry, False) assert hass.states.get("sensor.henk_fat_mass") is None meas_json = load_json_object_fixture("withings/get_meas.json") measurement_groups = [ MeasurementGroup.from_api(measurement) for measurement in meas_json["measuregrps"] ] withings.get_measurement_in_period.return_value = measurement_groups freezer.tick(timedelta(minutes=10)) async_fire_time_changed(hass) await hass.async_block_till_done() assert hass.states.get("sensor.henk_fat_mass") is not None async def test_update_new_goals_creates_new_sensor( hass: HomeAssistant, withings: AsyncMock, polling_config_entry: MockConfigEntry, freezer: FrozenDateTimeFactory, ) -> None: """Test fetching new goals will add a new sensor.""" goals_json = load_json_object_fixture("withings/goals_1.json") goals = Goals.from_api(goals_json) withings.get_goals.return_value = goals await setup_integration(hass, polling_config_entry, False) assert hass.states.get("sensor.henk_step_goal") is None assert hass.states.get("sensor.henk_weight_goal") is not None goals_json = load_json_object_fixture("withings/goals.json") goals = Goals.from_api(goals_json) withings.get_goals.return_value = goals freezer.tick(timedelta(hours=1)) async_fire_time_changed(hass) await hass.async_block_till_done() assert hass.states.get("sensor.henk_step_goal") is not None