Add recorder platform to input_boolean (#70154)
Co-authored-by: J. Nick Koston <nick@koston.org>
This commit is contained in:
parent
026e1635cc
commit
38a1ef45ed
3 changed files with 64 additions and 0 deletions
|
@ -22,6 +22,9 @@ from homeassistant.helpers import collection
|
||||||
import homeassistant.helpers.config_validation as cv
|
import homeassistant.helpers.config_validation as cv
|
||||||
from homeassistant.helpers.entity import ToggleEntity
|
from homeassistant.helpers.entity import ToggleEntity
|
||||||
from homeassistant.helpers.entity_component import EntityComponent
|
from homeassistant.helpers.entity_component import EntityComponent
|
||||||
|
from homeassistant.helpers.integration_platform import (
|
||||||
|
async_process_integration_platform_for_component,
|
||||||
|
)
|
||||||
from homeassistant.helpers.restore_state import RestoreEntity
|
from homeassistant.helpers.restore_state import RestoreEntity
|
||||||
import homeassistant.helpers.service
|
import homeassistant.helpers.service
|
||||||
from homeassistant.helpers.storage import Store
|
from homeassistant.helpers.storage import Store
|
||||||
|
@ -86,6 +89,11 @@ def is_on(hass: HomeAssistant, entity_id: str) -> bool:
|
||||||
async def async_setup(hass: HomeAssistant, config: ConfigType) -> bool:
|
async def async_setup(hass: HomeAssistant, config: ConfigType) -> bool:
|
||||||
"""Set up an input boolean."""
|
"""Set up an input boolean."""
|
||||||
component = EntityComponent(_LOGGER, DOMAIN, hass)
|
component = EntityComponent(_LOGGER, DOMAIN, hass)
|
||||||
|
|
||||||
|
# Process integration platforms right away since
|
||||||
|
# we will create entities before firing EVENT_COMPONENT_LOADED
|
||||||
|
await async_process_integration_platform_for_component(hass, DOMAIN)
|
||||||
|
|
||||||
id_manager = collection.IDManager()
|
id_manager = collection.IDManager()
|
||||||
|
|
||||||
yaml_collection = collection.YamlCollection(
|
yaml_collection = collection.YamlCollection(
|
||||||
|
|
11
homeassistant/components/input_boolean/recorder.py
Normal file
11
homeassistant/components/input_boolean/recorder.py
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
"""Integration platform for recorder."""
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from homeassistant.const import ATTR_EDITABLE
|
||||||
|
from homeassistant.core import HomeAssistant, callback
|
||||||
|
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def exclude_attributes(hass: HomeAssistant) -> set[str]:
|
||||||
|
"""Exclude editable hint from being recorded in the database."""
|
||||||
|
return {ATTR_EDITABLE}
|
45
tests/components/input_boolean/test_recorder.py
Normal file
45
tests/components/input_boolean/test_recorder.py
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
"""The tests for recorder platform."""
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from datetime import timedelta
|
||||||
|
|
||||||
|
from homeassistant.components.input_boolean import DOMAIN
|
||||||
|
from homeassistant.components.recorder.models import StateAttributes, States
|
||||||
|
from homeassistant.components.recorder.util import session_scope
|
||||||
|
from homeassistant.const import ATTR_EDITABLE
|
||||||
|
from homeassistant.core import HomeAssistant, 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: HomeAssistant, enable_custom_integrations: None
|
||||||
|
):
|
||||||
|
"""Test attributes to be excluded."""
|
||||||
|
await async_init_recorder_component(hass)
|
||||||
|
assert await async_setup_component(hass, DOMAIN, {DOMAIN: {"test": {}}})
|
||||||
|
|
||||||
|
state = hass.states.get("input_boolean.test")
|
||||||
|
assert state
|
||||||
|
assert state.attributes[ATTR_EDITABLE] is False
|
||||||
|
|
||||||
|
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
|
||||||
|
assert ATTR_EDITABLE not in states[0].attributes
|
Loading…
Add table
Add a link
Reference in a new issue