Add support for responses to call_service
WS cmd (#98610)
* Add support for responses to call_service WS cmd * Revert ServiceNotFound removal and add a parameter for return_response * fix type * fix tests * remove exception handling that was added * Revert unnecessary modifications * Use kwargs
This commit is contained in:
parent
229944c21c
commit
618b666126
3 changed files with 102 additions and 13 deletions
|
@ -18,7 +18,7 @@ from homeassistant.components.websocket_api.auth import (
|
|||
)
|
||||
from homeassistant.components.websocket_api.const import FEATURE_COALESCE_MESSAGES, URL
|
||||
from homeassistant.const import SIGNAL_BOOTSTRAP_INTEGRATIONS
|
||||
from homeassistant.core import Context, HomeAssistant, State, callback
|
||||
from homeassistant.core import Context, HomeAssistant, State, SupportsResponse, callback
|
||||
from homeassistant.exceptions import HomeAssistantError, ServiceValidationError
|
||||
from homeassistant.helpers import device_registry as dr
|
||||
from homeassistant.helpers.dispatcher import async_dispatcher_send
|
||||
|
@ -183,14 +183,76 @@ async def test_call_service(
|
|||
assert call.context.as_dict() == msg["result"]["context"]
|
||||
|
||||
|
||||
async def test_return_response_error(hass: HomeAssistant, websocket_client) -> None:
|
||||
"""Test return_response=True errors when service has no response."""
|
||||
hass.services.async_register(
|
||||
"domain_test", "test_service_with_no_response", lambda x: None
|
||||
)
|
||||
await websocket_client.send_json(
|
||||
{
|
||||
"id": 8,
|
||||
"type": "call_service",
|
||||
"domain": "domain_test",
|
||||
"service": "test_service_with_no_response",
|
||||
"service_data": {"hello": "world"},
|
||||
"return_response": True,
|
||||
},
|
||||
)
|
||||
msg = await websocket_client.receive_json()
|
||||
|
||||
assert msg["id"] == 8
|
||||
assert msg["type"] == const.TYPE_RESULT
|
||||
assert not msg["success"]
|
||||
assert msg["error"]["code"] == "unknown_error"
|
||||
|
||||
|
||||
@pytest.mark.parametrize("command", ("call_service", "call_service_action"))
|
||||
async def test_call_service_blocking(
|
||||
hass: HomeAssistant, websocket_client: MockHAClientWebSocket, command
|
||||
) -> None:
|
||||
"""Test call service commands block, except for homeassistant restart / stop."""
|
||||
async_mock_service(
|
||||
hass,
|
||||
"domain_test",
|
||||
"test_service",
|
||||
response={"hello": "world"},
|
||||
supports_response=SupportsResponse.OPTIONAL,
|
||||
)
|
||||
with patch(
|
||||
"homeassistant.core.ServiceRegistry.async_call", autospec=True
|
||||
) as mock_call:
|
||||
mock_call.return_value = {"foo": "bar"}
|
||||
await websocket_client.send_json(
|
||||
{
|
||||
"id": 4,
|
||||
"type": "call_service",
|
||||
"domain": "domain_test",
|
||||
"service": "test_service",
|
||||
"service_data": {"hello": "world"},
|
||||
"return_response": True,
|
||||
},
|
||||
)
|
||||
msg = await websocket_client.receive_json()
|
||||
|
||||
assert msg["id"] == 4
|
||||
assert msg["type"] == const.TYPE_RESULT
|
||||
assert msg["success"]
|
||||
assert msg["result"]["response"] == {"foo": "bar"}
|
||||
mock_call.assert_called_once_with(
|
||||
ANY,
|
||||
"domain_test",
|
||||
"test_service",
|
||||
{"hello": "world"},
|
||||
blocking=True,
|
||||
context=ANY,
|
||||
target=ANY,
|
||||
return_response=True,
|
||||
)
|
||||
|
||||
with patch(
|
||||
"homeassistant.core.ServiceRegistry.async_call", autospec=True
|
||||
) as mock_call:
|
||||
mock_call.return_value = None
|
||||
await websocket_client.send_json(
|
||||
{
|
||||
"id": 5,
|
||||
|
@ -213,11 +275,14 @@ async def test_call_service_blocking(
|
|||
blocking=True,
|
||||
context=ANY,
|
||||
target=ANY,
|
||||
return_response=False,
|
||||
)
|
||||
|
||||
async_mock_service(hass, "homeassistant", "test_service")
|
||||
with patch(
|
||||
"homeassistant.core.ServiceRegistry.async_call", autospec=True
|
||||
) as mock_call:
|
||||
mock_call.return_value = None
|
||||
await websocket_client.send_json(
|
||||
{
|
||||
"id": 6,
|
||||
|
@ -239,11 +304,14 @@ async def test_call_service_blocking(
|
|||
blocking=True,
|
||||
context=ANY,
|
||||
target=ANY,
|
||||
return_response=False,
|
||||
)
|
||||
|
||||
async_mock_service(hass, "homeassistant", "restart")
|
||||
with patch(
|
||||
"homeassistant.core.ServiceRegistry.async_call", autospec=True
|
||||
) as mock_call:
|
||||
mock_call.return_value = None
|
||||
await websocket_client.send_json(
|
||||
{
|
||||
"id": 7,
|
||||
|
@ -258,7 +326,14 @@ async def test_call_service_blocking(
|
|||
assert msg["type"] == const.TYPE_RESULT
|
||||
assert msg["success"]
|
||||
mock_call.assert_called_once_with(
|
||||
ANY, "homeassistant", "restart", ANY, blocking=True, context=ANY, target=ANY
|
||||
ANY,
|
||||
"homeassistant",
|
||||
"restart",
|
||||
ANY,
|
||||
blocking=True,
|
||||
context=ANY,
|
||||
target=ANY,
|
||||
return_response=False,
|
||||
)
|
||||
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue