mirror of
https://github.com/home-assistant/core.git
synced 2025-12-24 21:06:19 +00:00
Refactor recorder tests to use recorder history API (#89565)
This commit is contained in:
@@ -12,11 +12,11 @@ from homeassistant.components.automation import (
|
||||
CONF_ID,
|
||||
)
|
||||
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_ENTITY_ID, 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
|
||||
|
||||
from tests.common import async_mock_service
|
||||
from tests.components.recorder.common import async_wait_recording_done
|
||||
@@ -32,6 +32,7 @@ async def test_exclude_attributes(
|
||||
recorder_mock: Recorder, hass: HomeAssistant, calls
|
||||
) -> None:
|
||||
"""Test automation registered attributes to be excluded."""
|
||||
now = dt_util.utcnow()
|
||||
assert await async_setup_component(
|
||||
hass,
|
||||
automation.DOMAIN,
|
||||
@@ -49,25 +50,13 @@ async def test_exclude_attributes(
|
||||
assert ["hello.world"] == calls[0].data.get(ATTR_ENTITY_ID)
|
||||
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)
|
||||
assert len(states) > 1
|
||||
for state in states:
|
||||
assert ATTR_LAST_TRIGGERED not in state.attributes
|
||||
assert ATTR_MODE not in state.attributes
|
||||
assert ATTR_CUR not in state.attributes
|
||||
assert CONF_ID not in state.attributes
|
||||
assert ATTR_MAX not in state.attributes
|
||||
assert ATTR_FRIENDLY_NAME in state.attributes
|
||||
states = await hass.async_add_executor_job(get_significant_states, hass, now)
|
||||
assert len(states) == 1
|
||||
for entity_states in states.values():
|
||||
for state in entity_states:
|
||||
assert ATTR_LAST_TRIGGERED not in state.attributes
|
||||
assert ATTR_MODE not in state.attributes
|
||||
assert ATTR_CUR not in state.attributes
|
||||
assert CONF_ID not in state.attributes
|
||||
assert ATTR_MAX not in state.attributes
|
||||
assert ATTR_FRIENDLY_NAME in state.attributes
|
||||
|
||||
Reference in New Issue
Block a user