2020-08-17 16:54:56 +00:00
|
|
|
"""The tests for the trigger helper."""
|
2021-08-20 04:43:04 +00:00
|
|
|
from unittest.mock import MagicMock, call, patch
|
|
|
|
|
2020-08-17 16:54:56 +00:00
|
|
|
import pytest
|
|
|
|
import voluptuous as vol
|
|
|
|
|
2022-04-15 16:33:09 +00:00
|
|
|
from homeassistant.core import HomeAssistant, ServiceCall
|
2021-08-20 04:43:04 +00:00
|
|
|
from homeassistant.helpers.trigger import (
|
|
|
|
_async_get_trigger_platform,
|
|
|
|
async_validate_trigger_config,
|
|
|
|
)
|
2022-03-18 08:25:22 +00:00
|
|
|
from homeassistant.setup import async_setup_component
|
|
|
|
|
|
|
|
from tests.common import async_mock_service
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def calls(hass):
|
|
|
|
"""Track calls to a mock service."""
|
|
|
|
return async_mock_service(hass, "test", "automation")
|
2020-08-17 16:54:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_bad_trigger_platform(hass):
|
|
|
|
"""Test bad trigger platform."""
|
|
|
|
with pytest.raises(vol.Invalid) as ex:
|
|
|
|
await async_validate_trigger_config(hass, [{"platform": "not_a_platform"}])
|
|
|
|
assert "Invalid platform 'not_a_platform' specified" in str(ex)
|
2021-08-20 04:43:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_trigger_subtype(hass):
|
|
|
|
"""Test trigger subtypes."""
|
|
|
|
with patch(
|
|
|
|
"homeassistant.helpers.trigger.async_get_integration", return_value=MagicMock()
|
|
|
|
) as integration_mock:
|
|
|
|
await _async_get_trigger_platform(hass, {"platform": "test.subtype"})
|
|
|
|
assert integration_mock.call_args == call(hass, "test")
|
2022-03-18 08:25:22 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_trigger_variables(hass):
|
|
|
|
"""Test trigger variables."""
|
|
|
|
|
|
|
|
|
|
|
|
async def test_if_fires_on_event(hass, calls):
|
|
|
|
"""Test the firing of events."""
|
|
|
|
assert await async_setup_component(
|
|
|
|
hass,
|
|
|
|
"automation",
|
|
|
|
{
|
|
|
|
"automation": {
|
|
|
|
"trigger": {
|
|
|
|
"platform": "event",
|
|
|
|
"event_type": "test_event",
|
|
|
|
"variables": {
|
|
|
|
"name": "Paulus",
|
|
|
|
"via_event": "{{ trigger.event.event_type }}",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"action": {
|
|
|
|
"service": "test.automation",
|
|
|
|
"data_template": {"hello": "{{ name }} + {{ via_event }}"},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
hass.bus.async_fire("test_event")
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(calls) == 1
|
|
|
|
assert calls[0].data["hello"] == "Paulus + test_event"
|
2022-04-15 16:33:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_if_disabled_trigger_not_firing(
|
|
|
|
hass: HomeAssistant, calls: list[ServiceCall]
|
|
|
|
) -> None:
|
|
|
|
"""Test disabled triggers don't fire."""
|
|
|
|
assert await async_setup_component(
|
|
|
|
hass,
|
|
|
|
"automation",
|
|
|
|
{
|
|
|
|
"automation": {
|
|
|
|
"trigger": [
|
|
|
|
{
|
|
|
|
"platform": "event",
|
|
|
|
"event_type": "enabled_trigger_event",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"enabled": False,
|
|
|
|
"platform": "event",
|
|
|
|
"event_type": "disabled_trigger_event",
|
|
|
|
},
|
|
|
|
],
|
|
|
|
"action": {
|
|
|
|
"service": "test.automation",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
hass.bus.async_fire("disabled_trigger_event")
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert not calls
|
|
|
|
|
|
|
|
hass.bus.async_fire("enabled_trigger_event")
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(calls) == 1
|