Refactor recorder tests to use recorder history API (#89565)
This commit is contained in:
parent
50c31a5355
commit
1c57339ec3
27 changed files with 296 additions and 616 deletions
|
@ -16,10 +16,9 @@ from homeassistant.components.climate import (
|
|||
ATTR_TARGET_TEMP_STEP,
|
||||
)
|
||||
from homeassistant.components.recorder import Recorder
|
||||
from homeassistant.components.recorder.db_schema import StateAttributes, States
|
||||
from homeassistant.components.recorder.util import session_scope
|
||||
from homeassistant.components.recorder.history import get_significant_states
|
||||
from homeassistant.const import ATTR_FRIENDLY_NAME
|
||||
from homeassistant.core import HomeAssistant, State
|
||||
from homeassistant.core import HomeAssistant
|
||||
from homeassistant.setup import async_setup_component
|
||||
from homeassistant.util import dt as dt_util
|
||||
|
||||
|
@ -29,6 +28,7 @@ from tests.components.recorder.common import async_wait_recording_done
|
|||
|
||||
async def test_exclude_attributes(recorder_mock: Recorder, hass: HomeAssistant) -> None:
|
||||
"""Test climate registered attributes to be excluded."""
|
||||
now = dt_util.utcnow()
|
||||
await async_setup_component(
|
||||
hass, climate.DOMAIN, {climate.DOMAIN: {"platform": "demo"}}
|
||||
)
|
||||
|
@ -37,29 +37,17 @@ async def test_exclude_attributes(recorder_mock: Recorder, hass: HomeAssistant)
|
|||
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
|
||||
).outerjoin(
|
||||
StateAttributes, States.attributes_id == StateAttributes.attributes_id
|
||||
):
|
||||
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)
|
||||
states = await hass.async_add_executor_job(get_significant_states, hass, now)
|
||||
assert len(states) > 1
|
||||
for state in states:
|
||||
assert ATTR_PRESET_MODES not in state.attributes
|
||||
assert ATTR_HVAC_MODES not in state.attributes
|
||||
assert ATTR_FAN_MODES not in state.attributes
|
||||
assert ATTR_SWING_MODES not in state.attributes
|
||||
assert ATTR_MIN_TEMP not in state.attributes
|
||||
assert ATTR_MAX_TEMP not in state.attributes
|
||||
assert ATTR_MIN_HUMIDITY not in state.attributes
|
||||
assert ATTR_MAX_HUMIDITY not in state.attributes
|
||||
assert ATTR_TARGET_TEMP_STEP not in state.attributes
|
||||
assert ATTR_FRIENDLY_NAME in state.attributes
|
||||
for entity_states in states.values():
|
||||
for state in entity_states:
|
||||
assert ATTR_PRESET_MODES not in state.attributes
|
||||
assert ATTR_HVAC_MODES not in state.attributes
|
||||
assert ATTR_FAN_MODES not in state.attributes
|
||||
assert ATTR_SWING_MODES not in state.attributes
|
||||
assert ATTR_MIN_TEMP not in state.attributes
|
||||
assert ATTR_MAX_TEMP not in state.attributes
|
||||
assert ATTR_MIN_HUMIDITY not in state.attributes
|
||||
assert ATTR_MAX_HUMIDITY not in state.attributes
|
||||
assert ATTR_TARGET_TEMP_STEP not in state.attributes
|
||||
assert ATTR_FRIENDLY_NAME in state.attributes
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue