2016-04-28 10:03:57 +00:00
|
|
|
"""Test the condition helper."""
|
2016-05-29 21:32:32 +00:00
|
|
|
from unittest.mock import patch
|
|
|
|
|
2016-04-28 10:03:57 +00:00
|
|
|
from homeassistant.helpers import condition
|
2016-05-29 21:32:32 +00:00
|
|
|
from homeassistant.util import dt
|
2016-04-28 10:03:57 +00:00
|
|
|
|
|
|
|
from tests.common import get_test_home_assistant
|
|
|
|
|
|
|
|
|
|
|
|
class TestConditionHelper:
|
|
|
|
"""Test condition helpers."""
|
|
|
|
|
|
|
|
def setup_method(self, method):
|
2018-08-19 20:29:08 +00:00
|
|
|
"""Set up things to be run when tests are started."""
|
2016-04-28 10:03:57 +00:00
|
|
|
self.hass = get_test_home_assistant()
|
|
|
|
|
|
|
|
def teardown_method(self, method):
|
|
|
|
"""Stop everything that was started."""
|
|
|
|
self.hass.stop()
|
|
|
|
|
|
|
|
def test_and_condition(self):
|
|
|
|
"""Test the 'and' condition."""
|
|
|
|
test = condition.from_config({
|
|
|
|
'condition': 'and',
|
|
|
|
'conditions': [
|
|
|
|
{
|
|
|
|
'condition': 'state',
|
|
|
|
'entity_id': 'sensor.temperature',
|
|
|
|
'state': '100',
|
|
|
|
}, {
|
|
|
|
'condition': 'numeric_state',
|
|
|
|
'entity_id': 'sensor.temperature',
|
|
|
|
'below': 110,
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 120)
|
|
|
|
assert not test(self.hass)
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 105)
|
|
|
|
assert not test(self.hass)
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 100)
|
|
|
|
assert test(self.hass)
|
|
|
|
|
2016-09-28 04:29:55 +00:00
|
|
|
def test_and_condition_with_template(self):
|
|
|
|
"""Test the 'and' condition."""
|
|
|
|
test = condition.from_config({
|
|
|
|
'condition': 'and',
|
|
|
|
'conditions': [
|
|
|
|
{
|
|
|
|
'condition': 'template',
|
|
|
|
'value_template':
|
|
|
|
'{{ states.sensor.temperature.state == "100" }}',
|
|
|
|
}, {
|
|
|
|
'condition': 'numeric_state',
|
|
|
|
'entity_id': 'sensor.temperature',
|
|
|
|
'below': 110,
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 120)
|
|
|
|
assert not test(self.hass)
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 105)
|
|
|
|
assert not test(self.hass)
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 100)
|
|
|
|
assert test(self.hass)
|
|
|
|
|
2016-04-28 10:03:57 +00:00
|
|
|
def test_or_condition(self):
|
|
|
|
"""Test the 'or' condition."""
|
|
|
|
test = condition.from_config({
|
|
|
|
'condition': 'or',
|
|
|
|
'conditions': [
|
|
|
|
{
|
|
|
|
'condition': 'state',
|
|
|
|
'entity_id': 'sensor.temperature',
|
|
|
|
'state': '100',
|
|
|
|
}, {
|
|
|
|
'condition': 'numeric_state',
|
|
|
|
'entity_id': 'sensor.temperature',
|
|
|
|
'below': 110,
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 120)
|
|
|
|
assert not test(self.hass)
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 105)
|
|
|
|
assert test(self.hass)
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 100)
|
|
|
|
assert test(self.hass)
|
2016-05-29 21:32:32 +00:00
|
|
|
|
2016-09-28 04:29:55 +00:00
|
|
|
def test_or_condition_with_template(self):
|
|
|
|
"""Test the 'or' condition."""
|
|
|
|
test = condition.from_config({
|
|
|
|
'condition': 'or',
|
|
|
|
'conditions': [
|
|
|
|
{
|
|
|
|
'condition': 'template',
|
|
|
|
'value_template':
|
|
|
|
'{{ states.sensor.temperature.state == "100" }}',
|
|
|
|
}, {
|
|
|
|
'condition': 'numeric_state',
|
|
|
|
'entity_id': 'sensor.temperature',
|
|
|
|
'below': 110,
|
|
|
|
}
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 120)
|
|
|
|
assert not test(self.hass)
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 105)
|
|
|
|
assert test(self.hass)
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 100)
|
|
|
|
assert test(self.hass)
|
|
|
|
|
2016-05-29 21:32:32 +00:00
|
|
|
def test_time_window(self):
|
|
|
|
"""Test time condition windows."""
|
|
|
|
sixam = dt.parse_time("06:00:00")
|
|
|
|
sixpm = dt.parse_time("18:00:00")
|
|
|
|
|
|
|
|
with patch('homeassistant.helpers.condition.dt_util.now',
|
|
|
|
return_value=dt.now().replace(hour=3)):
|
|
|
|
assert not condition.time(after=sixam, before=sixpm)
|
|
|
|
assert condition.time(after=sixpm, before=sixam)
|
|
|
|
|
|
|
|
with patch('homeassistant.helpers.condition.dt_util.now',
|
|
|
|
return_value=dt.now().replace(hour=9)):
|
|
|
|
assert condition.time(after=sixam, before=sixpm)
|
|
|
|
assert not condition.time(after=sixpm, before=sixam)
|
|
|
|
|
|
|
|
with patch('homeassistant.helpers.condition.dt_util.now',
|
|
|
|
return_value=dt.now().replace(hour=15)):
|
|
|
|
assert condition.time(after=sixam, before=sixpm)
|
|
|
|
assert not condition.time(after=sixpm, before=sixam)
|
|
|
|
|
|
|
|
with patch('homeassistant.helpers.condition.dt_util.now',
|
|
|
|
return_value=dt.now().replace(hour=21)):
|
|
|
|
assert not condition.time(after=sixam, before=sixpm)
|
|
|
|
assert condition.time(after=sixpm, before=sixam)
|
2018-02-20 16:02:27 +00:00
|
|
|
|
|
|
|
def test_if_numeric_state_not_raise_on_unavailable(self):
|
|
|
|
"""Test numeric_state doesn't raise on unavailable/unknown state."""
|
|
|
|
test = condition.from_config({
|
|
|
|
'condition': 'numeric_state',
|
|
|
|
'entity_id': 'sensor.temperature',
|
|
|
|
'below': 42
|
|
|
|
})
|
|
|
|
|
|
|
|
with patch('homeassistant.helpers.condition._LOGGER.warning') \
|
|
|
|
as logwarn:
|
|
|
|
self.hass.states.set('sensor.temperature', 'unavailable')
|
|
|
|
assert not test(self.hass)
|
|
|
|
assert len(logwarn.mock_calls) == 0
|
|
|
|
|
|
|
|
self.hass.states.set('sensor.temperature', 'unknown')
|
|
|
|
assert not test(self.hass)
|
|
|
|
assert len(logwarn.mock_calls) == 0
|