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
|
@ -5,10 +5,9 @@ from datetime import timedelta
|
|||
|
||||
from homeassistant.components.input_datetime import CONF_HAS_DATE, CONF_HAS_TIME, DOMAIN
|
||||
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_EDITABLE
|
||||
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
|
||||
|
||||
|
@ -20,6 +19,7 @@ async def test_exclude_attributes(
|
|||
recorder_mock: Recorder, hass: HomeAssistant, enable_custom_integrations: None
|
||||
) -> None:
|
||||
"""Test attributes to be excluded."""
|
||||
now = dt_util.utcnow()
|
||||
assert await async_setup_component(
|
||||
hass, DOMAIN, {DOMAIN: {"test": {CONF_HAS_TIME: True}}}
|
||||
)
|
||||
|
@ -35,21 +35,10 @@ async def test_exclude_attributes(
|
|||
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)
|
||||
assert len(states) == 1
|
||||
assert ATTR_EDITABLE not in states[0].attributes
|
||||
assert CONF_HAS_DATE not in states[0].attributes
|
||||
assert CONF_HAS_TIME not in states[0].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_EDITABLE not in state.attributes
|
||||
assert CONF_HAS_DATE not in state.attributes
|
||||
assert CONF_HAS_TIME not in state.attributes
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue