49 lines
1.9 KiB
Python
49 lines
1.9 KiB
Python
"""The tests for humidifier recorder."""
|
|
from __future__ import annotations
|
|
|
|
from datetime import timedelta
|
|
|
|
from homeassistant.components import humidifier
|
|
from homeassistant.components.humidifier import (
|
|
ATTR_AVAILABLE_MODES,
|
|
ATTR_MAX_HUMIDITY,
|
|
ATTR_MIN_HUMIDITY,
|
|
)
|
|
from homeassistant.components.recorder.db_schema import StateAttributes, States
|
|
from homeassistant.components.recorder.util import session_scope
|
|
from homeassistant.const import ATTR_FRIENDLY_NAME
|
|
from homeassistant.core import State
|
|
from homeassistant.setup import async_setup_component
|
|
from homeassistant.util import dt as dt_util
|
|
|
|
from tests.common import async_fire_time_changed
|
|
from tests.components.recorder.common import async_wait_recording_done
|
|
|
|
|
|
async def test_exclude_attributes(hass, recorder_mock):
|
|
"""Test humidifier registered attributes to be excluded."""
|
|
await async_setup_component(
|
|
hass, humidifier.DOMAIN, {humidifier.DOMAIN: {"platform": "demo"}}
|
|
)
|
|
await hass.async_block_till_done()
|
|
async_fire_time_changed(hass, dt_util.utcnow() + timedelta(minutes=5))
|
|
await hass.async_block_till_done()
|
|
await async_wait_recording_done(hass)
|
|
|
|
def _fetch_states() -> list[State]:
|
|
with session_scope(hass=hass) as session:
|
|
native_states = []
|
|
for db_state, db_state_attributes in session.query(States, StateAttributes):
|
|
state = db_state.to_native()
|
|
state.attributes = db_state_attributes.to_native()
|
|
native_states.append(state)
|
|
return native_states
|
|
|
|
states: list[State] = await hass.async_add_executor_job(_fetch_states)
|
|
assert len(states) > 1
|
|
for state in states:
|
|
assert ATTR_MIN_HUMIDITY not in state.attributes
|
|
assert ATTR_MAX_HUMIDITY not in state.attributes
|
|
assert ATTR_AVAILABLE_MODES not in state.attributes
|
|
assert ATTR_FRIENDLY_NAME in state.attributes
|