2015-07-26 08:45:49 +00:00
|
|
|
"""
|
|
|
|
tests.helpers.event_test
|
2016-02-13 13:19:11 +00:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
2015-07-26 08:45:49 +00:00
|
|
|
|
|
|
|
Tests event helpers.
|
|
|
|
"""
|
|
|
|
# pylint: disable=protected-access,too-many-public-methods
|
|
|
|
# pylint: disable=too-few-public-methods
|
|
|
|
import unittest
|
2016-02-14 21:07:21 +00:00
|
|
|
from datetime import datetime, timedelta
|
2015-07-26 08:45:49 +00:00
|
|
|
|
2016-01-25 03:23:56 +00:00
|
|
|
from astral import Astral
|
|
|
|
|
2015-08-17 03:44:46 +00:00
|
|
|
import homeassistant.core as ha
|
2016-02-14 21:07:21 +00:00
|
|
|
from homeassistant.helpers.event import (
|
|
|
|
track_point_in_utc_time,
|
|
|
|
track_point_in_time,
|
|
|
|
track_utc_time_change,
|
|
|
|
track_time_change,
|
|
|
|
track_state_change,
|
|
|
|
track_sunrise,
|
|
|
|
track_sunset,
|
|
|
|
)
|
2016-01-25 03:23:56 +00:00
|
|
|
from homeassistant.components import sun
|
2016-02-14 21:07:21 +00:00
|
|
|
import homeassistant.util.dt as dt_util
|
2015-07-26 08:45:49 +00:00
|
|
|
|
2016-02-14 23:08:23 +00:00
|
|
|
from tests.common import get_test_home_assistant
|
|
|
|
|
2015-07-26 08:45:49 +00:00
|
|
|
|
|
|
|
class TestEventHelpers(unittest.TestCase):
|
|
|
|
"""
|
|
|
|
Tests the Home Assistant event helpers.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def setUp(self): # pylint: disable=invalid-name
|
|
|
|
""" things to be run when tests are started. """
|
2016-02-14 23:08:23 +00:00
|
|
|
self.hass = get_test_home_assistant()
|
2015-07-26 08:45:49 +00:00
|
|
|
|
|
|
|
def tearDown(self): # pylint: disable=invalid-name
|
|
|
|
""" Stop down stuff we started. """
|
|
|
|
self.hass.stop()
|
|
|
|
|
|
|
|
def test_track_point_in_time(self):
|
|
|
|
""" Test track point in time. """
|
2015-08-04 16:16:10 +00:00
|
|
|
before_birthday = datetime(1985, 7, 9, 12, 0, 0, tzinfo=dt_util.UTC)
|
|
|
|
birthday_paulus = datetime(1986, 7, 9, 12, 0, 0, tzinfo=dt_util.UTC)
|
|
|
|
after_birthday = datetime(1987, 7, 9, 12, 0, 0, tzinfo=dt_util.UTC)
|
2015-07-26 08:45:49 +00:00
|
|
|
|
|
|
|
runs = []
|
|
|
|
|
|
|
|
track_point_in_utc_time(
|
|
|
|
self.hass, lambda x: runs.append(1), birthday_paulus)
|
|
|
|
|
|
|
|
self._send_time_changed(before_birthday)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(runs))
|
|
|
|
|
|
|
|
self._send_time_changed(birthday_paulus)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(runs))
|
|
|
|
|
|
|
|
# A point in time tracker will only fire once, this should do nothing
|
|
|
|
self._send_time_changed(birthday_paulus)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(runs))
|
|
|
|
|
2015-08-04 16:16:10 +00:00
|
|
|
track_point_in_time(
|
2015-07-26 08:45:49 +00:00
|
|
|
self.hass, lambda x: runs.append(1), birthday_paulus)
|
|
|
|
|
|
|
|
self._send_time_changed(after_birthday)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(runs))
|
|
|
|
|
|
|
|
def test_track_time_change(self):
|
|
|
|
""" Test tracking time change. """
|
|
|
|
wildcard_runs = []
|
|
|
|
specific_runs = []
|
|
|
|
|
|
|
|
track_time_change(self.hass, lambda x: wildcard_runs.append(1))
|
2015-08-04 16:16:10 +00:00
|
|
|
track_utc_time_change(
|
2015-07-26 08:45:49 +00:00
|
|
|
self.hass, lambda x: specific_runs.append(1), second=[0, 30])
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 12, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
self.assertEqual(1, len(wildcard_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 12, 0, 15))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
self.assertEqual(2, len(wildcard_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 12, 0, 30))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(specific_runs))
|
|
|
|
self.assertEqual(3, len(wildcard_runs))
|
|
|
|
|
|
|
|
def test_track_state_change(self):
|
2016-02-14 06:57:40 +00:00
|
|
|
"""Test track_state_change."""
|
2015-07-26 08:45:49 +00:00
|
|
|
# 2 lists to track how often our callbacks get called
|
|
|
|
specific_runs = []
|
|
|
|
wildcard_runs = []
|
|
|
|
|
|
|
|
track_state_change(
|
|
|
|
self.hass, 'light.Bowl', lambda a, b, c: specific_runs.append(1),
|
|
|
|
'on', 'off')
|
|
|
|
|
|
|
|
track_state_change(
|
2016-02-14 06:57:40 +00:00
|
|
|
self.hass, 'light.Bowl',
|
|
|
|
lambda _, old_s, new_s: wildcard_runs.append((old_s, new_s)),
|
2015-07-26 08:45:49 +00:00
|
|
|
ha.MATCH_ALL, ha.MATCH_ALL)
|
|
|
|
|
2016-02-14 06:57:40 +00:00
|
|
|
# Adding state to state machine
|
|
|
|
self.hass.states.set("light.Bowl", "on")
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(specific_runs))
|
|
|
|
self.assertEqual(1, len(wildcard_runs))
|
|
|
|
self.assertIsNone(wildcard_runs[-1][0])
|
|
|
|
self.assertIsNotNone(wildcard_runs[-1][1])
|
|
|
|
|
2015-07-26 08:45:49 +00:00
|
|
|
# Set same state should not trigger a state change/listener
|
|
|
|
self.hass.states.set('light.Bowl', 'on')
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(specific_runs))
|
2016-02-14 06:57:40 +00:00
|
|
|
self.assertEqual(1, len(wildcard_runs))
|
2015-07-26 08:45:49 +00:00
|
|
|
|
|
|
|
# State change off -> on
|
|
|
|
self.hass.states.set('light.Bowl', 'off')
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
2016-02-14 06:57:40 +00:00
|
|
|
self.assertEqual(2, len(wildcard_runs))
|
2015-07-26 08:45:49 +00:00
|
|
|
|
|
|
|
# State change off -> off
|
|
|
|
self.hass.states.set('light.Bowl', 'off', {"some_attr": 1})
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
2016-02-14 06:57:40 +00:00
|
|
|
self.assertEqual(3, len(wildcard_runs))
|
2015-07-26 08:45:49 +00:00
|
|
|
|
|
|
|
# State change off -> on
|
|
|
|
self.hass.states.set('light.Bowl', 'on')
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
2016-02-14 06:57:40 +00:00
|
|
|
self.assertEqual(4, len(wildcard_runs))
|
|
|
|
|
|
|
|
self.hass.states.remove('light.bowl')
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
self.assertEqual(5, len(wildcard_runs))
|
|
|
|
self.assertIsNotNone(wildcard_runs[-1][0])
|
|
|
|
self.assertIsNone(wildcard_runs[-1][1])
|
2015-07-26 08:45:49 +00:00
|
|
|
|
2016-01-25 03:23:56 +00:00
|
|
|
def test_track_sunrise(self):
|
|
|
|
""" Test track sunrise """
|
|
|
|
latitude = 32.87336
|
|
|
|
longitude = 117.22743
|
|
|
|
|
|
|
|
# setup sun component
|
|
|
|
self.hass.config.latitude = latitude
|
|
|
|
self.hass.config.longitude = longitude
|
|
|
|
sun.setup(self.hass, {sun.DOMAIN: {sun.CONF_ELEVATION: 0}})
|
|
|
|
|
|
|
|
# get next sunrise/sunset
|
|
|
|
astral = Astral()
|
|
|
|
utc_now = dt_util.utcnow()
|
|
|
|
|
|
|
|
mod = -1
|
|
|
|
while True:
|
|
|
|
next_rising = (astral.sunrise_utc(utc_now +
|
|
|
|
timedelta(days=mod), latitude, longitude))
|
|
|
|
if next_rising > utc_now:
|
|
|
|
break
|
|
|
|
mod += 1
|
|
|
|
|
|
|
|
# track sunrise
|
|
|
|
runs = []
|
|
|
|
track_sunrise(self.hass, lambda: runs.append(1))
|
|
|
|
|
|
|
|
offset_runs = []
|
|
|
|
offset = timedelta(minutes=30)
|
|
|
|
track_sunrise(self.hass, lambda: offset_runs.append(1), offset)
|
|
|
|
|
|
|
|
# run tests
|
|
|
|
self._send_time_changed(next_rising - offset)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(runs))
|
|
|
|
self.assertEqual(0, len(offset_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(next_rising)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(runs))
|
|
|
|
self.assertEqual(0, len(offset_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(next_rising + offset)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(runs))
|
|
|
|
self.assertEqual(1, len(offset_runs))
|
|
|
|
|
|
|
|
def test_track_sunset(self):
|
|
|
|
""" Test track sunset """
|
|
|
|
latitude = 32.87336
|
|
|
|
longitude = 117.22743
|
|
|
|
|
|
|
|
# setup sun component
|
|
|
|
self.hass.config.latitude = latitude
|
|
|
|
self.hass.config.longitude = longitude
|
|
|
|
sun.setup(self.hass, {sun.DOMAIN: {sun.CONF_ELEVATION: 0}})
|
|
|
|
|
|
|
|
# get next sunrise/sunset
|
|
|
|
astral = Astral()
|
|
|
|
utc_now = dt_util.utcnow()
|
|
|
|
|
|
|
|
mod = -1
|
|
|
|
while True:
|
|
|
|
next_setting = (astral.sunset_utc(utc_now +
|
|
|
|
timedelta(days=mod), latitude, longitude))
|
|
|
|
if next_setting > utc_now:
|
|
|
|
break
|
|
|
|
mod += 1
|
|
|
|
|
|
|
|
# track sunset
|
|
|
|
runs = []
|
|
|
|
track_sunset(self.hass, lambda: runs.append(1))
|
|
|
|
|
|
|
|
offset_runs = []
|
|
|
|
offset = timedelta(minutes=30)
|
|
|
|
track_sunset(self.hass, lambda: offset_runs.append(1), offset)
|
|
|
|
|
|
|
|
# run tests
|
|
|
|
self._send_time_changed(next_setting - offset)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(runs))
|
|
|
|
self.assertEqual(0, len(offset_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(next_setting)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(runs))
|
|
|
|
self.assertEqual(0, len(offset_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(next_setting + offset)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(runs))
|
|
|
|
self.assertEqual(1, len(offset_runs))
|
|
|
|
|
2015-07-26 08:45:49 +00:00
|
|
|
def _send_time_changed(self, now):
|
|
|
|
""" Send a time changed event. """
|
|
|
|
self.hass.bus.fire(ha.EVENT_TIME_CHANGED, {ha.ATTR_NOW: now})
|
2016-01-26 09:28:31 +00:00
|
|
|
|
2016-01-26 17:37:19 +00:00
|
|
|
def test_periodic_task_minute(self):
|
2016-01-26 09:28:31 +00:00
|
|
|
specific_runs = []
|
|
|
|
|
|
|
|
track_utc_time_change(
|
|
|
|
self.hass, lambda x: specific_runs.append(1), minute='/5')
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 12, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 12, 3, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 12, 5, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(specific_runs))
|
2016-01-26 16:06:50 +00:00
|
|
|
|
|
|
|
def test_periodic_task_hour(self):
|
|
|
|
specific_runs = []
|
|
|
|
|
|
|
|
track_utc_time_change(
|
|
|
|
self.hass, lambda x: specific_runs.append(1), hour='/2')
|
|
|
|
|
2016-01-26 16:13:18 +00:00
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 22, 0, 0))
|
2016-01-26 16:06:50 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
|
2016-01-26 16:13:18 +00:00
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 23, 0, 0))
|
2016-01-26 16:06:50 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
|
2016-01-26 16:13:18 +00:00
|
|
|
self._send_time_changed(datetime(2014, 5, 24, 0, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(specific_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 25, 1, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(specific_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 25, 2, 0, 0))
|
2016-01-26 16:06:50 +00:00
|
|
|
self.hass.pool.block_till_done()
|
2016-01-26 16:13:18 +00:00
|
|
|
self.assertEqual(3, len(specific_runs))
|
2016-01-26 17:37:19 +00:00
|
|
|
|
|
|
|
def test_periodic_task_day(self):
|
|
|
|
specific_runs = []
|
|
|
|
|
|
|
|
track_utc_time_change(
|
|
|
|
self.hass, lambda x: specific_runs.append(1), day='/2')
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 2, 0, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 3, 12, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 4, 0, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(specific_runs))
|
2016-01-26 17:44:41 +00:00
|
|
|
|
|
|
|
def test_periodic_task_year(self):
|
|
|
|
specific_runs = []
|
|
|
|
|
|
|
|
track_utc_time_change(
|
|
|
|
self.hass, lambda x: specific_runs.append(1), year='/2')
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 2, 0, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2015, 5, 2, 0, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(specific_runs))
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2016, 5, 2, 0, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(2, len(specific_runs))
|
2016-01-26 19:43:29 +00:00
|
|
|
|
|
|
|
def test_periodic_task_wrong_input(self):
|
|
|
|
specific_runs = []
|
|
|
|
|
|
|
|
track_utc_time_change(
|
|
|
|
self.hass, lambda x: specific_runs.append(1), year='/two')
|
|
|
|
|
|
|
|
self._send_time_changed(datetime(2014, 5, 2, 0, 0, 0))
|
|
|
|
self.hass.pool.block_till_done()
|
2016-01-26 19:49:51 +00:00
|
|
|
self.assertEqual(0, len(specific_runs))
|