mirror of
https://github.com/home-assistant/core.git
synced 2025-07-25 14:17:45 +00:00
Exclude static number attributes from being recorded in the database (#69194)
This commit is contained in:
parent
8de26e5085
commit
4f8c7fe05b
17
homeassistant/components/number/recorder.py
Normal file
17
homeassistant/components/number/recorder.py
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
"""Integration platform for recorder."""
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from homeassistant.core import HomeAssistant, callback
|
||||||
|
|
||||||
|
from . import ATTR_MAX, ATTR_MIN, ATTR_MODE, ATTR_STEP
|
||||||
|
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def exclude_attributes(hass: HomeAssistant) -> set[str]:
|
||||||
|
"""Exclude static attributes from being recorded in the database."""
|
||||||
|
return {
|
||||||
|
ATTR_MIN,
|
||||||
|
ATTR_MAX,
|
||||||
|
ATTR_STEP,
|
||||||
|
ATTR_MODE,
|
||||||
|
}
|
46
tests/components/number/test_recorder.py
Normal file
46
tests/components/number/test_recorder.py
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
"""The tests for number recorder."""
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from datetime import timedelta
|
||||||
|
|
||||||
|
from homeassistant.components import number
|
||||||
|
from homeassistant.components.number import ATTR_MAX, ATTR_MIN, ATTR_MODE, ATTR_STEP
|
||||||
|
from homeassistant.components.recorder.models 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, async_init_recorder_component
|
||||||
|
from tests.components.recorder.common import async_wait_recording_done_without_instance
|
||||||
|
|
||||||
|
|
||||||
|
async def test_exclude_attributes(hass):
|
||||||
|
"""Test number registered attributes to be excluded."""
|
||||||
|
await async_init_recorder_component(hass)
|
||||||
|
await async_setup_component(
|
||||||
|
hass, number.DOMAIN, {number.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_without_instance(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 not in state.attributes
|
||||||
|
assert ATTR_MAX not in state.attributes
|
||||||
|
assert ATTR_STEP not in state.attributes
|
||||||
|
assert ATTR_MODE not in state.attributes
|
||||||
|
assert ATTR_FRIENDLY_NAME in state.attributes
|
Loading…
x
Reference in New Issue
Block a user