mirror of
https://github.com/home-assistant/core.git
synced 2025-07-19 19:27:45 +00:00
Numeric state trigger: validate that above is not above below (#32421)
* Numeric state trigger: validate that above is not above below * Lint
This commit is contained in:
parent
db7d0eb9b9
commit
4cf86262af
@ -19,6 +19,23 @@ from homeassistant.helpers.event import async_track_same_state, async_track_stat
|
|||||||
# mypy: allow-incomplete-defs, allow-untyped-calls, allow-untyped-defs
|
# mypy: allow-incomplete-defs, allow-untyped-calls, allow-untyped-defs
|
||||||
# mypy: no-check-untyped-defs
|
# mypy: no-check-untyped-defs
|
||||||
|
|
||||||
|
|
||||||
|
def validate_above_below(value):
|
||||||
|
"""Validate that above and below can co-exist."""
|
||||||
|
above = value.get(CONF_ABOVE)
|
||||||
|
below = value.get(CONF_BELOW)
|
||||||
|
|
||||||
|
if above is None or below is None:
|
||||||
|
return value
|
||||||
|
|
||||||
|
if above > below:
|
||||||
|
raise vol.Invalid(
|
||||||
|
f"A value can never be above {above} and below {below} at the same time. You probably want two different triggers.",
|
||||||
|
)
|
||||||
|
|
||||||
|
return value
|
||||||
|
|
||||||
|
|
||||||
TRIGGER_SCHEMA = vol.All(
|
TRIGGER_SCHEMA = vol.All(
|
||||||
vol.Schema(
|
vol.Schema(
|
||||||
{
|
{
|
||||||
@ -35,6 +52,7 @@ TRIGGER_SCHEMA = vol.All(
|
|||||||
}
|
}
|
||||||
),
|
),
|
||||||
cv.has_at_least_one_key(CONF_BELOW, CONF_ABOVE),
|
cv.has_at_least_one_key(CONF_BELOW, CONF_ABOVE),
|
||||||
|
validate_above_below,
|
||||||
)
|
)
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
@ -3,8 +3,10 @@ from datetime import timedelta
|
|||||||
from unittest.mock import patch
|
from unittest.mock import patch
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
|
import voluptuous as vol
|
||||||
|
|
||||||
import homeassistant.components.automation as automation
|
import homeassistant.components.automation as automation
|
||||||
|
from homeassistant.components.automation import numeric_state
|
||||||
from homeassistant.core import Context
|
from homeassistant.core import Context
|
||||||
from homeassistant.setup import async_setup_component
|
from homeassistant.setup import async_setup_component
|
||||||
import homeassistant.util.dt as dt_util
|
import homeassistant.util.dt as dt_util
|
||||||
@ -1229,3 +1231,11 @@ async def test_if_fires_on_entities_change_overlap_for_template(hass, calls):
|
|||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
assert 2 == len(calls)
|
assert 2 == len(calls)
|
||||||
assert "test.entity_2 - 0:00:10" == calls[1].data["some"]
|
assert "test.entity_2 - 0:00:10" == calls[1].data["some"]
|
||||||
|
|
||||||
|
|
||||||
|
def test_below_above():
|
||||||
|
"""Test above cannot be above below."""
|
||||||
|
with pytest.raises(vol.Invalid):
|
||||||
|
numeric_state.TRIGGER_SCHEMA(
|
||||||
|
{"platform": "numeric_state", "above": 1200, "below": 1000}
|
||||||
|
)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user