2014-11-24 23:15:14 -08:00
|
|
|
"""
|
2014-11-30 23:14:08 -08:00
|
|
|
ha_test.test_component_sun
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2014-11-24 23:15:14 -08:00
|
|
|
|
2014-11-24 23:35:50 -08:00
|
|
|
Tests Sun component.
|
2014-11-24 23:15:14 -08:00
|
|
|
"""
|
|
|
|
# pylint: disable=too-many-public-methods,protected-access
|
|
|
|
import unittest
|
|
|
|
import datetime as dt
|
|
|
|
|
|
|
|
import ephem
|
|
|
|
|
|
|
|
import homeassistant as ha
|
2014-12-06 23:57:02 -08:00
|
|
|
from homeassistant.const import CONF_LATITUDE, CONF_LONGITUDE
|
2014-11-24 23:15:14 -08:00
|
|
|
import homeassistant.components.sun as sun
|
|
|
|
|
|
|
|
|
|
|
|
class TestSun(unittest.TestCase):
|
|
|
|
""" Test the sun module. """
|
|
|
|
|
|
|
|
def setUp(self): # pylint: disable=invalid-name
|
|
|
|
self.hass = ha.HomeAssistant()
|
|
|
|
|
|
|
|
def tearDown(self): # pylint: disable=invalid-name
|
|
|
|
""" Stop down stuff we started. """
|
2014-11-28 20:22:08 -08:00
|
|
|
self.hass.stop()
|
2014-11-24 23:15:14 -08:00
|
|
|
|
|
|
|
def test_is_on(self):
|
|
|
|
""" Test is_on method. """
|
|
|
|
self.hass.states.set(sun.ENTITY_ID, sun.STATE_ABOVE_HORIZON)
|
|
|
|
self.assertTrue(sun.is_on(self.hass))
|
|
|
|
self.hass.states.set(sun.ENTITY_ID, sun.STATE_BELOW_HORIZON)
|
|
|
|
self.assertFalse(sun.is_on(self.hass))
|
|
|
|
|
|
|
|
def test_setting_rising(self):
|
|
|
|
""" Test retrieving sun setting and rising. """
|
|
|
|
# Compare it with the real data
|
|
|
|
self.assertTrue(sun.setup(
|
|
|
|
self.hass,
|
|
|
|
{ha.DOMAIN: {
|
2014-12-06 23:57:02 -08:00
|
|
|
CONF_LATITUDE: '32.87336',
|
|
|
|
CONF_LONGITUDE: '117.22743'
|
2014-11-24 23:15:14 -08:00
|
|
|
}}))
|
|
|
|
|
|
|
|
observer = ephem.Observer()
|
|
|
|
observer.lat = '32.87336' # pylint: disable=assigning-non-slot
|
|
|
|
observer.long = '117.22743' # pylint: disable=assigning-non-slot
|
|
|
|
|
2014-11-25 22:31:36 -08:00
|
|
|
utc_now = dt.datetime.utcnow()
|
2014-11-24 23:15:14 -08:00
|
|
|
body_sun = ephem.Sun() # pylint: disable=no-member
|
2014-11-25 22:31:36 -08:00
|
|
|
next_rising_dt = ephem.localtime(
|
|
|
|
observer.next_rising(body_sun, start=utc_now))
|
|
|
|
next_setting_dt = ephem.localtime(
|
|
|
|
observer.next_setting(body_sun, start=utc_now))
|
2014-11-24 23:15:14 -08:00
|
|
|
|
|
|
|
# Home Assistant strips out microseconds
|
|
|
|
# strip it out of the datetime objects
|
|
|
|
next_rising_dt = next_rising_dt - dt.timedelta(
|
|
|
|
microseconds=next_rising_dt.microsecond)
|
|
|
|
next_setting_dt = next_setting_dt - dt.timedelta(
|
|
|
|
microseconds=next_setting_dt.microsecond)
|
|
|
|
|
|
|
|
self.assertEqual(next_rising_dt, sun.next_rising(self.hass))
|
|
|
|
self.assertEqual(next_setting_dt, sun.next_setting(self.hass))
|
|
|
|
|
|
|
|
# Point it at a state without the proper attributes
|
|
|
|
self.hass.states.set(sun.ENTITY_ID, sun.STATE_ABOVE_HORIZON)
|
|
|
|
self.assertIsNone(sun.next_rising(self.hass))
|
|
|
|
self.assertIsNone(sun.next_setting(self.hass))
|
|
|
|
|
|
|
|
# Point it at a non-existing state
|
|
|
|
self.assertIsNone(sun.next_rising(self.hass, 'non.existing'))
|
|
|
|
self.assertIsNone(sun.next_setting(self.hass, 'non.existing'))
|
|
|
|
|
2014-11-25 22:31:36 -08:00
|
|
|
def test_state_change(self):
|
|
|
|
""" Test if the state changes at next setting/rising. """
|
|
|
|
self.assertTrue(sun.setup(
|
|
|
|
self.hass,
|
|
|
|
{ha.DOMAIN: {
|
2014-12-06 23:57:02 -08:00
|
|
|
CONF_LATITUDE: '32.87336',
|
|
|
|
CONF_LONGITUDE: '117.22743'
|
2014-11-25 22:31:36 -08:00
|
|
|
}}))
|
|
|
|
|
|
|
|
if sun.is_on(self.hass):
|
|
|
|
test_state = sun.STATE_BELOW_HORIZON
|
|
|
|
test_time = sun.next_setting(self.hass)
|
|
|
|
else:
|
|
|
|
test_state = sun.STATE_ABOVE_HORIZON
|
|
|
|
test_time = sun.next_rising(self.hass)
|
|
|
|
|
|
|
|
self.assertIsNotNone(test_time)
|
|
|
|
|
|
|
|
self.hass.bus.fire(ha.EVENT_TIME_CHANGED,
|
|
|
|
{ha.ATTR_NOW: test_time + dt.timedelta(seconds=5)})
|
|
|
|
|
2014-12-16 21:46:02 -08:00
|
|
|
self.hass.pool.block_till_done()
|
2014-11-25 22:31:36 -08:00
|
|
|
|
|
|
|
self.assertEqual(test_state, self.hass.states.get(sun.ENTITY_ID).state)
|
|
|
|
|
2014-11-24 23:15:14 -08:00
|
|
|
def test_setup(self):
|
|
|
|
""" Test Sun setup with empty and wrong configs. """
|
|
|
|
self.assertFalse(sun.setup(self.hass, {}))
|
|
|
|
self.assertFalse(sun.setup(self.hass, {sun.DOMAIN: {}}))
|
|
|
|
self.assertFalse(sun.setup(
|
2014-12-06 23:57:02 -08:00
|
|
|
self.hass, {ha.DOMAIN: {CONF_LATITUDE: '32.87336'}}))
|
2014-11-24 23:15:14 -08:00
|
|
|
self.assertFalse(sun.setup(
|
2014-12-06 23:57:02 -08:00
|
|
|
self.hass, {ha.DOMAIN: {CONF_LONGITUDE: '117.22743'}}))
|
2014-11-24 23:15:14 -08:00
|
|
|
self.assertFalse(sun.setup(
|
2014-12-06 23:57:02 -08:00
|
|
|
self.hass, {ha.DOMAIN: {CONF_LATITUDE: 'hello'}}))
|
2014-11-24 23:15:14 -08:00
|
|
|
self.assertFalse(sun.setup(
|
2014-12-06 23:57:02 -08:00
|
|
|
self.hass, {ha.DOMAIN: {CONF_LONGITUDE: 'how are you'}}))
|
2014-11-24 23:15:14 -08:00
|
|
|
self.assertFalse(sun.setup(
|
|
|
|
self.hass, {ha.DOMAIN: {
|
2014-12-06 23:57:02 -08:00
|
|
|
CONF_LATITUDE: 'wrong', CONF_LONGITUDE: '117.22743'
|
2014-11-24 23:15:14 -08:00
|
|
|
}}))
|
|
|
|
self.assertFalse(sun.setup(
|
|
|
|
self.hass, {ha.DOMAIN: {
|
2014-12-06 23:57:02 -08:00
|
|
|
CONF_LATITUDE: '32.87336', CONF_LONGITUDE: 'wrong'
|
2014-11-24 23:15:14 -08:00
|
|
|
}}))
|
|
|
|
|
|
|
|
# Test with correct config
|
|
|
|
self.assertTrue(sun.setup(
|
|
|
|
self.hass, {ha.DOMAIN: {
|
2014-12-06 23:57:02 -08:00
|
|
|
CONF_LATITUDE: '32.87336', CONF_LONGITUDE: '117.22743'
|
2014-11-24 23:15:14 -08:00
|
|
|
}}))
|