2014-11-25 08:20:36 +00:00
|
|
|
"""
|
2015-01-09 04:05:12 +00:00
|
|
|
tests.helper
|
2014-12-01 07:14:08 +00:00
|
|
|
~~~~~~~~~~~~~
|
2014-11-25 08:20:36 +00:00
|
|
|
|
2014-12-01 07:14:08 +00:00
|
|
|
Helper method for writing tests.
|
2014-11-25 08:20:36 +00:00
|
|
|
"""
|
2014-12-01 07:14:08 +00:00
|
|
|
import os
|
|
|
|
|
|
|
|
import homeassistant as ha
|
2014-12-07 07:57:02 +00:00
|
|
|
from homeassistant.helpers import ToggleDevice
|
2015-01-11 17:20:41 +00:00
|
|
|
from homeassistant.const import STATE_ON, STATE_OFF, DEVICE_DEFAULT_NAME
|
2014-11-25 08:20:36 +00:00
|
|
|
|
|
|
|
|
2014-12-01 07:14:08 +00:00
|
|
|
def get_test_home_assistant():
|
|
|
|
""" Returns a Home Assistant object pointing at test config dir. """
|
|
|
|
hass = ha.HomeAssistant()
|
|
|
|
hass.config_dir = os.path.join(os.path.dirname(__file__), "config")
|
|
|
|
|
|
|
|
return hass
|
|
|
|
|
|
|
|
|
|
|
|
def mock_service(hass, domain, service):
|
|
|
|
"""
|
|
|
|
Sets up a fake service.
|
|
|
|
Returns a list that logs all calls to fake service.
|
|
|
|
"""
|
|
|
|
calls = []
|
|
|
|
|
|
|
|
hass.services.register(
|
|
|
|
domain, service, lambda call: calls.append(call))
|
|
|
|
|
|
|
|
return calls
|
|
|
|
|
|
|
|
|
|
|
|
class MockModule(object):
|
|
|
|
""" Provides a fake module. """
|
|
|
|
|
|
|
|
def __init__(self, domain, dependencies=[], setup=None):
|
|
|
|
self.DOMAIN = domain
|
|
|
|
self.DEPENDENCIES = dependencies
|
|
|
|
# Setup a mock setup if none given.
|
|
|
|
self.setup = lambda hass, config: False if setup is None else setup
|
|
|
|
|
|
|
|
|
2014-12-07 07:57:02 +00:00
|
|
|
class MockToggleDevice(ToggleDevice):
|
2014-12-01 07:14:08 +00:00
|
|
|
""" Provides a mock toggle device. """
|
2014-11-25 08:20:36 +00:00
|
|
|
def __init__(self, name, state):
|
2015-01-11 17:20:41 +00:00
|
|
|
self._name = name or DEVICE_DEFAULT_NAME
|
|
|
|
self._state = state
|
2014-11-26 05:28:43 +00:00
|
|
|
self.calls = []
|
2014-11-25 08:20:36 +00:00
|
|
|
|
2015-01-11 17:20:41 +00:00
|
|
|
@property
|
|
|
|
def name(self):
|
2014-11-25 08:20:36 +00:00
|
|
|
""" Returns the name of the device if any. """
|
2015-01-11 17:20:41 +00:00
|
|
|
self.calls.append(('name', {}))
|
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def state(self):
|
|
|
|
""" Returns the name of the device if any. """
|
|
|
|
self.calls.append(('state', {}))
|
|
|
|
return self._state
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self):
|
|
|
|
""" True if device is on. """
|
|
|
|
self.calls.append(('is_on', {}))
|
|
|
|
return self._state == STATE_ON
|
2014-11-25 08:20:36 +00:00
|
|
|
|
|
|
|
def turn_on(self, **kwargs):
|
|
|
|
""" Turn the device on. """
|
2014-11-26 05:28:43 +00:00
|
|
|
self.calls.append(('turn_on', kwargs))
|
2015-01-11 17:20:41 +00:00
|
|
|
self._state = STATE_ON
|
2014-11-25 08:20:36 +00:00
|
|
|
|
|
|
|
def turn_off(self, **kwargs):
|
|
|
|
""" Turn the device off. """
|
2014-11-26 05:28:43 +00:00
|
|
|
self.calls.append(('turn_off', kwargs))
|
2015-01-11 17:20:41 +00:00
|
|
|
self._state = STATE_OFF
|
2014-11-25 08:20:36 +00:00
|
|
|
|
2014-11-26 05:28:43 +00:00
|
|
|
def last_call(self, method=None):
|
|
|
|
if method is None:
|
|
|
|
return self.calls[-1]
|
|
|
|
else:
|
|
|
|
return next(call for call in reversed(self.calls)
|
|
|
|
if call[0] == method)
|