core/tests/components/recorder/test_models.py

162 lines
4.8 KiB
Python
Raw Normal View History

2016-07-11 07:46:56 +00:00
"""The tests for the Recorder component."""
import unittest
from datetime import datetime
from sqlalchemy import create_engine
from sqlalchemy.orm import scoped_session, sessionmaker
import homeassistant.core as ha
from homeassistant.const import EVENT_STATE_CHANGED
from homeassistant.util import dt
2019-07-31 19:25:30 +00:00
from homeassistant.components.recorder.models import Base, Events, States, RecorderRuns
2016-07-11 07:46:56 +00:00
ENGINE = None
SESSION = None
2016-07-11 07:46:56 +00:00
def setUpModule(): # pylint: disable=invalid-name
2016-07-11 07:46:56 +00:00
"""Set up a database to use."""
global ENGINE
global SESSION
2016-07-11 07:46:56 +00:00
ENGINE = create_engine("sqlite://")
Base.metadata.create_all(ENGINE)
session_factory = sessionmaker(bind=ENGINE)
SESSION = scoped_session(session_factory)
2016-07-11 07:46:56 +00:00
def tearDownModule(): # pylint: disable=invalid-name
2016-07-11 07:46:56 +00:00
"""Close database."""
global ENGINE
global SESSION
2016-07-11 07:46:56 +00:00
ENGINE.dispose()
ENGINE = None
SESSION = None
2016-07-11 07:46:56 +00:00
class TestEvents(unittest.TestCase):
"""Test Events model."""
# pylint: disable=no-self-use
2016-07-11 07:46:56 +00:00
def test_from_event(self):
"""Test converting event to db event."""
2019-07-31 19:25:30 +00:00
event = ha.Event("test_event", {"some_data": 15})
2016-07-11 07:46:56 +00:00
assert event == Events.from_event(event).to_native()
class TestStates(unittest.TestCase):
"""Test States model."""
# pylint: disable=no-self-use
2016-07-11 07:46:56 +00:00
def test_from_event(self):
"""Test converting event to db state."""
2019-07-31 19:25:30 +00:00
state = ha.State("sensor.temperature", "18")
event = ha.Event(
EVENT_STATE_CHANGED,
{"entity_id": "sensor.temperature", "old_state": None, "new_state": state},
context=state.context,
)
2016-07-11 07:46:56 +00:00
assert state == States.from_event(event).to_native()
def test_from_event_to_delete_state(self):
"""Test converting deleting state event to db state."""
2019-07-31 19:25:30 +00:00
event = ha.Event(
EVENT_STATE_CHANGED,
{
"entity_id": "sensor.temperature",
"old_state": ha.State("sensor.temperature", "18"),
"new_state": None,
},
)
2016-07-11 07:46:56 +00:00
db_state = States.from_event(event)
2019-07-31 19:25:30 +00:00
assert db_state.entity_id == "sensor.temperature"
assert db_state.domain == "sensor"
assert db_state.state == ""
2016-07-11 07:46:56 +00:00
assert db_state.last_changed == event.time_fired
assert db_state.last_updated == event.time_fired
class TestRecorderRuns(unittest.TestCase):
"""Test recorder run model."""
def setUp(self): # pylint: disable=invalid-name
2016-07-11 07:46:56 +00:00
"""Set up recorder runs."""
self.session = session = SESSION()
2016-07-11 07:46:56 +00:00
session.query(Events).delete()
session.query(States).delete()
session.query(RecorderRuns).delete()
def tearDown(self): # pylint: disable=invalid-name
2016-07-11 07:46:56 +00:00
"""Clean up."""
self.session.rollback()
def test_entity_ids(self):
"""Test if entity ids helper method works."""
run = RecorderRuns(
start=datetime(2016, 7, 9, 11, 0, 0, tzinfo=dt.UTC),
end=datetime(2016, 7, 9, 23, 0, 0, tzinfo=dt.UTC),
closed_incorrect=False,
created=datetime(2016, 7, 9, 11, 0, 0, tzinfo=dt.UTC),
)
self.session.add(run)
self.session.commit()
before_run = datetime(2016, 7, 9, 8, 0, 0, tzinfo=dt.UTC)
in_run = datetime(2016, 7, 9, 13, 0, 0, tzinfo=dt.UTC)
in_run2 = datetime(2016, 7, 9, 15, 0, 0, tzinfo=dt.UTC)
in_run3 = datetime(2016, 7, 9, 18, 0, 0, tzinfo=dt.UTC)
after_run = datetime(2016, 7, 9, 23, 30, 0, tzinfo=dt.UTC)
assert run.to_native() == run
assert run.entity_ids() == []
2019-07-31 19:25:30 +00:00
self.session.add(
States(
entity_id="sensor.temperature",
state="20",
last_changed=before_run,
last_updated=before_run,
)
)
self.session.add(
States(
entity_id="sensor.sound",
state="10",
last_changed=after_run,
last_updated=after_run,
)
)
self.session.add(
States(
entity_id="sensor.humidity",
state="76",
last_changed=in_run,
last_updated=in_run,
)
)
self.session.add(
States(
entity_id="sensor.lux",
state="5",
last_changed=in_run3,
last_updated=in_run3,
)
)
assert sorted(run.entity_ids()) == ["sensor.humidity", "sensor.lux"]
assert run.entity_ids(in_run2) == ["sensor.humidity"]
def test_states_from_native_invalid_entity_id():
"""Test loading a state from an invalid entity ID."""
event = States()
event.entity_id = "test.invalid__id"
event.attributes = "{}"
state = event.to_native()
2019-07-31 19:25:30 +00:00
assert state.entity_id == "test.invalid__id"