1
0
mirror of https://github.com/home-assistant/core.git synced 2025-12-27 06:28:31 +00:00
Files
core/tests/components/text/test_trigger.py
Erik Montnemery 8dd35cb129 Add entity triggers and conditions (#156852)
Co-authored-by: Abílio Costa <abmantis@users.noreply.github.com>
Co-authored-by: Artur Pragacz <49985303+arturpragacz@users.noreply.github.com>
Co-authored-by: abmantis <amfcalt@gmail.com>
Co-authored-by: Bram Kragten <mail@bramkragten.nl>
Co-authored-by: Franck Nijhof <git@frenck.dev>
Co-authored-by: Martin Hjelmare <marhje52@gmail.com>
2025-11-25 17:52:20 +01:00

116 lines
3.8 KiB
Python

"""Test text trigger."""
import pytest
from homeassistant.const import CONF_ENTITY_ID, STATE_UNAVAILABLE, STATE_UNKNOWN
from homeassistant.core import HomeAssistant, ServiceCall
from homeassistant.setup import async_setup_component
from tests.components import (
StateDescription,
arm_trigger,
parametrize_target_entities,
set_or_remove_state,
target_entities,
)
@pytest.fixture(autouse=True, name="stub_blueprint_populate")
def stub_blueprint_populate_autouse(stub_blueprint_populate: None) -> None:
"""Stub copying the blueprints to the config folder."""
@pytest.fixture
async def target_texts(hass: HomeAssistant) -> list[str]:
"""Create multiple text entities associated with different targets."""
return await target_entities(hass, "text")
@pytest.mark.parametrize(
("trigger_target_config", "entity_id", "entities_in_target"),
parametrize_target_entities("text"),
)
@pytest.mark.parametrize(
("trigger", "states"),
[
(
"text.changed",
[
{"state": None, "attributes": {}, "count": 0},
{"state": "bar", "attributes": {}, "count": 0},
{"state": "baz", "attributes": {}, "count": 1},
],
),
(
"text.changed",
[
{"state": "foo", "attributes": {}, "count": 0},
{"state": "bar", "attributes": {}, "count": 1},
{"state": "baz", "attributes": {}, "count": 1},
],
),
(
"text.changed",
[
{"state": "foo", "attributes": {}, "count": 0},
{"state": "", "attributes": {}, "count": 1}, # empty string
{"state": "baz", "attributes": {}, "count": 1},
],
),
(
"text.changed",
[
{"state": STATE_UNAVAILABLE, "attributes": {}, "count": 0},
{"state": "bar", "attributes": {}, "count": 0},
{"state": "baz", "attributes": {}, "count": 1},
{"state": STATE_UNAVAILABLE, "attributes": {}, "count": 0},
],
),
(
"text.changed",
[
{"state": STATE_UNKNOWN, "attributes": {}, "count": 0},
{"state": "bar", "attributes": {}, "count": 0},
{"state": "baz", "attributes": {}, "count": 1},
{"state": STATE_UNKNOWN, "attributes": {}, "count": 0},
],
),
],
)
async def test_text_state_trigger_behavior_any(
hass: HomeAssistant,
service_calls: list[ServiceCall],
target_texts: list[str],
trigger_target_config: dict,
entity_id: str,
entities_in_target: int,
trigger: str,
states: list[StateDescription],
) -> None:
"""Test that the text state trigger fires when any text state changes to a specific state."""
await async_setup_component(hass, "text", {})
other_entity_ids = set(target_texts) - {entity_id}
# Set all texts, including the tested text, to the initial state
for eid in target_texts:
set_or_remove_state(hass, eid, states[0])
await hass.async_block_till_done()
await arm_trigger(hass, trigger, None, trigger_target_config)
for state in states[1:]:
set_or_remove_state(hass, entity_id, state)
await hass.async_block_till_done()
assert len(service_calls) == state["count"]
for service_call in service_calls:
assert service_call.data[CONF_ENTITY_ID] == entity_id
service_calls.clear()
# Check if changing other texts also triggers
for other_entity_id in other_entity_ids:
set_or_remove_state(hass, other_entity_id, state)
await hass.async_block_till_done()
assert len(service_calls) == (entities_in_target - 1) * state["count"]
service_calls.clear()