2013-09-28 18:09:36 +00:00
|
|
|
"""
|
|
|
|
homeassistant.test
|
|
|
|
~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Provides tests to verify that Home Assistant modules do what they should do.
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
import time
|
|
|
|
|
|
|
|
import requests
|
|
|
|
|
2013-10-13 16:40:38 +00:00
|
|
|
import homeassistant as ha
|
2013-10-25 10:05:58 +00:00
|
|
|
import homeassistant.remote as remote
|
2014-04-29 07:30:31 +00:00
|
|
|
import homeassistant.components.http as http
|
2013-10-28 00:39:54 +00:00
|
|
|
|
2013-09-28 18:09:36 +00:00
|
|
|
API_PASSWORD = "test1234"
|
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
HTTP_BASE_URL = "http://127.0.0.1:{}".format(remote.SERVER_PORT)
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-11-11 00:46:48 +00:00
|
|
|
|
2013-11-01 18:34:43 +00:00
|
|
|
def _url(path=""):
|
|
|
|
""" Helper method to generate urls. """
|
|
|
|
return HTTP_BASE_URL + path
|
|
|
|
|
2013-11-11 00:46:48 +00:00
|
|
|
|
|
|
|
class HAHelper(object): # pylint: disable=too-few-public-methods
|
2013-11-01 18:34:43 +00:00
|
|
|
""" Helper class to keep track of current running HA instance. """
|
2014-04-24 07:40:45 +00:00
|
|
|
hass = None
|
2014-04-29 07:30:31 +00:00
|
|
|
slave = None
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-11-11 00:46:48 +00:00
|
|
|
|
2013-11-01 18:34:43 +00:00
|
|
|
def ensure_homeassistant_started():
|
|
|
|
""" Ensures home assistant is started. """
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
if not HAHelper.hass:
|
|
|
|
hass = ha.HomeAssistant()
|
2013-10-29 07:22:38 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
hass.bus.listen('test_event', len)
|
|
|
|
hass.states.set('test', 'a_state')
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2014-08-13 12:28:45 +00:00
|
|
|
http.setup(hass,
|
|
|
|
{http.DOMAIN: {http.CONF_API_PASSWORD: API_PASSWORD}})
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
hass.start()
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-11-01 18:34:43 +00:00
|
|
|
# Give objects time to startup
|
|
|
|
time.sleep(1)
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
HAHelper.hass = hass
|
2013-11-01 18:34:43 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
return HAHelper.hass
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-11-11 00:46:48 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def ensure_slave_started():
|
|
|
|
""" Ensure a home assistant slave is started. """
|
|
|
|
|
2014-08-13 12:28:45 +00:00
|
|
|
ensure_homeassistant_started()
|
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
if not HAHelper.slave:
|
|
|
|
local_api = remote.API("127.0.0.1", API_PASSWORD, 8124)
|
|
|
|
remote_api = remote.API("127.0.0.1", API_PASSWORD)
|
2014-08-13 12:28:45 +00:00
|
|
|
slave = remote.HomeAssistant(remote_api, local_api)
|
2014-04-29 07:30:31 +00:00
|
|
|
|
2014-08-13 12:28:45 +00:00
|
|
|
http.setup(slave,
|
|
|
|
{http.DOMAIN: {http.CONF_API_PASSWORD: API_PASSWORD,
|
|
|
|
http.CONF_SERVER_PORT: 8124}})
|
2014-04-29 07:30:31 +00:00
|
|
|
|
|
|
|
slave.start()
|
|
|
|
|
|
|
|
# Give objects time to startup
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
HAHelper.slave = slave
|
|
|
|
|
|
|
|
return HAHelper.slave
|
|
|
|
|
|
|
|
|
2013-11-01 18:34:43 +00:00
|
|
|
# pylint: disable=too-many-public-methods
|
2014-08-13 12:28:45 +00:00
|
|
|
class TestHTTP(unittest.TestCase):
|
2013-11-01 18:34:43 +00:00
|
|
|
""" Test the HTTP debug interface and API. """
|
2013-10-08 06:55:19 +00:00
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls): # pylint: disable=invalid-name
|
|
|
|
""" things to be run when tests are started. """
|
2014-04-24 07:40:45 +00:00
|
|
|
cls.hass = ensure_homeassistant_started()
|
2013-10-08 06:55:19 +00:00
|
|
|
|
2013-09-28 18:09:36 +00:00
|
|
|
def test_debug_interface(self):
|
2013-10-08 06:55:19 +00:00
|
|
|
""" Test if we can login by comparing not logged in screen to
|
|
|
|
logged in screen. """
|
2013-10-29 07:22:38 +00:00
|
|
|
|
|
|
|
with_pw = requests.get(
|
2013-11-11 00:46:48 +00:00
|
|
|
_url("/?api_password={}".format(API_PASSWORD)))
|
2013-10-29 07:22:38 +00:00
|
|
|
|
2013-11-01 18:34:43 +00:00
|
|
|
without_pw = requests.get(_url())
|
2013-10-29 07:22:38 +00:00
|
|
|
|
|
|
|
self.assertNotEqual(without_pw.text, with_pw.text)
|
2013-09-28 18:09:36 +00:00
|
|
|
|
|
|
|
def test_api_password(self):
|
2013-10-08 06:55:19 +00:00
|
|
|
""" Test if we get access denied if we omit or provide
|
|
|
|
a wrong api password. """
|
2013-11-01 19:28:18 +00:00
|
|
|
req = requests.get(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_STATES_ENTITY.format("test")))
|
2013-09-28 18:09:36 +00:00
|
|
|
|
|
|
|
self.assertEqual(req.status_code, 401)
|
|
|
|
|
2013-11-01 19:28:18 +00:00
|
|
|
req = requests.get(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_STATES_ENTITY.format("test")),
|
2013-11-11 00:46:48 +00:00
|
|
|
params={"api_password": "not the password"})
|
2013-09-28 18:09:36 +00:00
|
|
|
|
|
|
|
self.assertEqual(req.status_code, 401)
|
|
|
|
|
2013-11-05 01:16:27 +00:00
|
|
|
def test_debug_change_state(self):
|
|
|
|
""" Test if we can change a state from the debug interface. """
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.states.set("test.test", "not_to_be_set")
|
2013-11-05 01:16:27 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
requests.post(_url(http.URL_CHANGE_STATE),
|
2014-01-20 07:37:40 +00:00
|
|
|
data={"entity_id": "test.test",
|
2013-11-11 00:46:48 +00:00
|
|
|
"new_state": "debug_state_change2",
|
|
|
|
"api_password": API_PASSWORD})
|
2013-11-05 01:16:27 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.assertEqual(self.hass.states.get("test.test").state,
|
2013-11-05 01:16:27 +00:00
|
|
|
"debug_state_change2")
|
|
|
|
|
|
|
|
def test_debug_fire_event(self):
|
|
|
|
""" Test if we can fire an event from the debug interface. """
|
|
|
|
test_value = []
|
|
|
|
|
|
|
|
def listener(event): # pylint: disable=unused-argument
|
|
|
|
""" Helper method that will verify that our event got called and
|
|
|
|
that test if our data came through. """
|
|
|
|
if "test" in event.data:
|
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.listen_once_event("test_event_with_data", listener)
|
2013-11-05 01:16:27 +00:00
|
|
|
|
|
|
|
requests.post(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(http.URL_FIRE_EVENT),
|
2013-11-05 01:16:27 +00:00
|
|
|
data={"event_type": "test_event_with_data",
|
2013-11-11 00:46:48 +00:00
|
|
|
"event_data": '{"test": 1}',
|
|
|
|
"api_password": API_PASSWORD})
|
2013-11-05 01:16:27 +00:00
|
|
|
|
|
|
|
# Allow the event to take place
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
self.assertEqual(len(test_value), 1)
|
|
|
|
|
2014-01-20 07:37:40 +00:00
|
|
|
def test_api_list_state_entities(self):
|
|
|
|
""" Test if the debug interface allows us to list state entities. """
|
2014-04-29 07:30:31 +00:00
|
|
|
req = requests.get(_url(remote.URL_API_STATES),
|
2013-11-11 00:46:48 +00:00
|
|
|
data={"api_password": API_PASSWORD})
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
remote_data = req.json()
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
local_data = {entity_id: state.as_dict() for entity_id, state
|
|
|
|
in self.hass.states.all().items()}
|
|
|
|
|
|
|
|
self.assertEqual(local_data, remote_data)
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
def test_api_get(self):
|
2013-10-29 07:22:38 +00:00
|
|
|
""" Test if the debug interface allows us to get a state. """
|
|
|
|
req = requests.get(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_STATES_ENTITY.format("test")),
|
2013-11-11 00:46:48 +00:00
|
|
|
data={"api_password": API_PASSWORD})
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-01-23 03:40:19 +00:00
|
|
|
data = ha.State.from_dict(req.json())
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
state = self.hass.states.get("test")
|
2013-10-28 00:39:54 +00:00
|
|
|
|
2014-01-20 03:10:40 +00:00
|
|
|
self.assertEqual(data.state, state.state)
|
|
|
|
self.assertEqual(data.last_changed, state.last_changed)
|
|
|
|
self.assertEqual(data.attributes, state.attributes)
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2013-11-01 18:34:43 +00:00
|
|
|
def test_api_get_non_existing_state(self):
|
|
|
|
""" Test if the debug interface allows us to get a state. """
|
|
|
|
req = requests.get(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_STATES_ENTITY.format("does_not_exist")),
|
2013-11-11 00:46:48 +00:00
|
|
|
params={"api_password": API_PASSWORD})
|
2013-11-01 18:34:43 +00:00
|
|
|
|
|
|
|
self.assertEqual(req.status_code, 422)
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2013-09-28 18:09:36 +00:00
|
|
|
def test_api_state_change(self):
|
2014-01-20 07:37:40 +00:00
|
|
|
""" Test if we can change the state of an entity that exists. """
|
2013-10-05 19:28:18 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.states.set("test.test", "not_to_be_set")
|
2013-10-05 19:28:18 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
requests.post(_url(remote.URL_API_STATES_ENTITY.format("test.test")),
|
2013-11-11 00:46:48 +00:00
|
|
|
data={"new_state": "debug_state_change2",
|
|
|
|
"api_password": API_PASSWORD})
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.assertEqual(self.hass.states.get("test.test").state,
|
2013-10-08 06:55:19 +00:00
|
|
|
"debug_state_change2")
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-10-08 06:55:19 +00:00
|
|
|
# pylint: disable=invalid-name
|
2014-01-20 07:37:40 +00:00
|
|
|
def test_api_state_change_of_non_existing_entity(self):
|
2013-10-08 06:55:19 +00:00
|
|
|
""" Test if the API allows us to change a state of
|
2014-01-20 07:37:40 +00:00
|
|
|
a non existing entity. """
|
2013-10-08 06:55:19 +00:00
|
|
|
|
|
|
|
new_state = "debug_state_change"
|
2013-10-05 19:28:18 +00:00
|
|
|
|
2013-10-29 07:22:38 +00:00
|
|
|
req = requests.post(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_STATES_ENTITY.format(
|
2014-01-20 07:37:40 +00:00
|
|
|
"test_entity_that_does_not_exist")),
|
2013-11-11 00:46:48 +00:00
|
|
|
data={"new_state": new_state,
|
|
|
|
"api_password": API_PASSWORD})
|
2013-10-08 06:55:19 +00:00
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
cur_state = (self.hass.states.
|
|
|
|
get("test_entity_that_does_not_exist").state)
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-10-29 07:22:38 +00:00
|
|
|
self.assertEqual(req.status_code, 201)
|
2013-10-08 06:55:19 +00:00
|
|
|
self.assertEqual(cur_state, new_state)
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-10-08 06:55:19 +00:00
|
|
|
# pylint: disable=invalid-name
|
2013-09-28 18:09:36 +00:00
|
|
|
def test_api_fire_event_with_no_data(self):
|
|
|
|
""" Test if the API allows us to fire an event. """
|
|
|
|
test_value = []
|
|
|
|
|
2013-10-08 06:55:19 +00:00
|
|
|
def listener(event): # pylint: disable=unused-argument
|
2013-09-28 18:09:36 +00:00
|
|
|
""" Helper method that will verify our event got called. """
|
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.listen_once_event("test.event_no_data", listener)
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-10-29 07:22:38 +00:00
|
|
|
requests.post(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_EVENTS_EVENT.format("test.event_no_data")),
|
2013-11-11 00:46:48 +00:00
|
|
|
data={"api_password": API_PASSWORD})
|
2013-09-28 18:09:36 +00:00
|
|
|
|
|
|
|
# Allow the event to take place
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
self.assertEqual(len(test_value), 1)
|
|
|
|
|
2013-10-08 06:55:19 +00:00
|
|
|
# pylint: disable=invalid-name
|
2013-09-28 18:09:36 +00:00
|
|
|
def test_api_fire_event_with_data(self):
|
|
|
|
""" Test if the API allows us to fire an event. """
|
|
|
|
test_value = []
|
|
|
|
|
2013-10-08 06:55:19 +00:00
|
|
|
def listener(event): # pylint: disable=unused-argument
|
2013-09-28 18:09:36 +00:00
|
|
|
""" Helper method that will verify that our event got called and
|
|
|
|
that test if our data came through. """
|
|
|
|
if "test" in event.data:
|
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.listen_once_event("test_event_with_data", listener)
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-10-29 07:22:38 +00:00
|
|
|
requests.post(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_EVENTS_EVENT.format("test_event_with_data")),
|
2013-11-11 00:46:48 +00:00
|
|
|
data={"event_data": '{"test": 1}',
|
|
|
|
"api_password": API_PASSWORD})
|
2013-09-28 18:09:36 +00:00
|
|
|
|
|
|
|
# Allow the event to take place
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
self.assertEqual(len(test_value), 1)
|
|
|
|
|
2013-10-08 06:55:19 +00:00
|
|
|
# pylint: disable=invalid-name
|
2013-09-28 18:09:36 +00:00
|
|
|
def test_api_fire_event_with_invalid_json(self):
|
|
|
|
""" Test if the API allows us to fire an event. """
|
|
|
|
test_value = []
|
|
|
|
|
2013-10-08 06:55:19 +00:00
|
|
|
def listener(event): # pylint: disable=unused-argument
|
2013-09-28 18:09:36 +00:00
|
|
|
""" Helper method that will verify our event got called. """
|
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.listen_once_event("test_event_with_bad_data", listener)
|
2013-09-28 18:09:36 +00:00
|
|
|
|
2013-10-29 07:22:38 +00:00
|
|
|
req = requests.post(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_EVENTS_EVENT.format("test_event")),
|
2013-11-11 00:46:48 +00:00
|
|
|
data={"event_data": 'not json',
|
|
|
|
"api_password": API_PASSWORD})
|
2013-09-28 18:09:36 +00:00
|
|
|
|
|
|
|
# It shouldn't but if it fires, allow the event to take place
|
|
|
|
time.sleep(1)
|
|
|
|
|
2013-11-01 18:34:43 +00:00
|
|
|
self.assertEqual(req.status_code, 422)
|
2013-09-28 18:09:36 +00:00
|
|
|
self.assertEqual(len(test_value), 0)
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2013-11-01 19:28:18 +00:00
|
|
|
def test_api_get_event_listeners(self):
|
|
|
|
""" Test if we can get the list of events being listened for. """
|
2014-04-29 07:30:31 +00:00
|
|
|
req = requests.get(_url(remote.URL_API_EVENTS),
|
2013-11-11 00:46:48 +00:00
|
|
|
params={"api_password": API_PASSWORD})
|
2013-11-01 19:28:18 +00:00
|
|
|
|
|
|
|
data = req.json()
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.assertEqual(data['event_listeners'], self.hass.bus.listeners)
|
2013-11-20 07:48:08 +00:00
|
|
|
|
|
|
|
def test_api_get_services(self):
|
|
|
|
""" Test if we can get a dict describing current services. """
|
2014-04-29 07:30:31 +00:00
|
|
|
req = requests.get(_url(remote.URL_API_SERVICES),
|
2013-11-20 07:48:08 +00:00
|
|
|
params={"api_password": API_PASSWORD})
|
|
|
|
|
|
|
|
data = req.json()
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.assertEqual(data['services'], self.hass.services.services)
|
2013-11-20 07:48:08 +00:00
|
|
|
|
|
|
|
def test_api_call_service_no_data(self):
|
|
|
|
""" Test if the API allows us to call a service. """
|
|
|
|
test_value = []
|
|
|
|
|
|
|
|
def listener(service_call): # pylint: disable=unused-argument
|
|
|
|
""" Helper method that will verify that our service got called. """
|
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.services.register("test_domain", "test_service", listener)
|
2013-11-20 07:48:08 +00:00
|
|
|
|
|
|
|
requests.post(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_SERVICES_SERVICE.format(
|
2013-11-20 07:48:08 +00:00
|
|
|
"test_domain", "test_service")),
|
|
|
|
data={"api_password": API_PASSWORD})
|
|
|
|
|
|
|
|
# Allow the event to take place
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
self.assertEqual(len(test_value), 1)
|
|
|
|
|
|
|
|
def test_api_call_service_with_data(self):
|
|
|
|
""" Test if the API allows us to call a service. """
|
|
|
|
test_value = []
|
|
|
|
|
|
|
|
def listener(service_call): # pylint: disable=unused-argument
|
|
|
|
""" Helper method that will verify that our service got called and
|
|
|
|
that test if our data came through. """
|
|
|
|
if "test" in service_call.data:
|
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.services.register("test_domain", "test_service", listener)
|
2013-11-20 07:48:08 +00:00
|
|
|
|
|
|
|
requests.post(
|
2014-04-29 07:30:31 +00:00
|
|
|
_url(remote.URL_API_SERVICES_SERVICE.format(
|
2013-11-20 07:48:08 +00:00
|
|
|
"test_domain", "test_service")),
|
|
|
|
data={"service_data": '{"test": 1}',
|
|
|
|
"api_password": API_PASSWORD})
|
|
|
|
|
|
|
|
# Allow the event to take place
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
self.assertEqual(len(test_value), 1)
|
2013-11-01 19:28:18 +00:00
|
|
|
|
2013-11-11 00:46:48 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
class TestRemoteMethods(unittest.TestCase):
|
2013-11-01 18:34:43 +00:00
|
|
|
""" Test the homeassistant.remote module. """
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls): # pylint: disable=invalid-name
|
|
|
|
""" things to be run when tests are started. """
|
2014-04-24 07:40:45 +00:00
|
|
|
cls.hass = ensure_homeassistant_started()
|
2013-11-01 18:34:43 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
cls.api = remote.API("127.0.0.1", API_PASSWORD)
|
2013-11-01 18:34:43 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_get_event_listeners(self):
|
|
|
|
""" Test Python API get_event_listeners. """
|
2013-11-01 18:34:43 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
self.assertEqual(
|
|
|
|
remote.get_event_listeners(self.api), self.hass.bus.listeners)
|
2013-11-01 18:34:43 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_fire_event(self):
|
|
|
|
""" Test Python API fire_event. """
|
2013-10-25 10:05:58 +00:00
|
|
|
test_value = []
|
|
|
|
|
|
|
|
def listener(event): # pylint: disable=unused-argument
|
|
|
|
""" Helper method that will verify our event got called. """
|
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
self.hass.listen_once_event("test.event_no_data", listener)
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
remote.fire_event(self.api, "test.event_no_data")
|
2013-10-25 10:05:58 +00:00
|
|
|
|
|
|
|
# Allow the event to take place
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
self.assertEqual(len(test_value), 1)
|
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_get_state(self):
|
|
|
|
""" Test Python API get_state. """
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
self.assertEqual(
|
|
|
|
remote.get_state(self.api, 'test'), self.hass.states.get('test'))
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_get_states(self):
|
|
|
|
""" Test Python API get_state_entity_ids. """
|
2013-11-20 07:48:08 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
self.assertEqual(
|
|
|
|
remote.get_states(self.api), self.hass.states.all())
|
2013-11-20 07:48:08 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_set_state(self):
|
|
|
|
""" Test Python API set_state. """
|
|
|
|
remote.set_state(self.api, 'test', 'set_test')
|
2013-11-20 07:48:08 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
self.assertEqual(self.hass.states.get('test').state, 'set_test')
|
2013-11-20 07:48:08 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_is_state(self):
|
|
|
|
""" Test Python API is_state. """
|
|
|
|
|
|
|
|
self.assertEqual(
|
|
|
|
remote.is_state(self.api, 'test',
|
|
|
|
self.hass.states.get('test').state),
|
|
|
|
True)
|
|
|
|
|
|
|
|
def test_get_services(self):
|
|
|
|
""" Test Python API get_services. """
|
|
|
|
|
|
|
|
self.assertEqual(
|
|
|
|
remote.get_services(self.api), self.hass.services.services)
|
|
|
|
|
|
|
|
def test_call_service(self):
|
|
|
|
""" Test Python API call_service. """
|
2013-11-20 07:48:08 +00:00
|
|
|
test_value = []
|
|
|
|
|
|
|
|
def listener(service_call): # pylint: disable=unused-argument
|
2014-04-29 07:30:31 +00:00
|
|
|
""" Helper method that will verify that our service got called. """
|
2013-11-20 07:48:08 +00:00
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-24 07:40:45 +00:00
|
|
|
self.hass.services.register("test_domain", "test_service", listener)
|
2013-11-20 07:48:08 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
remote.call_service(self.api, "test_domain", "test_service")
|
2013-11-20 07:48:08 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
# Allow the event to take place
|
2013-11-20 07:48:08 +00:00
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
self.assertEqual(len(test_value), 1)
|
|
|
|
|
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
class TestRemoteClasses(unittest.TestCase):
|
|
|
|
""" Test the homeassistant.remote module. """
|
2013-11-20 07:48:08 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpClass(cls): # pylint: disable=invalid-name
|
|
|
|
""" things to be run when tests are started. """
|
|
|
|
cls.hass = ensure_homeassistant_started()
|
|
|
|
cls.slave = ensure_slave_started()
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_statemachine_init(self):
|
|
|
|
""" Tests if remote.StateMachine copies all states on init. """
|
|
|
|
self.assertEqual(self.hass.states.all(), self.slave.states.all())
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_statemachine_set(self):
|
|
|
|
""" Tests if setting the state on a slave is recorded. """
|
|
|
|
self.slave.states.set("test", "remote.statemachine test")
|
|
|
|
|
|
|
|
# Allow interaction between 2 instances
|
2013-10-25 10:05:58 +00:00
|
|
|
time.sleep(1)
|
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
self.assertEqual(self.slave.states.get("test").state,
|
|
|
|
"remote.statemachine test")
|
2013-10-25 10:05:58 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
def test_eventbus_fire(self):
|
|
|
|
""" Test if events fired from the eventbus get fired. """
|
2013-10-29 01:45:35 +00:00
|
|
|
test_value = []
|
|
|
|
|
|
|
|
def listener(event): # pylint: disable=unused-argument
|
|
|
|
""" Helper method that will verify our event got called. """
|
|
|
|
test_value.append(1)
|
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
self.slave.listen_once_event("test.event_no_data", listener)
|
2013-10-29 01:45:35 +00:00
|
|
|
|
2014-04-29 07:30:31 +00:00
|
|
|
self.slave.bus.fire("test.event_no_data")
|
2013-10-29 01:45:35 +00:00
|
|
|
|
|
|
|
# Allow the event to take place
|
|
|
|
time.sleep(1)
|
|
|
|
|
|
|
|
self.assertEqual(len(test_value), 1)
|