Improve sun condition trace (#49551)
parent
a9065f381d
commit
d28b959a09
|
@ -97,7 +97,7 @@ def condition_trace_set_result(result: bool, **kwargs: Any) -> None:
|
||||||
node.set_result(result=result, **kwargs)
|
node.set_result(result=result, **kwargs)
|
||||||
|
|
||||||
|
|
||||||
def condition_trace_update_result(result: bool, **kwargs: Any) -> None:
|
def condition_trace_update_result(**kwargs: Any) -> None:
|
||||||
"""Update the result of TraceElement at the top of the stack."""
|
"""Update the result of TraceElement at the top of the stack."""
|
||||||
node = trace_stack_top(trace_stack_cv)
|
node = trace_stack_top(trace_stack_cv)
|
||||||
|
|
||||||
|
@ -106,7 +106,7 @@ def condition_trace_update_result(result: bool, **kwargs: Any) -> None:
|
||||||
if not node:
|
if not node:
|
||||||
return
|
return
|
||||||
|
|
||||||
node.update_result(result=result, **kwargs)
|
node.update_result(**kwargs)
|
||||||
|
|
||||||
|
|
||||||
@contextmanager
|
@contextmanager
|
||||||
|
@ -131,7 +131,7 @@ def trace_condition_function(condition: ConditionCheckerType) -> ConditionChecke
|
||||||
"""Trace condition."""
|
"""Trace condition."""
|
||||||
with trace_condition(variables):
|
with trace_condition(variables):
|
||||||
result = condition(hass, variables)
|
result = condition(hass, variables)
|
||||||
condition_trace_update_result(result)
|
condition_trace_update_result(result=result)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
return wrapper
|
return wrapper
|
||||||
|
@ -607,23 +607,37 @@ def sun(
|
||||||
|
|
||||||
if sunrise is None and SUN_EVENT_SUNRISE in (before, after):
|
if sunrise is None and SUN_EVENT_SUNRISE in (before, after):
|
||||||
# There is no sunrise today
|
# There is no sunrise today
|
||||||
|
condition_trace_set_result(False, message="no sunrise today")
|
||||||
return False
|
return False
|
||||||
|
|
||||||
if sunset is None and SUN_EVENT_SUNSET in (before, after):
|
if sunset is None and SUN_EVENT_SUNSET in (before, after):
|
||||||
# There is no sunset today
|
# There is no sunset today
|
||||||
|
condition_trace_set_result(False, message="no sunset today")
|
||||||
return False
|
return False
|
||||||
|
|
||||||
if before == SUN_EVENT_SUNRISE and utcnow > cast(datetime, sunrise) + before_offset:
|
if before == SUN_EVENT_SUNRISE:
|
||||||
return False
|
wanted_time_before = cast(datetime, sunrise) + before_offset
|
||||||
|
condition_trace_update_result(wanted_time_before=wanted_time_before)
|
||||||
|
if utcnow > wanted_time_before:
|
||||||
|
return False
|
||||||
|
|
||||||
if before == SUN_EVENT_SUNSET and utcnow > cast(datetime, sunset) + before_offset:
|
if before == SUN_EVENT_SUNSET:
|
||||||
return False
|
wanted_time_before = cast(datetime, sunset) + before_offset
|
||||||
|
condition_trace_update_result(wanted_time_before=wanted_time_before)
|
||||||
|
if utcnow > wanted_time_before:
|
||||||
|
return False
|
||||||
|
|
||||||
if after == SUN_EVENT_SUNRISE and utcnow < cast(datetime, sunrise) + after_offset:
|
if after == SUN_EVENT_SUNRISE:
|
||||||
return False
|
wanted_time_after = cast(datetime, sunrise) + after_offset
|
||||||
|
condition_trace_update_result(wanted_time_after=wanted_time_after)
|
||||||
|
if utcnow < wanted_time_after:
|
||||||
|
return False
|
||||||
|
|
||||||
if after == SUN_EVENT_SUNSET and utcnow < cast(datetime, sunset) + after_offset:
|
if after == SUN_EVENT_SUNSET:
|
||||||
return False
|
wanted_time_after = cast(datetime, sunset) + after_offset
|
||||||
|
condition_trace_update_result(wanted_time_after=wanted_time_after)
|
||||||
|
if utcnow < wanted_time_after:
|
||||||
|
return False
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
|
@ -168,695 +168,3 @@ async def test_sunrise_trigger_with_offset(hass, calls, legacy_patchable_time):
|
||||||
async_fire_time_changed(hass, trigger_time)
|
async_fire_time_changed(hass, trigger_time)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
assert len(calls) == 1
|
assert len(calls) == 1
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_before_sunrise_no_offset(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was before sunrise.
|
|
||||||
|
|
||||||
Before sunrise is true from midnight until sunset, local time.
|
|
||||||
"""
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {"condition": "sun", "before": SUN_EVENT_SUNRISE},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-09-16 06:33:18 local, sunset: 2015-09-16 18:53:45 local
|
|
||||||
# sunrise: 2015-09-16 13:33:18 UTC, sunset: 2015-09-17 01:53:45 UTC
|
|
||||||
# now = sunrise + 1s -> 'before sunrise' not true
|
|
||||||
now = datetime(2015, 9, 16, 13, 33, 19, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunrise -> 'before sunrise' true
|
|
||||||
now = datetime(2015, 9, 16, 13, 33, 18, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight -> 'before sunrise' true
|
|
||||||
now = datetime(2015, 9, 16, 7, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = local midnight - 1s -> 'before sunrise' not true
|
|
||||||
now = datetime(2015, 9, 17, 6, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_after_sunrise_no_offset(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was after sunrise.
|
|
||||||
|
|
||||||
After sunrise is true from sunrise until midnight, local time.
|
|
||||||
"""
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {"condition": "sun", "after": SUN_EVENT_SUNRISE},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-09-16 06:33:18 local, sunset: 2015-09-16 18:53:45 local
|
|
||||||
# sunrise: 2015-09-16 13:33:18 UTC, sunset: 2015-09-17 01:53:45 UTC
|
|
||||||
# now = sunrise - 1s -> 'after sunrise' not true
|
|
||||||
now = datetime(2015, 9, 16, 13, 33, 17, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunrise + 1s -> 'after sunrise' true
|
|
||||||
now = datetime(2015, 9, 16, 13, 33, 19, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight -> 'after sunrise' not true
|
|
||||||
now = datetime(2015, 9, 16, 7, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight - 1s -> 'after sunrise' true
|
|
||||||
now = datetime(2015, 9, 17, 6, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_before_sunrise_with_offset(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was before sunrise with offset.
|
|
||||||
|
|
||||||
Before sunrise is true from midnight until sunset, local time.
|
|
||||||
"""
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {
|
|
||||||
"condition": "sun",
|
|
||||||
"before": SUN_EVENT_SUNRISE,
|
|
||||||
"before_offset": "+1:00:00",
|
|
||||||
},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-09-16 06:33:18 local, sunset: 2015-09-16 18:53:45 local
|
|
||||||
# sunrise: 2015-09-16 13:33:18 UTC, sunset: 2015-09-17 01:53:45 UTC
|
|
||||||
# now = sunrise + 1s + 1h -> 'before sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 16, 14, 33, 19, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunrise + 1h -> 'before sunrise' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 14, 33, 18, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = UTC midnight -> 'before sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 17, 0, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = UTC midnight - 1s -> 'before sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 16, 23, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight -> 'before sunrise' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 7, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = local midnight - 1s -> 'before sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 17, 6, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = sunset -> 'before sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 17, 1, 53, 45, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = sunset -1s -> 'before sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 17, 1, 53, 44, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_before_sunset_with_offset(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was before sunset with offset.
|
|
||||||
|
|
||||||
Before sunset is true from midnight until sunset, local time.
|
|
||||||
"""
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {
|
|
||||||
"condition": "sun",
|
|
||||||
"before": "sunset",
|
|
||||||
"before_offset": "+1:00:00",
|
|
||||||
},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-09-16 06:33:18 local, sunset: 2015-09-16 18:53:45 local
|
|
||||||
# sunrise: 2015-09-16 13:33:18 UTC, sunset: 2015-09-17 01:53:45 UTC
|
|
||||||
# now = local midnight -> 'before sunset' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 7, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = sunset + 1s + 1h -> 'before sunset' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 17, 2, 53, 46, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = sunset + 1h -> 'before sunset' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 17, 2, 53, 44, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = UTC midnight -> 'before sunset' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 17, 0, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 3
|
|
||||||
|
|
||||||
# now = UTC midnight - 1s -> 'before sunset' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 23, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 4
|
|
||||||
|
|
||||||
# now = sunrise -> 'before sunset' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 13, 33, 18, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 5
|
|
||||||
|
|
||||||
# now = sunrise -1s -> 'before sunset' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 13, 33, 17, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 6
|
|
||||||
|
|
||||||
# now = local midnight-1s -> 'after sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 17, 6, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 6
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_after_sunrise_with_offset(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was after sunrise with offset.
|
|
||||||
|
|
||||||
After sunrise is true from sunrise until midnight, local time.
|
|
||||||
"""
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {
|
|
||||||
"condition": "sun",
|
|
||||||
"after": SUN_EVENT_SUNRISE,
|
|
||||||
"after_offset": "+1:00:00",
|
|
||||||
},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-09-16 06:33:18 local, sunset: 2015-09-16 18:53:45 local
|
|
||||||
# sunrise: 2015-09-16 13:33:18 UTC, sunset: 2015-09-17 01:53:45 UTC
|
|
||||||
# now = sunrise - 1s + 1h -> 'after sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 16, 14, 33, 17, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunrise + 1h -> 'after sunrise' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 14, 33, 58, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = UTC noon -> 'after sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 16, 12, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = UTC noon - 1s -> 'after sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 16, 11, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local noon -> 'after sunrise' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 19, 1, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = local noon - 1s -> 'after sunrise' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 18, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 3
|
|
||||||
|
|
||||||
# now = sunset -> 'after sunrise' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 17, 1, 53, 45, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 4
|
|
||||||
|
|
||||||
# now = sunset + 1s -> 'after sunrise' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 17, 1, 53, 45, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 5
|
|
||||||
|
|
||||||
# now = local midnight-1s -> 'after sunrise' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 17, 6, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 6
|
|
||||||
|
|
||||||
# now = local midnight -> 'after sunrise' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 17, 7, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 6
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_after_sunset_with_offset(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was after sunset with offset.
|
|
||||||
|
|
||||||
After sunset is true from sunset until midnight, local time.
|
|
||||||
"""
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {
|
|
||||||
"condition": "sun",
|
|
||||||
"after": "sunset",
|
|
||||||
"after_offset": "+1:00:00",
|
|
||||||
},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-09-16 06:33:18 local, sunset: 2015-09-16 18:53:45 local
|
|
||||||
# sunrise: 2015-09-16 13:33:18 UTC, sunset: 2015-09-17 01:53:45 UTC
|
|
||||||
# now = sunset - 1s + 1h -> 'after sunset' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 17, 2, 53, 44, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunset + 1h -> 'after sunset' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 17, 2, 53, 45, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = midnight-1s -> 'after sunset' with offset +1h true
|
|
||||||
now = datetime(2015, 9, 16, 6, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = midnight -> 'after sunset' with offset +1h not true
|
|
||||||
now = datetime(2015, 9, 16, 7, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_before_and_after_during(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was after sunset and before sunrise.
|
|
||||||
|
|
||||||
This is true from sunrise until sunset.
|
|
||||||
"""
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {
|
|
||||||
"condition": "sun",
|
|
||||||
"after": SUN_EVENT_SUNRISE,
|
|
||||||
"before": SUN_EVENT_SUNSET,
|
|
||||||
},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-09-16 06:33:18 local, sunset: 2015-09-16 18:53:45 local
|
|
||||||
# sunrise: 2015-09-16 13:33:18 UTC, sunset: 2015-09-17 01:53:45 UTC
|
|
||||||
# now = sunrise - 1s -> 'after sunrise' + 'before sunset' not true
|
|
||||||
now = datetime(2015, 9, 16, 13, 33, 17, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunset + 1s -> 'after sunrise' + 'before sunset' not true
|
|
||||||
now = datetime(2015, 9, 17, 1, 53, 46, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunrise + 1s -> 'after sunrise' + 'before sunset' true
|
|
||||||
now = datetime(2015, 9, 16, 13, 33, 19, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = sunset - 1s -> 'after sunrise' + 'before sunset' true
|
|
||||||
now = datetime(2015, 9, 17, 1, 53, 44, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = 9AM local -> 'after sunrise' + 'before sunset' true
|
|
||||||
now = datetime(2015, 9, 16, 16, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 3
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_before_sunrise_no_offset_kotzebue(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was before sunrise.
|
|
||||||
|
|
||||||
Local timezone: Alaska time
|
|
||||||
Location: Kotzebue, which has a very skewed local timezone with sunrise
|
|
||||||
at 7 AM and sunset at 3AM during summer
|
|
||||||
After sunrise is true from sunrise until midnight, local time.
|
|
||||||
"""
|
|
||||||
tz = dt_util.get_time_zone("America/Anchorage")
|
|
||||||
dt_util.set_default_time_zone(tz)
|
|
||||||
hass.config.latitude = 66.5
|
|
||||||
hass.config.longitude = 162.4
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {"condition": "sun", "before": SUN_EVENT_SUNRISE},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-07-24 07:21:12 local, sunset: 2015-07-25 03:13:33 local
|
|
||||||
# sunrise: 2015-07-24 15:21:12 UTC, sunset: 2015-07-25 11:13:33 UTC
|
|
||||||
# now = sunrise + 1s -> 'before sunrise' not true
|
|
||||||
now = datetime(2015, 7, 24, 15, 21, 13, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunrise - 1h -> 'before sunrise' true
|
|
||||||
now = datetime(2015, 7, 24, 14, 21, 12, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight -> 'before sunrise' true
|
|
||||||
now = datetime(2015, 7, 24, 8, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = local midnight - 1s -> 'before sunrise' not true
|
|
||||||
now = datetime(2015, 7, 24, 7, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_after_sunrise_no_offset_kotzebue(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was after sunrise.
|
|
||||||
|
|
||||||
Local timezone: Alaska time
|
|
||||||
Location: Kotzebue, which has a very skewed local timezone with sunrise
|
|
||||||
at 7 AM and sunset at 3AM during summer
|
|
||||||
Before sunrise is true from midnight until sunrise, local time.
|
|
||||||
"""
|
|
||||||
tz = dt_util.get_time_zone("America/Anchorage")
|
|
||||||
dt_util.set_default_time_zone(tz)
|
|
||||||
hass.config.latitude = 66.5
|
|
||||||
hass.config.longitude = 162.4
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {"condition": "sun", "after": SUN_EVENT_SUNRISE},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-07-24 07:21:12 local, sunset: 2015-07-25 03:13:33 local
|
|
||||||
# sunrise: 2015-07-24 15:21:12 UTC, sunset: 2015-07-25 11:13:33 UTC
|
|
||||||
# now = sunrise -> 'after sunrise' true
|
|
||||||
now = datetime(2015, 7, 24, 15, 21, 12, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = sunrise - 1h -> 'after sunrise' not true
|
|
||||||
now = datetime(2015, 7, 24, 14, 21, 12, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight -> 'after sunrise' not true
|
|
||||||
now = datetime(2015, 7, 24, 8, 0, 1, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight - 1s -> 'after sunrise' true
|
|
||||||
now = datetime(2015, 7, 24, 7, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_before_sunset_no_offset_kotzebue(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was before sunrise.
|
|
||||||
|
|
||||||
Local timezone: Alaska time
|
|
||||||
Location: Kotzebue, which has a very skewed local timezone with sunrise
|
|
||||||
at 7 AM and sunset at 3AM during summer
|
|
||||||
Before sunset is true from midnight until sunset, local time.
|
|
||||||
"""
|
|
||||||
tz = dt_util.get_time_zone("America/Anchorage")
|
|
||||||
dt_util.set_default_time_zone(tz)
|
|
||||||
hass.config.latitude = 66.5
|
|
||||||
hass.config.longitude = 162.4
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {"condition": "sun", "before": SUN_EVENT_SUNSET},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-07-24 07:21:12 local, sunset: 2015-07-25 03:13:33 local
|
|
||||||
# sunrise: 2015-07-24 15:21:12 UTC, sunset: 2015-07-25 11:13:33 UTC
|
|
||||||
# now = sunset + 1s -> 'before sunset' not true
|
|
||||||
now = datetime(2015, 7, 25, 11, 13, 34, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 0
|
|
||||||
|
|
||||||
# now = sunset - 1h-> 'before sunset' true
|
|
||||||
now = datetime(2015, 7, 25, 10, 13, 33, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight -> 'before sunrise' true
|
|
||||||
now = datetime(2015, 7, 24, 8, 0, 0, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
# now = local midnight - 1s -> 'before sunrise' not true
|
|
||||||
now = datetime(2015, 7, 24, 7, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
||||||
|
|
||||||
async def test_if_action_after_sunset_no_offset_kotzebue(hass, calls):
|
|
||||||
"""
|
|
||||||
Test if action was after sunrise.
|
|
||||||
|
|
||||||
Local timezone: Alaska time
|
|
||||||
Location: Kotzebue, which has a very skewed local timezone with sunrise
|
|
||||||
at 7 AM and sunset at 3AM during summer
|
|
||||||
After sunset is true from sunset until midnight, local time.
|
|
||||||
"""
|
|
||||||
tz = dt_util.get_time_zone("America/Anchorage")
|
|
||||||
dt_util.set_default_time_zone(tz)
|
|
||||||
hass.config.latitude = 66.5
|
|
||||||
hass.config.longitude = 162.4
|
|
||||||
await async_setup_component(
|
|
||||||
hass,
|
|
||||||
automation.DOMAIN,
|
|
||||||
{
|
|
||||||
automation.DOMAIN: {
|
|
||||||
"trigger": {"platform": "event", "event_type": "test_event"},
|
|
||||||
"condition": {"condition": "sun", "after": SUN_EVENT_SUNSET},
|
|
||||||
"action": {"service": "test.automation"},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
# sunrise: 2015-07-24 07:21:12 local, sunset: 2015-07-25 03:13:33 local
|
|
||||||
# sunrise: 2015-07-24 15:21:12 UTC, sunset: 2015-07-25 11:13:33 UTC
|
|
||||||
# now = sunset -> 'after sunset' true
|
|
||||||
now = datetime(2015, 7, 25, 11, 13, 33, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = sunset - 1s -> 'after sunset' not true
|
|
||||||
now = datetime(2015, 7, 25, 11, 13, 32, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight -> 'after sunset' not true
|
|
||||||
now = datetime(2015, 7, 24, 8, 0, 1, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 1
|
|
||||||
|
|
||||||
# now = local midnight - 1s -> 'after sunset' true
|
|
||||||
now = datetime(2015, 7, 24, 7, 59, 59, tzinfo=dt_util.UTC)
|
|
||||||
with patch("homeassistant.util.dt.utcnow", return_value=now):
|
|
||||||
hass.bus.async_fire("test_event")
|
|
||||||
await hass.async_block_till_done()
|
|
||||||
assert len(calls) == 2
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue