-
-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Exclude unimportant attributes from being recorded in the database (#132
- Loading branch information
Showing
7 changed files
with
183 additions
and
167 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
"""Integration platform for recorder.""" | ||
from __future__ import annotations | ||
|
||
from homeassistant.core import HomeAssistant, callback | ||
|
||
from .const import ATTR_SOURCES, ATTR_TO_PROPERTY | ||
|
||
|
||
@callback | ||
def exclude_attributes(hass: HomeAssistant) -> set[str]: | ||
"""Exclude unimportant attributes from being recorded in the database.""" | ||
attributes_to_exclude = set(ATTR_TO_PROPERTY) | ||
attributes_to_exclude.discard(ATTR_SOURCES) | ||
return attributes_to_exclude |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,85 @@ | ||
"""The tests for recorder platform.""" | ||
from __future__ import annotations | ||
|
||
import logging | ||
from datetime import timedelta | ||
from unittest.mock import patch | ||
|
||
from homeassistant.components import recorder | ||
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 pytest_homeassistant_custom_component.common import async_fire_time_changed | ||
from pytest_homeassistant_custom_component.components.recorder.common import ( | ||
wait_recording_done, | ||
) | ||
|
||
from custom_components.average.const import ATTR_SOURCES, ATTR_TO_PROPERTY | ||
|
||
_LOGGER = logging.getLogger(__name__) | ||
|
||
|
||
async def async_init_recorder_component(hass, add_config=None): | ||
"""Initialize the recorder asynchronously.""" | ||
config = dict(add_config) if add_config else {} | ||
if recorder.CONF_DB_URL not in config: | ||
config[recorder.CONF_DB_URL] = "sqlite://" # In memory DB | ||
if recorder.CONF_COMMIT_INTERVAL not in config: | ||
config[recorder.CONF_COMMIT_INTERVAL] = 0 | ||
|
||
with patch( | ||
"homeassistant.components.recorder.ALLOW_IN_MEMORY_DB", | ||
True, | ||
), patch("homeassistant.components.recorder.migration.migrate_schema"): | ||
assert await async_setup_component( | ||
hass, recorder.DOMAIN, {recorder.DOMAIN: config} | ||
) | ||
assert recorder.DOMAIN in hass.config.components | ||
_LOGGER.info( | ||
"Test recorder successfully started, database location: %s", | ||
config[recorder.CONF_DB_URL], | ||
) | ||
|
||
|
||
async def async_wait_recording_done_without_instance(hass: HomeAssistant) -> None: | ||
"""Block till recording is done.""" | ||
await hass.loop.run_in_executor(None, wait_recording_done, hass) | ||
|
||
|
||
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 | ||
|
||
attributes_to_exclude = set(ATTR_TO_PROPERTY) | ||
attributes_to_exclude.discard(ATTR_SOURCES) | ||
|
||
for attr in attributes_to_exclude: | ||
assert attr not in states[0].attributes |
Oops, something went wrong.