core/tests/components/withings/test_sensor.py

138 lines
4.3 KiB
Python
Raw Normal View History

"""Tests for the Withings component."""
from datetime import timedelta
from unittest.mock import AsyncMock
from aiowithings import 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."""
await setup_integration(hass, polling_config_entry)
entity_registry = er.async_get(hass)
entities = er.async_entries_for_config_entry(
entity_registry, polling_config_entry.entry_id
)
for entity in entities:
if entity.domain == Platform.SENSOR:
assert hass.states.get(entity.entity_id) == snapshot
assert entities
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