2015-09-13 10:53:37 +00:00
|
|
|
"""
|
2015-09-15 07:02:46 +00:00
|
|
|
tests.components.automation.test_numeric_state
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2015-09-13 10:53:37 +00:00
|
|
|
|
2015-09-15 07:02:46 +00:00
|
|
|
Tests numeric state automation.
|
2015-09-13 10:53:37 +00:00
|
|
|
"""
|
|
|
|
import unittest
|
|
|
|
|
|
|
|
import homeassistant.components.automation as automation
|
|
|
|
|
2016-02-14 23:08:23 +00:00
|
|
|
from tests.common import get_test_home_assistant
|
|
|
|
|
2015-09-13 10:53:37 +00:00
|
|
|
|
2015-09-13 17:59:26 +00:00
|
|
|
class TestAutomationNumericState(unittest.TestCase):
|
2015-09-13 10:53:37 +00:00
|
|
|
""" Test the event automation. """
|
|
|
|
|
|
|
|
def setUp(self): # pylint: disable=invalid-name
|
2016-02-14 23:08:23 +00:00
|
|
|
self.hass = get_test_home_assistant()
|
2015-09-13 10:53:37 +00:00
|
|
|
self.calls = []
|
|
|
|
|
|
|
|
def record_call(service):
|
|
|
|
self.calls.append(service)
|
|
|
|
|
|
|
|
self.hass.services.register('test', 'automation', record_call)
|
|
|
|
|
|
|
|
def tearDown(self): # pylint: disable=invalid-name
|
|
|
|
""" Stop down stuff we started. """
|
|
|
|
self.hass.stop()
|
|
|
|
|
|
|
|
def test_if_fires_on_entity_change_below(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 9 is below 10
|
|
|
|
self.hass.states.set('test.entity', 9)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_fires_on_entity_change_over_to_below(self):
|
|
|
|
self.hass.states.set('test.entity', 11)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
|
|
|
|
# 9 is below 10
|
|
|
|
self.hass.states.set('test.entity', 9)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_not_fires_on_entity_change_below_to_below(self):
|
|
|
|
self.hass.states.set('test.entity', 9)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
|
|
|
|
# 9 is below 10 so this should not fire again
|
|
|
|
self.hass.states.set('test.entity', 8)
|
|
|
|
self.hass.pool.block_till_done()
|
2015-09-13 17:59:26 +00:00
|
|
|
self.assertEqual(0, len(self.calls))
|
2015-09-13 10:53:37 +00:00
|
|
|
|
|
|
|
def test_if_fires_on_entity_change_above(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'above': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 11 is above 10
|
|
|
|
self.hass.states.set('test.entity', 11)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_fires_on_entity_change_below_to_above(self):
|
|
|
|
# set initial state
|
|
|
|
self.hass.states.set('test.entity', 9)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'above': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
|
|
|
|
# 11 is above 10 and 9 is below
|
|
|
|
self.hass.states.set('test.entity', 11)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_not_fires_on_entity_change_above_to_above(self):
|
|
|
|
# set initial state
|
|
|
|
self.hass.states.set('test.entity', 11)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'above': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
|
|
|
|
# 11 is above 10 so this should fire again
|
|
|
|
self.hass.states.set('test.entity', 12)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_fires_on_entity_change_below_range(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
'above': 5,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 9 is below 10
|
|
|
|
self.hass.states.set('test.entity', 9)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_fires_on_entity_change_below_above_range(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
'above': 5,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 4 is below 5
|
|
|
|
self.hass.states.set('test.entity', 4)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_fires_on_entity_change_over_to_below_range(self):
|
|
|
|
self.hass.states.set('test.entity', 11)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
'above': 5,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
|
|
|
|
# 9 is below 10
|
|
|
|
self.hass.states.set('test.entity', 9)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_fires_on_entity_change_over_to_below_above_range(self):
|
|
|
|
self.hass.states.set('test.entity', 11)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
'above': 5,
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
|
2015-09-13 11:05:36 +00:00
|
|
|
# 4 is below 5 so it should not fire
|
2015-09-13 10:53:37 +00:00
|
|
|
self.hass.states.set('test.entity', 4)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_not_fires_if_entity_not_match(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.another_entity',
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-13 10:53:37 +00:00
|
|
|
}
|
|
|
|
}))
|
|
|
|
|
|
|
|
self.hass.states.set('test.entity', 11)
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
2015-09-14 18:33:01 +00:00
|
|
|
|
2015-11-29 21:37:08 +00:00
|
|
|
def test_if_fires_on_entity_change_below_with_attribute(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 9 is below 10
|
2016-02-13 13:19:11 +00:00
|
|
|
self.hass.states.set('test.entity', 9, {'test_attribute': 11})
|
2015-11-29 21:37:08 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_not_fires_on_entity_change_not_below_with_attribute(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 11 is not below 10
|
2016-02-13 13:19:11 +00:00
|
|
|
self.hass.states.set('test.entity', 11, {'test_attribute': 9})
|
2015-11-29 21:37:08 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_fires_on_attribute_change_with_attribute_below(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
2015-12-15 17:12:43 +00:00
|
|
|
'value_template': '{{ state.attributes.test_attribute }}',
|
2015-11-29 21:37:08 +00:00
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 9 is below 10
|
2016-02-13 13:19:11 +00:00
|
|
|
self.hass.states.set('test.entity', 'entity', {'test_attribute': 9})
|
2015-11-29 21:37:08 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_not_fires_on_attribute_change_with_attribute_not_below(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
2015-12-15 17:12:43 +00:00
|
|
|
'value_template': '{{ state.attributes.test_attribute }}',
|
2015-11-29 21:37:08 +00:00
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 11 is not below 10
|
2016-02-13 13:19:11 +00:00
|
|
|
self.hass.states.set('test.entity', 'entity', {'test_attribute': 11})
|
2015-11-29 21:37:08 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_not_fires_on_entity_change_with_attribute_below(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
2015-12-15 17:12:43 +00:00
|
|
|
'value_template': '{{ state.attributes.test_attribute }}',
|
2015-11-29 21:37:08 +00:00
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 11 is not below 10, entity state value should not be tested
|
2016-02-13 13:19:11 +00:00
|
|
|
self.hass.states.set('test.entity', '9', {'test_attribute': 11})
|
2015-11-29 21:37:08 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
|
|
|
|
|
|
|
def test_if_not_fires_on_entity_change_with_not_attribute_below(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
2015-12-15 17:12:43 +00:00
|
|
|
'value_template': '{{ state.attributes.test_attribute }}',
|
2015-11-29 21:37:08 +00:00
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 11 is not below 10, entity state value should not be tested
|
|
|
|
self.hass.states.set('test.entity', 'entity')
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
|
|
|
|
2016-02-14 21:07:21 +00:00
|
|
|
def test_fires_on_attr_change_with_attribute_below_and_multiple_attr(self):
|
2015-11-29 21:37:08 +00:00
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
2015-12-15 17:12:43 +00:00
|
|
|
'value_template': '{{ state.attributes.test_attribute }}',
|
2015-11-29 21:37:08 +00:00
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 9 is not below 10
|
2016-02-14 21:07:21 +00:00
|
|
|
self.hass.states.set('test.entity', 'entity',
|
|
|
|
{'test_attribute': 9, 'not_test_attribute': 11})
|
2015-11-29 21:37:08 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
2015-12-14 21:47:32 +00:00
|
|
|
def test_template_list(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
2016-02-14 21:07:21 +00:00
|
|
|
'value_template':
|
|
|
|
'{{ state.attributes.test_attribute[2] }}',
|
2015-12-14 21:47:32 +00:00
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 3 is below 10
|
2016-02-14 21:07:21 +00:00
|
|
|
self.hass.states.set('test.entity', 'entity',
|
|
|
|
{'test_attribute': [11, 15, 3]})
|
2015-12-14 21:47:32 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
def test_template_string(self):
|
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
2016-02-14 21:07:21 +00:00
|
|
|
'value_template':
|
|
|
|
'{{ state.attributes.test_attribute | multiply(10) }}',
|
2015-12-14 21:47:32 +00:00
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 9 is below 10
|
2016-02-14 21:07:21 +00:00
|
|
|
self.hass.states.set('test.entity', 'entity',
|
|
|
|
{'test_attribute': '0.9'})
|
2015-12-14 21:47:32 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
2016-02-14 21:07:21 +00:00
|
|
|
def test_not_fires_on_attr_change_with_attr_not_below_multiple_attr(self):
|
2015-11-29 21:37:08 +00:00
|
|
|
self.assertTrue(automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
|
|
|
'trigger': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': 'test.entity',
|
2015-12-15 17:12:43 +00:00
|
|
|
'value_template': '{{ state.attributes.test_attribute }}',
|
2015-11-29 21:37:08 +00:00
|
|
|
'below': 10,
|
|
|
|
},
|
|
|
|
'action': {
|
|
|
|
'service': 'test.automation'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
# 11 is not below 10
|
2016-02-14 21:07:21 +00:00
|
|
|
self.hass.states.set('test.entity', 'entity',
|
|
|
|
{'test_attribute': 11, 'not_test_attribute': 9})
|
2015-11-29 21:37:08 +00:00
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
self.assertEqual(0, len(self.calls))
|
|
|
|
|
2015-09-14 18:33:01 +00:00
|
|
|
def test_if_action(self):
|
|
|
|
entity_id = 'domain.test_entity'
|
|
|
|
test_state = 10
|
|
|
|
automation.setup(self.hass, {
|
|
|
|
automation.DOMAIN: {
|
2015-09-15 05:05:40 +00:00
|
|
|
'trigger': {
|
|
|
|
'platform': 'event',
|
|
|
|
'event_type': 'test_event',
|
|
|
|
},
|
|
|
|
'condition': {
|
|
|
|
'platform': 'numeric_state',
|
|
|
|
'entity_id': entity_id,
|
|
|
|
'above': test_state,
|
|
|
|
'below': test_state + 2
|
|
|
|
},
|
|
|
|
'action': {
|
2015-09-19 15:43:56 +00:00
|
|
|
'service': 'test.automation'
|
2015-09-15 05:05:40 +00:00
|
|
|
}
|
2015-09-14 18:33:01 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2015-09-15 05:05:40 +00:00
|
|
|
self.hass.states.set(entity_id, test_state)
|
2015-09-14 18:33:01 +00:00
|
|
|
self.hass.bus.fire('test_event')
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
self.hass.states.set(entity_id, test_state - 1)
|
|
|
|
self.hass.bus.fire('test_event')
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertEqual(1, len(self.calls))
|
|
|
|
|
|
|
|
self.hass.states.set(entity_id, test_state + 1)
|
|
|
|
self.hass.bus.fire('test_event')
|
|
|
|
self.hass.pool.block_till_done()
|
|
|
|
|
|
|
|
self.assertEqual(2, len(self.calls))
|