core/tests/test_core.py

502 lines
17 KiB
Python
Raw Normal View History

2016-03-09 09:25:50 +00:00
"""Test to verify that Home Assistant core works."""
2014-11-23 17:51:16 +00:00
# pylint: disable=protected-access,too-many-public-methods
2014-11-24 06:18:51 +00:00
# pylint: disable=too-few-public-methods
2014-11-23 17:51:16 +00:00
import os
import signal
2014-11-23 17:51:16 +00:00
import unittest
2015-09-13 05:56:49 +00:00
from unittest.mock import patch
2014-11-23 17:51:16 +00:00
import time
import threading
2015-09-13 05:56:49 +00:00
from datetime import datetime, timedelta
2014-11-23 17:51:16 +00:00
2015-08-04 16:16:10 +00:00
import pytz
2015-08-17 03:53:17 +00:00
import homeassistant.core as ha
2015-08-30 02:44:59 +00:00
from homeassistant.exceptions import (
HomeAssistantError, InvalidEntityFormatError)
2015-08-04 16:16:10 +00:00
import homeassistant.util.dt as dt_util
2016-08-09 03:42:25 +00:00
from homeassistant.util.unit_system import (METRIC_SYSTEM)
2015-08-04 16:16:10 +00:00
from homeassistant.const import (
2015-10-26 04:00:22 +00:00
__version__, EVENT_HOMEASSISTANT_START, EVENT_HOMEASSISTANT_STOP,
Add unit system support Add unit symbol constants Initial unit system object Import more constants Pydoc for unit system file Import constants for configuration validation Unit system validation method Typing for constants Inches are valid lengths too Typings Change base class to dict - needed for remote api call serialization Validation Use dictionary keys Defined unit systems Update location util to use metric instead of us fahrenheit Update constant imports Import defined unit systems Update configuration to use unit system Update schema to use unit system Update constants Add imports to core for unit system and distance Type for config Default unit system Convert distance from HASS instance Update temperature conversion to use unit system Update temperature conversion Set unit system based on configuration Set info unit system Return unit system dictionary with config dictionary Auto discover unit system Update location test for use metric Update forecast unit system Update mold indicator unit system Update thermostat unit system Update thermostat demo test Unit tests around unit system Update test common hass configuration Update configuration unit tests There should always be a unit system! Update core unit tests Constants typing Linting issues Remove unused import Update fitbit sensor to use application unit system Update google travel time to use application unit system Update configuration example Update dht sensor Update DHT temperature conversion to use the utility function Update swagger config Update my sensors metric flag Update hvac component temperature conversion HVAC conversion for temperature Pull unit from sensor type map Pull unit from sensor type map Update the temper sensor unit Update yWeather sensor unit Update hvac demo unit test Set unit test config unit system to metric Use hass unit system length for default in proximity Use the name of the system instead of temperature Use constants from const Unused import Forecasted temperature Fix calculation in case furthest distance is greater than 1000000 units Remove unneeded constants Set default length to km or miles Use constants Linting doesn't like importing just for typing Fix reference Test is expecting meters - set config to meters Use constant Use constant PyDoc for unit test Should be not in Rename to units Change unit system to be an object - not a dictionary Return tuple in conversion Move convert to temperature util Temperature conversion is now in unit system Update imports Rename to units Units is now an object Use temperature util conversion Unit system is now an object Validate and convert unit system config Return the scalar value in template distance Test is expecting meters Update unit tests around unit system Distance util returns tuple Fix location info test Set units Update unit tests Convert distance DOH Pull out the scalar from the vector Linting I really hate python linting Linting again BLARG Unit test documentation Unit test around is metric flag Break ternary statement into if/else blocks Don't use dictionary - use members is metric flag Rename constants Use is metric flag Move constants to CONST file Move to const file Raise error if unit is not expected Typing No need to return unit since only performing conversion if it can work Use constants Line wrapping Raise error if invalid value Remove subscripts from conversion as they are no longer returned as tuples No longer tuples No longer tuples Check for numeric type Fix string format to use correct variable Typing Assert errors raised Remove subscript Only convert temperature if we know the unit If no unit of measurement set - default to HASS config Convert only if we know the unit Remove subscription Fix not in clause Linting fixes Wants a boolean Clearer if-block Check if the key is in the config first Missed a couple expecting tuples Backwards compatibility No like-y ternary! Error handling around state setting Pretty unit system configuration validation More tuple crap Use is metric flag Error handling around min/max temp Explode if no unit Pull unit from config Celsius has a decimal Unused import Check if it's a temperature before we try to convert it to a temperature Linting says too many statements - combine lat/long in a fairly reasonable manner Backwards compatibility unit test Better doc
2016-07-31 20:24:49 +00:00
EVENT_STATE_CHANGED, ATTR_FRIENDLY_NAME, CONF_UNIT_SYSTEM)
2015-08-04 16:16:10 +00:00
2016-02-14 23:08:23 +00:00
from tests.common import get_test_home_assistant
2015-08-04 16:16:10 +00:00
PST = pytz.timezone('America/Los_Angeles')
2014-11-23 17:51:16 +00:00
2016-08-09 03:21:40 +00:00
class TestMethods(unittest.TestCase):
"""Test the Home Assistant helper methods."""
def test_split_entity_id(self):
"""Test split_entity_id."""
self.assertEqual(['domain', 'object_id'],
ha.split_entity_id('domain.object_id'))
2014-11-23 17:51:16 +00:00
class TestHomeAssistant(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""Test the Home Assistant core classes."""
2014-11-23 17:51:16 +00:00
def setUp(self): # pylint: disable=invalid-name
2016-03-09 09:25:50 +00:00
"""Setup things to be run when tests are started."""
2016-02-14 23:08:23 +00:00
self.hass = get_test_home_assistant()
2014-11-23 17:51:16 +00:00
self.hass.states.set("light.Bowl", "on")
self.hass.states.set("switch.AC", "off")
2014-11-23 20:57:29 +00:00
def tearDown(self): # pylint: disable=invalid-name
2016-03-09 10:15:04 +00:00
"""Stop everything that was started."""
2015-04-30 06:21:31 +00:00
try:
self.hass.stop()
2015-08-30 02:44:59 +00:00
except HomeAssistantError:
2015-04-30 06:21:31 +00:00
# Already stopped after the block till stopped test
pass
2014-11-23 20:57:29 +00:00
2015-08-04 16:16:10 +00:00
def test_start(self):
2016-03-09 09:25:50 +00:00
"""Start the test."""
2015-08-04 16:16:10 +00:00
calls = []
self.hass.bus.listen_once(EVENT_HOMEASSISTANT_START,
lambda event: calls.append(1))
self.hass.start()
self.hass.pool.block_till_done()
self.assertEqual(1, len(calls))
2014-11-23 17:51:16 +00:00
2015-09-13 05:56:49 +00:00
# @patch('homeassistant.core.time.sleep')
2014-11-23 17:51:16 +00:00
def test_block_till_stoped(self):
2016-03-09 09:25:50 +00:00
"""Test if we can block till stop service is called."""
2015-09-13 05:56:49 +00:00
with patch('time.sleep'):
blocking_thread = threading.Thread(
target=self.hass.block_till_stopped)
2014-11-23 17:51:16 +00:00
2015-09-13 05:56:49 +00:00
self.assertFalse(blocking_thread.is_alive())
2015-08-04 16:16:10 +00:00
2015-09-13 05:56:49 +00:00
blocking_thread.start()
2014-11-23 17:51:16 +00:00
2015-09-13 05:56:49 +00:00
self.assertTrue(blocking_thread.is_alive())
2014-11-23 17:51:16 +00:00
2015-09-13 05:56:49 +00:00
self.hass.services.call(ha.DOMAIN, ha.SERVICE_HOMEASSISTANT_STOP)
self.hass.pool.block_till_done()
2014-11-23 17:51:16 +00:00
2015-09-13 05:56:49 +00:00
# Wait for thread to stop
for _ in range(20):
if not blocking_thread.is_alive():
break
2015-08-04 16:16:10 +00:00
time.sleep(0.05)
2014-11-23 17:51:16 +00:00
self.assertFalse(blocking_thread.is_alive())
def test_stopping_with_sigterm(self):
2016-03-09 09:25:50 +00:00
"""Test for stopping with sigterm."""
2015-08-04 16:16:10 +00:00
calls = []
self.hass.bus.listen_once(EVENT_HOMEASSISTANT_STOP,
lambda event: calls.append(1))
def send_sigterm(length):
2016-03-09 09:25:50 +00:00
"""Send sigterm."""
os.kill(os.getpid(), signal.SIGTERM)
2015-08-04 16:16:10 +00:00
with patch('homeassistant.core.time.sleep', send_sigterm):
2015-08-04 16:16:10 +00:00
self.hass.block_till_stopped()
self.assertEqual(1, len(calls))
2014-11-23 17:51:16 +00:00
class TestEvent(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""A Test Event class."""
2015-08-04 16:16:10 +00:00
def test_eq(self):
2016-03-09 09:25:50 +00:00
"""Test events."""
2015-08-04 16:16:10 +00:00
now = dt_util.utcnow()
data = {'some': 'attr'}
event1, event2 = [
ha.Event('some_type', data, time_fired=now)
for _ in range(2)
]
self.assertEqual(event1, event2)
2014-11-23 17:51:16 +00:00
def test_repr(self):
2016-03-09 10:15:04 +00:00
"""Test that repr method works."""
2014-11-23 17:51:16 +00:00
self.assertEqual(
"<Event TestEvent[L]>",
str(ha.Event("TestEvent")))
self.assertEqual(
"<Event TestEvent[R]: beer=nice>",
str(ha.Event("TestEvent",
{"beer": "nice"},
ha.EventOrigin.remote)))
2015-08-04 16:16:10 +00:00
def test_as_dict(self):
2016-03-09 09:25:50 +00:00
"""Test as dictionary."""
2015-08-04 16:16:10 +00:00
event_type = 'some_type'
now = dt_util.utcnow()
data = {'some': 'attr'}
event = ha.Event(event_type, data, ha.EventOrigin.local, now)
expected = {
'event_type': event_type,
'data': data,
'origin': 'LOCAL',
2016-04-16 07:55:35 +00:00
'time_fired': now,
2015-08-04 16:16:10 +00:00
}
self.assertEqual(expected, event.as_dict())
2014-11-23 17:51:16 +00:00
class TestEventBus(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""Test EventBus methods."""
2014-11-23 17:51:16 +00:00
def setUp(self): # pylint: disable=invalid-name
2016-03-09 09:25:50 +00:00
"""Setup things to be run when tests are started."""
2015-08-04 16:16:10 +00:00
self.bus = ha.EventBus(ha.create_worker_pool(0))
2014-11-23 17:51:16 +00:00
self.bus.listen('test_event', lambda x: len)
2014-11-23 20:57:29 +00:00
def tearDown(self): # pylint: disable=invalid-name
2016-03-09 09:25:50 +00:00
"""Stop down stuff we started."""
2014-11-23 20:57:29 +00:00
self.bus._pool.stop()
2014-11-23 17:51:16 +00:00
def test_add_remove_listener(self):
2016-03-09 09:25:50 +00:00
"""Test remove_listener method."""
2015-08-04 16:16:10 +00:00
self.bus._pool.add_worker()
2014-11-23 17:51:16 +00:00
old_count = len(self.bus.listeners)
2016-02-14 06:57:40 +00:00
def listener(_): pass
2014-11-23 17:51:16 +00:00
self.bus.listen('test', listener)
self.assertEqual(old_count + 1, len(self.bus.listeners))
# Try deleting a non registered listener, nothing should happen
self.bus.remove_listener('test', lambda x: len)
# Remove listener
self.bus.remove_listener('test', listener)
self.assertEqual(old_count, len(self.bus.listeners))
# Try deleting listener while category doesn't exist either
self.bus.remove_listener('test', listener)
2014-11-29 07:19:59 +00:00
def test_listen_once_event(self):
2016-03-09 09:25:50 +00:00
"""Test listen_once_event method."""
2014-11-29 07:19:59 +00:00
runs = []
self.bus.listen_once('test_event', lambda x: runs.append(1))
self.bus.fire('test_event')
# Second time it should not increase runs
self.bus.fire('test_event')
2015-08-04 16:16:10 +00:00
self.bus._pool.add_worker()
2014-11-29 07:19:59 +00:00
self.bus._pool.block_till_done()
self.assertEqual(1, len(runs))
2014-11-23 17:51:16 +00:00
class TestState(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""Test State methods."""
2014-11-23 17:51:16 +00:00
def test_init(self):
2016-03-09 09:25:50 +00:00
"""Test state.init."""
2014-11-23 17:51:16 +00:00
self.assertRaises(
2015-08-30 02:44:59 +00:00
InvalidEntityFormatError, ha.State,
2014-11-23 17:51:16 +00:00
'invalid_entity_format', 'test_state')
2015-08-04 16:16:10 +00:00
def test_domain(self):
2016-03-09 09:25:50 +00:00
"""Test domain."""
2015-08-04 16:16:10 +00:00
state = ha.State('some_domain.hello', 'world')
self.assertEqual('some_domain', state.domain)
def test_object_id(self):
2016-03-09 09:25:50 +00:00
"""Test object ID."""
2015-08-04 16:16:10 +00:00
state = ha.State('domain.hello', 'world')
self.assertEqual('hello', state.object_id)
def test_name_if_no_friendly_name_attr(self):
2016-03-09 09:25:50 +00:00
"""Test if there is no friendly name."""
2015-08-04 16:16:10 +00:00
state = ha.State('domain.hello_world', 'world')
self.assertEqual('hello world', state.name)
def test_name_if_friendly_name_attr(self):
2016-03-09 09:25:50 +00:00
"""Test if there is a friendly name."""
2015-08-04 16:16:10 +00:00
name = 'Some Unique Name'
state = ha.State('domain.hello_world', 'world',
{ATTR_FRIENDLY_NAME: name})
self.assertEqual(name, state.name)
def test_dict_conversion(self):
2016-03-09 09:25:50 +00:00
"""Test conversion of dict."""
2015-08-04 16:16:10 +00:00
state = ha.State('domain.hello', 'world', {'some': 'attr'})
self.assertEqual(state, ha.State.from_dict(state.as_dict()))
def test_dict_conversion_with_wrong_data(self):
2016-03-09 09:25:50 +00:00
"""Test conversion with wrong data."""
2015-08-04 16:16:10 +00:00
self.assertIsNone(ha.State.from_dict(None))
self.assertIsNone(ha.State.from_dict({'state': 'yes'}))
self.assertIsNone(ha.State.from_dict({'entity_id': 'yes'}))
2014-11-23 17:51:16 +00:00
def test_repr(self):
2016-03-09 09:25:50 +00:00
"""Test state.repr."""
2016-04-16 07:55:35 +00:00
self.assertEqual("<state happy.happy=on @ 1984-12-08T12:00:00+00:00>",
2014-11-23 17:51:16 +00:00
str(ha.State(
"happy.happy", "on",
last_changed=datetime(1984, 12, 8, 12, 0, 0))))
self.assertEqual(
2016-04-16 07:55:35 +00:00
"<state happy.happy=on; brightness=144 @ "
"1984-12-08T12:00:00+00:00>",
str(ha.State("happy.happy", "on", {"brightness": 144},
datetime(1984, 12, 8, 12, 0, 0))))
2014-11-23 17:51:16 +00:00
class TestStateMachine(unittest.TestCase):
2016-03-09 10:15:04 +00:00
"""Test State machine methods."""
2014-11-23 17:51:16 +00:00
def setUp(self): # pylint: disable=invalid-name
2016-03-09 09:25:50 +00:00
"""Setup things to be run when tests are started."""
2015-08-04 16:16:10 +00:00
self.pool = ha.create_worker_pool(0)
self.bus = ha.EventBus(self.pool)
2014-11-23 17:51:16 +00:00
self.states = ha.StateMachine(self.bus)
self.states.set("light.Bowl", "on")
self.states.set("switch.AC", "off")
2014-11-23 20:57:29 +00:00
def tearDown(self): # pylint: disable=invalid-name
2016-03-09 09:25:50 +00:00
"""Stop down stuff we started."""
2015-08-04 16:16:10 +00:00
self.pool.stop()
2014-11-23 20:57:29 +00:00
2014-11-23 17:51:16 +00:00
def test_is_state(self):
2016-03-09 09:25:50 +00:00
"""Test is_state method."""
2014-11-23 17:51:16 +00:00
self.assertTrue(self.states.is_state('light.Bowl', 'on'))
self.assertFalse(self.states.is_state('light.Bowl', 'off'))
self.assertFalse(self.states.is_state('light.Non_existing', 'on'))
def test_is_state_attr(self):
2016-03-09 09:25:50 +00:00
"""Test is_state_attr method."""
self.states.set("light.Bowl", "on", {"brightness": 100})
self.assertTrue(
self.states.is_state_attr('light.Bowl', 'brightness', 100))
self.assertFalse(
self.states.is_state_attr('light.Bowl', 'friendly_name', 200))
self.assertFalse(
self.states.is_state_attr('light.Bowl', 'friendly_name', 'Bowl'))
self.assertFalse(
self.states.is_state_attr('light.Non_existing', 'brightness', 100))
2014-11-29 07:19:59 +00:00
def test_entity_ids(self):
2016-03-09 09:25:50 +00:00
"""Test get_entity_ids method."""
2014-11-29 07:19:59 +00:00
ent_ids = self.states.entity_ids()
self.assertEqual(2, len(ent_ids))
2015-02-06 08:17:30 +00:00
self.assertTrue('light.bowl' in ent_ids)
self.assertTrue('switch.ac' in ent_ids)
2014-11-29 07:19:59 +00:00
ent_ids = self.states.entity_ids('light')
self.assertEqual(1, len(ent_ids))
2015-02-06 08:17:30 +00:00
self.assertTrue('light.bowl' in ent_ids)
2014-11-29 07:19:59 +00:00
2015-08-04 16:16:10 +00:00
def test_all(self):
2016-03-09 09:25:50 +00:00
"""Test everything."""
2015-08-04 16:16:10 +00:00
states = sorted(state.entity_id for state in self.states.all())
self.assertEqual(['light.bowl', 'switch.ac'], states)
2014-11-23 17:51:16 +00:00
def test_remove(self):
2016-03-09 09:25:50 +00:00
"""Test remove method."""
2016-02-14 06:57:40 +00:00
self.pool.add_worker()
events = []
self.bus.listen(EVENT_STATE_CHANGED,
lambda event: events.append(event))
self.assertIn('light.bowl', self.states.entity_ids())
2015-02-06 08:17:30 +00:00
self.assertTrue(self.states.remove('light.bowl'))
2016-02-14 06:57:40 +00:00
self.pool.block_till_done()
self.assertNotIn('light.bowl', self.states.entity_ids())
self.assertEqual(1, len(events))
self.assertEqual('light.bowl', events[0].data.get('entity_id'))
self.assertIsNotNone(events[0].data.get('old_state'))
self.assertEqual('light.bowl', events[0].data['old_state'].entity_id)
self.assertIsNone(events[0].data.get('new_state'))
2014-11-23 17:51:16 +00:00
# If it does not exist, we should get False
self.assertFalse(self.states.remove('light.Bowl'))
2016-02-14 06:57:40 +00:00
self.pool.block_till_done()
self.assertEqual(1, len(events))
2014-11-23 17:51:16 +00:00
def test_case_insensitivty(self):
2016-03-09 09:25:50 +00:00
"""Test insensitivty."""
2015-08-04 16:16:10 +00:00
self.pool.add_worker()
runs = []
2016-02-10 07:59:31 +00:00
self.bus.listen(EVENT_STATE_CHANGED, lambda event: runs.append(event))
self.states.set('light.BOWL', 'off')
self.bus._pool.block_till_done()
self.assertTrue(self.states.is_state('light.bowl', 'off'))
self.assertEqual(1, len(runs))
def test_last_changed_not_updated_on_same_state(self):
2016-03-09 09:25:50 +00:00
"""Test to not update the existing, same state."""
state = self.states.get('light.Bowl')
2015-09-13 05:56:49 +00:00
future = dt_util.utcnow() + timedelta(hours=10)
2015-09-13 05:56:49 +00:00
with patch('homeassistant.util.dt.utcnow', return_value=future):
self.states.set("light.Bowl", "on", {'attr': 'triggers_change'})
self.assertEqual(state.last_changed,
self.states.get('light.Bowl').last_changed)
def test_force_update(self):
"""Test force update option."""
self.pool.add_worker()
events = []
self.bus.listen(EVENT_STATE_CHANGED, events.append)
self.states.set('light.bowl', 'on')
self.bus._pool.block_till_done()
self.assertEqual(0, len(events))
self.states.set('light.bowl', 'on', None, True)
self.bus._pool.block_till_done()
self.assertEqual(1, len(events))
2014-11-23 17:51:16 +00:00
class TestServiceCall(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""Test ServiceCall class."""
2014-11-23 17:51:16 +00:00
def test_repr(self):
2016-03-09 09:25:50 +00:00
"""Test repr method."""
2014-11-23 17:51:16 +00:00
self.assertEqual(
"<ServiceCall homeassistant.start>",
str(ha.ServiceCall('homeassistant', 'start')))
self.assertEqual(
"<ServiceCall homeassistant.start: fast=yes>",
str(ha.ServiceCall('homeassistant', 'start', {"fast": "yes"})))
class TestServiceRegistry(unittest.TestCase):
2016-03-09 10:15:04 +00:00
"""Test ServicerRegistry methods."""
2014-11-23 17:51:16 +00:00
def setUp(self): # pylint: disable=invalid-name
2016-03-09 09:25:50 +00:00
"""Setup things to be run when tests are started."""
2015-08-04 16:16:10 +00:00
self.pool = ha.create_worker_pool(0)
2014-11-23 20:57:29 +00:00
self.bus = ha.EventBus(self.pool)
def add_job(*args, **kwargs):
"""Forward calls to add_job on Home Assistant."""
# self works because we also have self.pool defined.
return ha.HomeAssistant.add_job(self, *args, **kwargs)
self.services = ha.ServiceRegistry(self.bus, add_job)
self.services.register("Test_Domain", "TEST_SERVICE", lambda x: None)
2014-11-23 17:51:16 +00:00
2014-11-23 20:57:29 +00:00
def tearDown(self): # pylint: disable=invalid-name
2016-03-09 09:25:50 +00:00
"""Stop down stuff we started."""
2015-08-04 16:16:10 +00:00
if self.pool.worker_count:
self.pool.stop()
2014-11-23 20:57:29 +00:00
2014-11-23 17:51:16 +00:00
def test_has_service(self):
2016-03-09 09:25:50 +00:00
"""Test has_service method."""
2014-11-23 17:51:16 +00:00
self.assertTrue(
self.services.has_service("tesT_domaiN", "tesT_servicE"))
2015-08-04 16:16:10 +00:00
self.assertFalse(
self.services.has_service("test_domain", "non_existing"))
self.assertFalse(
self.services.has_service("non_existing", "test_service"))
def test_services(self):
2016-03-09 09:25:50 +00:00
"""Test services."""
2015-08-04 16:16:10 +00:00
expected = {
2015-09-27 06:17:04 +00:00
'test_domain': {'test_service': {'description': '', 'fields': {}}}
2015-08-04 16:16:10 +00:00
}
self.assertEqual(expected, self.services.services)
def test_call_with_blocking_done_in_time(self):
2016-03-09 09:25:50 +00:00
"""Test call with blocking."""
2015-08-04 16:16:10 +00:00
self.pool.add_worker()
self.pool.add_worker()
calls = []
self.services.register("test_domain", "register_calls",
lambda x: calls.append(1))
self.assertTrue(
self.services.call('test_domain', 'REGISTER_CALLS', blocking=True))
2015-08-04 16:16:10 +00:00
self.assertEqual(1, len(calls))
def test_call_with_blocking_not_done_in_time(self):
2016-03-09 09:25:50 +00:00
"""Test with blocking."""
2015-08-04 16:16:10 +00:00
calls = []
self.services.register("test_domain", "register_calls",
lambda x: calls.append(1))
orig_limit = ha.SERVICE_CALL_LIMIT
ha.SERVICE_CALL_LIMIT = 0.01
self.assertFalse(
self.services.call('test_domain', 'register_calls', blocking=True))
self.assertEqual(0, len(calls))
ha.SERVICE_CALL_LIMIT = orig_limit
def test_call_non_existing_with_blocking(self):
2016-03-09 09:25:50 +00:00
"""Test non-existing with blocking."""
2015-08-04 16:16:10 +00:00
self.pool.add_worker()
self.pool.add_worker()
orig_limit = ha.SERVICE_CALL_LIMIT
ha.SERVICE_CALL_LIMIT = 0.01
self.assertFalse(
self.services.call('test_domain', 'i_do_not_exist', blocking=True))
ha.SERVICE_CALL_LIMIT = orig_limit
class TestConfig(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""Test configuration methods."""
2015-08-04 16:16:10 +00:00
def setUp(self): # pylint: disable=invalid-name
2016-03-09 10:15:04 +00:00
"""Setup things to be run when tests are started."""
2015-08-04 16:16:10 +00:00
self.config = ha.Config()
2016-08-09 03:21:40 +00:00
self.assertIsNone(self.config.config_dir)
2015-08-04 16:16:10 +00:00
def test_path_with_file(self):
2016-03-09 09:25:50 +00:00
"""Test get_config_path method."""
2016-08-09 03:21:40 +00:00
self.config.config_dir = '/tmp/ha-config'
self.assertEqual("/tmp/ha-config/test.conf",
2015-08-04 16:16:10 +00:00
self.config.path("test.conf"))
def test_path_with_dir_and_file(self):
2016-03-09 09:25:50 +00:00
"""Test get_config_path method."""
2016-08-09 03:21:40 +00:00
self.config.config_dir = '/tmp/ha-config'
self.assertEqual("/tmp/ha-config/dir/test.conf",
self.config.path("dir", "test.conf"))
2015-08-04 16:16:10 +00:00
def test_as_dict(self):
2016-03-09 09:25:50 +00:00
"""Test as dict."""
2015-08-04 16:16:10 +00:00
expected = {
'latitude': None,
'longitude': None,
Add unit system support Add unit symbol constants Initial unit system object Import more constants Pydoc for unit system file Import constants for configuration validation Unit system validation method Typing for constants Inches are valid lengths too Typings Change base class to dict - needed for remote api call serialization Validation Use dictionary keys Defined unit systems Update location util to use metric instead of us fahrenheit Update constant imports Import defined unit systems Update configuration to use unit system Update schema to use unit system Update constants Add imports to core for unit system and distance Type for config Default unit system Convert distance from HASS instance Update temperature conversion to use unit system Update temperature conversion Set unit system based on configuration Set info unit system Return unit system dictionary with config dictionary Auto discover unit system Update location test for use metric Update forecast unit system Update mold indicator unit system Update thermostat unit system Update thermostat demo test Unit tests around unit system Update test common hass configuration Update configuration unit tests There should always be a unit system! Update core unit tests Constants typing Linting issues Remove unused import Update fitbit sensor to use application unit system Update google travel time to use application unit system Update configuration example Update dht sensor Update DHT temperature conversion to use the utility function Update swagger config Update my sensors metric flag Update hvac component temperature conversion HVAC conversion for temperature Pull unit from sensor type map Pull unit from sensor type map Update the temper sensor unit Update yWeather sensor unit Update hvac demo unit test Set unit test config unit system to metric Use hass unit system length for default in proximity Use the name of the system instead of temperature Use constants from const Unused import Forecasted temperature Fix calculation in case furthest distance is greater than 1000000 units Remove unneeded constants Set default length to km or miles Use constants Linting doesn't like importing just for typing Fix reference Test is expecting meters - set config to meters Use constant Use constant PyDoc for unit test Should be not in Rename to units Change unit system to be an object - not a dictionary Return tuple in conversion Move convert to temperature util Temperature conversion is now in unit system Update imports Rename to units Units is now an object Use temperature util conversion Unit system is now an object Validate and convert unit system config Return the scalar value in template distance Test is expecting meters Update unit tests around unit system Distance util returns tuple Fix location info test Set units Update unit tests Convert distance DOH Pull out the scalar from the vector Linting I really hate python linting Linting again BLARG Unit test documentation Unit test around is metric flag Break ternary statement into if/else blocks Don't use dictionary - use members is metric flag Rename constants Use is metric flag Move constants to CONST file Move to const file Raise error if unit is not expected Typing No need to return unit since only performing conversion if it can work Use constants Line wrapping Raise error if invalid value Remove subscripts from conversion as they are no longer returned as tuples No longer tuples No longer tuples Check for numeric type Fix string format to use correct variable Typing Assert errors raised Remove subscript Only convert temperature if we know the unit If no unit of measurement set - default to HASS config Convert only if we know the unit Remove subscription Fix not in clause Linting fixes Wants a boolean Clearer if-block Check if the key is in the config first Missed a couple expecting tuples Backwards compatibility No like-y ternary! Error handling around state setting Pretty unit system configuration validation More tuple crap Use is metric flag Error handling around min/max temp Explode if no unit Pull unit from config Celsius has a decimal Unused import Check if it's a temperature before we try to convert it to a temperature Linting says too many statements - combine lat/long in a fairly reasonable manner Backwards compatibility unit test Better doc
2016-07-31 20:24:49 +00:00
CONF_UNIT_SYSTEM: METRIC_SYSTEM.as_dict(),
2015-08-04 16:16:10 +00:00
'location_name': None,
'time_zone': 'UTC',
'components': [],
2015-10-26 04:00:22 +00:00
'version': __version__,
2015-08-04 16:16:10 +00:00
}
self.assertEqual(expected, self.config.as_dict())
class TestWorkerPool(unittest.TestCase):
2016-03-09 09:25:50 +00:00
"""Test WorkerPool methods."""
2015-08-04 16:16:10 +00:00
def test_exception_during_job(self):
2016-03-09 09:25:50 +00:00
"""Test exception during a job."""
2015-08-04 16:16:10 +00:00
pool = ha.create_worker_pool(1)
def malicious_job(_):
raise Exception("Test breaking worker pool")
calls = []
def register_call(_):
calls.append(1)
pool.add_job(ha.JobPriority.EVENT_DEFAULT, (malicious_job, None))
pool.add_job(ha.JobPriority.EVENT_DEFAULT, (register_call, None))
pool.block_till_done()
self.assertEqual(1, len(calls))