2020-01-10 02:19:10 +00:00
|
|
|
"""Tests for Samsung TV config flow."""
|
|
|
|
import pytest
|
|
|
|
from samsungctl.exceptions import AccessDenied, UnhandledResponse
|
2020-03-10 10:48:09 +00:00
|
|
|
from samsungtvws.exceptions import ConnectionFailure
|
2020-02-08 11:03:35 +00:00
|
|
|
from websocket import WebSocketProtocolException
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
from homeassistant.components.samsungtv.const import (
|
|
|
|
CONF_MANUFACTURER,
|
|
|
|
CONF_MODEL,
|
|
|
|
DOMAIN,
|
|
|
|
)
|
|
|
|
from homeassistant.components.ssdp import (
|
|
|
|
ATTR_SSDP_LOCATION,
|
|
|
|
ATTR_UPNP_FRIENDLY_NAME,
|
|
|
|
ATTR_UPNP_MANUFACTURER,
|
|
|
|
ATTR_UPNP_MODEL_NAME,
|
|
|
|
ATTR_UPNP_UDN,
|
|
|
|
)
|
2020-03-21 15:50:18 +00:00
|
|
|
from homeassistant.const import CONF_HOST, CONF_ID, CONF_METHOD, CONF_NAME, CONF_TOKEN
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2020-04-30 20:29:50 +00:00
|
|
|
from tests.async_mock import DEFAULT as DEFAULT_MOCK, Mock, PropertyMock, call, patch
|
|
|
|
|
2020-01-10 02:19:10 +00:00
|
|
|
MOCK_USER_DATA = {CONF_HOST: "fake_host", CONF_NAME: "fake_name"}
|
|
|
|
MOCK_SSDP_DATA = {
|
|
|
|
ATTR_SSDP_LOCATION: "https://fake_host:12345/test",
|
|
|
|
ATTR_UPNP_FRIENDLY_NAME: "[TV]fake_name",
|
|
|
|
ATTR_UPNP_MANUFACTURER: "fake_manufacturer",
|
|
|
|
ATTR_UPNP_MODEL_NAME: "fake_model",
|
|
|
|
ATTR_UPNP_UDN: "uuid:fake_uuid",
|
|
|
|
}
|
|
|
|
MOCK_SSDP_DATA_NOPREFIX = {
|
|
|
|
ATTR_SSDP_LOCATION: "http://fake2_host:12345/test",
|
|
|
|
ATTR_UPNP_FRIENDLY_NAME: "fake2_name",
|
|
|
|
ATTR_UPNP_MANUFACTURER: "fake2_manufacturer",
|
|
|
|
ATTR_UPNP_MODEL_NAME: "fake2_model",
|
|
|
|
ATTR_UPNP_UDN: "fake2_uuid",
|
|
|
|
}
|
|
|
|
|
|
|
|
AUTODETECT_LEGACY = {
|
|
|
|
"name": "HomeAssistant",
|
|
|
|
"description": "HomeAssistant",
|
|
|
|
"id": "ha.component.samsung",
|
|
|
|
"method": "legacy",
|
|
|
|
"port": None,
|
|
|
|
"host": "fake_host",
|
2020-02-03 19:34:02 +00:00
|
|
|
"timeout": 31,
|
2020-01-10 02:19:10 +00:00
|
|
|
}
|
2020-03-21 15:50:18 +00:00
|
|
|
AUTODETECT_WEBSOCKET_PLAIN = {
|
|
|
|
"host": "fake_host",
|
|
|
|
"name": "HomeAssistant",
|
|
|
|
"port": 8001,
|
|
|
|
"timeout": 31,
|
|
|
|
"token": None,
|
|
|
|
}
|
|
|
|
AUTODETECT_WEBSOCKET_SSL = {
|
|
|
|
"host": "fake_host",
|
|
|
|
"name": "HomeAssistant",
|
|
|
|
"port": 8002,
|
|
|
|
"timeout": 31,
|
|
|
|
"token": None,
|
|
|
|
}
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(name="remote")
|
|
|
|
def remote_fixture():
|
|
|
|
"""Patch the samsungctl Remote."""
|
2020-03-10 10:48:09 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.Remote"
|
|
|
|
) as remote_class, patch(
|
2020-01-10 02:19:10 +00:00
|
|
|
"homeassistant.components.samsungtv.config_flow.socket"
|
|
|
|
) as socket_class:
|
2020-04-30 20:29:50 +00:00
|
|
|
remote = Mock()
|
|
|
|
remote.__enter__ = Mock()
|
|
|
|
remote.__exit__ = Mock()
|
2020-01-10 02:19:10 +00:00
|
|
|
remote_class.return_value = remote
|
2020-04-30 20:29:50 +00:00
|
|
|
socket = Mock()
|
2020-01-10 02:19:10 +00:00
|
|
|
socket_class.return_value = socket
|
2020-04-06 09:21:52 +00:00
|
|
|
socket_class.gethostbyname.return_value = "FAKE_IP_ADDRESS"
|
2020-01-10 02:19:10 +00:00
|
|
|
yield remote
|
|
|
|
|
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
@pytest.fixture(name="remotews")
|
|
|
|
def remotews_fixture():
|
|
|
|
"""Patch the samsungtvws SamsungTVWS."""
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS"
|
|
|
|
) as remotews_class, patch(
|
|
|
|
"homeassistant.components.samsungtv.config_flow.socket"
|
|
|
|
) as socket_class:
|
2020-04-30 20:29:50 +00:00
|
|
|
remotews = Mock()
|
|
|
|
remotews.__enter__ = Mock()
|
|
|
|
remotews.__exit__ = Mock()
|
2020-03-10 10:48:09 +00:00
|
|
|
remotews_class.return_value = remotews
|
2020-04-06 09:21:52 +00:00
|
|
|
remotews_class().__enter__().token = "FAKE_TOKEN"
|
2020-04-30 20:29:50 +00:00
|
|
|
socket = Mock()
|
2020-03-10 10:48:09 +00:00
|
|
|
socket_class.return_value = socket
|
2020-04-06 09:21:52 +00:00
|
|
|
socket_class.gethostbyname.return_value = "FAKE_IP_ADDRESS"
|
2020-03-10 10:48:09 +00:00
|
|
|
yield remotews
|
|
|
|
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
async def test_user_legacy(hass, remote):
|
|
|
|
"""Test starting a flow by user."""
|
2020-01-10 02:19:10 +00:00
|
|
|
# show form
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "user"
|
|
|
|
|
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input=MOCK_USER_DATA
|
|
|
|
)
|
2020-03-10 10:48:09 +00:00
|
|
|
# legacy tv entry created
|
2020-01-10 02:19:10 +00:00
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "fake_name"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
2020-02-03 19:34:02 +00:00
|
|
|
assert result["data"][CONF_NAME] == "fake_name"
|
2020-03-10 10:48:09 +00:00
|
|
|
assert result["data"][CONF_METHOD] == "legacy"
|
2020-01-10 02:19:10 +00:00
|
|
|
assert result["data"][CONF_MANUFACTURER] is None
|
|
|
|
assert result["data"][CONF_MODEL] is None
|
|
|
|
assert result["data"][CONF_ID] is None
|
|
|
|
|
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
async def test_user_websocket(hass, remotews):
|
|
|
|
"""Test starting a flow by user."""
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.Remote", side_effect=OSError("Boom")
|
|
|
|
):
|
|
|
|
# show form
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "user"
|
|
|
|
|
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
# legacy tv entry created
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "fake_name"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "fake_name"
|
|
|
|
assert result["data"][CONF_METHOD] == "websocket"
|
|
|
|
assert result["data"][CONF_MANUFACTURER] is None
|
|
|
|
assert result["data"][CONF_MODEL] is None
|
|
|
|
assert result["data"][CONF_ID] is None
|
|
|
|
|
|
|
|
|
|
|
|
async def test_user_legacy_missing_auth(hass):
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow by user with authentication."""
|
|
|
|
with patch(
|
2020-03-10 10:48:09 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=AccessDenied("Boom"),
|
|
|
|
), patch("homeassistant.components.samsungtv.config_flow.socket"):
|
2020-03-10 10:48:09 +00:00
|
|
|
# legacy device missing authentication
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "auth_missing"
|
|
|
|
|
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
async def test_user_legacy_not_supported(hass):
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow by user for not supported device."""
|
|
|
|
with patch(
|
2020-03-10 10:48:09 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=UnhandledResponse("Boom"),
|
|
|
|
), patch("homeassistant.components.samsungtv.config_flow.socket"):
|
2020-03-10 10:48:09 +00:00
|
|
|
# legacy device not supported
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "not_supported"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
|
|
|
|
async def test_user_websocket_not_supported(hass):
|
|
|
|
"""Test starting a flow by user for not supported device."""
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS",
|
|
|
|
side_effect=WebSocketProtocolException("Boom"),
|
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.config_flow.socket"
|
|
|
|
):
|
|
|
|
# websocket device not supported
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "not_supported"
|
|
|
|
|
|
|
|
|
2020-02-03 19:34:02 +00:00
|
|
|
async def test_user_not_successful(hass):
|
|
|
|
"""Test starting a flow by user but no connection found."""
|
2020-01-10 02:19:10 +00:00
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.config_flow.socket"
|
|
|
|
):
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2020-10-05 09:45:35 +00:00
|
|
|
assert result["reason"] == "cannot_connect"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
|
|
|
|
async def test_user_not_successful_2(hass):
|
|
|
|
"""Test starting a flow by user but no connection found."""
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS",
|
|
|
|
side_effect=ConnectionFailure("Boom"),
|
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.config_flow.socket"
|
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2020-10-05 09:45:35 +00:00
|
|
|
assert result["reason"] == "cannot_connect"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_user_already_configured(hass, remote):
|
|
|
|
"""Test starting a flow by user when already configured."""
|
|
|
|
|
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
|
|
|
|
# failed as already configured
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_ssdp(hass, remote):
|
|
|
|
"""Test starting a flow from discovery."""
|
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
2020-02-03 19:34:02 +00:00
|
|
|
assert result["title"] == "fake_model"
|
2020-01-10 02:19:10 +00:00
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
2020-02-03 19:34:02 +00:00
|
|
|
assert result["data"][CONF_NAME] == "Samsung fake_model"
|
2020-01-10 02:19:10 +00:00
|
|
|
assert result["data"][CONF_MANUFACTURER] == "fake_manufacturer"
|
|
|
|
assert result["data"][CONF_MODEL] == "fake_model"
|
|
|
|
assert result["data"][CONF_ID] == "fake_uuid"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_ssdp_noprefix(hass, remote):
|
|
|
|
"""Test starting a flow from discovery without prefixes."""
|
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA_NOPREFIX
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
2020-02-03 19:34:02 +00:00
|
|
|
assert result["title"] == "fake2_model"
|
2020-01-10 02:19:10 +00:00
|
|
|
assert result["data"][CONF_HOST] == "fake2_host"
|
2020-02-03 19:34:02 +00:00
|
|
|
assert result["data"][CONF_NAME] == "Samsung fake2_model"
|
2020-01-10 02:19:10 +00:00
|
|
|
assert result["data"][CONF_MANUFACTURER] == "fake2_manufacturer"
|
|
|
|
assert result["data"][CONF_MODEL] == "fake2_model"
|
|
|
|
assert result["data"][CONF_ID] == "fake2_uuid"
|
|
|
|
|
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
async def test_ssdp_legacy_missing_auth(hass):
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow from discovery with authentication."""
|
|
|
|
with patch(
|
2020-03-10 10:48:09 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=AccessDenied("Boom"),
|
|
|
|
), patch("homeassistant.components.samsungtv.config_flow.socket"):
|
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# missing authentication
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "auth_missing"
|
|
|
|
|
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
async def test_ssdp_legacy_not_supported(hass):
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow from discovery for not supported device."""
|
|
|
|
with patch(
|
2020-03-10 10:48:09 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=UnhandledResponse("Boom"),
|
|
|
|
), patch("homeassistant.components.samsungtv.config_flow.socket"):
|
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# device not supported
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "not_supported"
|
|
|
|
|
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
async def test_ssdp_websocket_not_supported(hass):
|
2020-02-08 11:03:35 +00:00
|
|
|
"""Test starting a flow from discovery for not supported device."""
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS",
|
2020-02-08 11:03:35 +00:00
|
|
|
side_effect=WebSocketProtocolException("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.config_flow.socket"
|
|
|
|
):
|
2020-02-08 11:03:35 +00:00
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# device not supported
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "not_supported"
|
|
|
|
|
|
|
|
|
2020-02-03 19:34:02 +00:00
|
|
|
async def test_ssdp_not_successful(hass):
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow from discovery but no device found."""
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.config_flow.socket"
|
|
|
|
):
|
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# device not found
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2020-10-05 09:45:35 +00:00
|
|
|
assert result["reason"] == "cannot_connect"
|
2020-03-10 10:48:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_ssdp_not_successful_2(hass):
|
|
|
|
"""Test starting a flow from discovery but no device found."""
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS",
|
|
|
|
side_effect=ConnectionFailure("Boom"),
|
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.config_flow.socket"
|
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# device not found
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2020-10-05 09:45:35 +00:00
|
|
|
assert result["reason"] == "cannot_connect"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_ssdp_already_in_progress(hass, remote):
|
|
|
|
"""Test starting a flow from discovery twice."""
|
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# failed as already in progress
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_in_progress"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_ssdp_already_configured(hass, remote):
|
|
|
|
"""Test starting a flow from discovery when already configured."""
|
|
|
|
|
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
2020-03-09 21:07:50 +00:00
|
|
|
entry = result["result"]
|
|
|
|
assert entry.data[CONF_MANUFACTURER] is None
|
|
|
|
assert entry.data[CONF_MODEL] is None
|
|
|
|
assert entry.data[CONF_ID] is None
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
# failed as already configured
|
|
|
|
result2 = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "ssdp"}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result2["type"] == "abort"
|
|
|
|
assert result2["reason"] == "already_configured"
|
|
|
|
|
|
|
|
# check updated device info
|
2020-03-09 21:07:50 +00:00
|
|
|
assert entry.data[CONF_MANUFACTURER] == "fake_manufacturer"
|
|
|
|
assert entry.data[CONF_MODEL] == "fake_model"
|
|
|
|
assert entry.data[CONF_ID] == "fake_uuid"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
async def test_autodetect_websocket(hass, remote, remotews):
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test for send key with autodetection of protocol."""
|
2020-03-10 10:48:09 +00:00
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
), patch("homeassistant.components.samsungtv.bridge.SamsungTVWS") as remotews:
|
2020-03-21 15:50:18 +00:00
|
|
|
enter = Mock()
|
|
|
|
type(enter).token = PropertyMock(return_value="123456789")
|
|
|
|
remote = Mock()
|
|
|
|
remote.__enter__ = Mock(return_value=enter)
|
|
|
|
remote.__exit__ = Mock(return_value=False)
|
|
|
|
remotews.return_value = remote
|
|
|
|
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["data"][CONF_METHOD] == "websocket"
|
2020-03-21 15:50:18 +00:00
|
|
|
assert result["data"][CONF_TOKEN] == "123456789"
|
2020-03-10 10:48:09 +00:00
|
|
|
assert remotews.call_count == 1
|
2020-03-21 15:50:18 +00:00
|
|
|
assert remotews.call_args_list == [call(**AUTODETECT_WEBSOCKET_PLAIN)]
|
|
|
|
|
|
|
|
|
|
|
|
async def test_autodetect_websocket_ssl(hass, remote, remotews):
|
|
|
|
"""Test for send key with autodetection of protocol."""
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-21 15:50:18 +00:00
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS",
|
2020-04-30 20:29:50 +00:00
|
|
|
side_effect=[WebSocketProtocolException("Boom"), DEFAULT_MOCK],
|
2020-03-21 15:50:18 +00:00
|
|
|
) as remotews:
|
|
|
|
enter = Mock()
|
|
|
|
type(enter).token = PropertyMock(return_value="123456789")
|
|
|
|
remote = Mock()
|
|
|
|
remote.__enter__ = Mock(return_value=enter)
|
|
|
|
remote.__exit__ = Mock(return_value=False)
|
|
|
|
remotews.return_value = remote
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["data"][CONF_METHOD] == "websocket"
|
|
|
|
assert result["data"][CONF_TOKEN] == "123456789"
|
|
|
|
assert remotews.call_count == 2
|
2020-03-10 10:48:09 +00:00
|
|
|
assert remotews.call_args_list == [
|
2020-03-21 15:50:18 +00:00
|
|
|
call(**AUTODETECT_WEBSOCKET_PLAIN),
|
|
|
|
call(**AUTODETECT_WEBSOCKET_SSL),
|
2020-03-10 10:48:09 +00:00
|
|
|
]
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_autodetect_auth_missing(hass, remote):
|
|
|
|
"""Test for send key with autodetection of protocol."""
|
|
|
|
with patch(
|
2020-03-10 10:48:09 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=[AccessDenied("Boom")],
|
|
|
|
) as remote:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "auth_missing"
|
|
|
|
assert remote.call_count == 1
|
2020-03-10 10:48:09 +00:00
|
|
|
assert remote.call_args_list == [call(AUTODETECT_LEGACY)]
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_autodetect_not_supported(hass, remote):
|
|
|
|
"""Test for send key with autodetection of protocol."""
|
|
|
|
with patch(
|
2020-03-10 10:48:09 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=[UnhandledResponse("Boom")],
|
|
|
|
) as remote:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "not_supported"
|
|
|
|
assert remote.call_count == 1
|
2020-03-10 10:48:09 +00:00
|
|
|
assert remote.call_args_list == [call(AUTODETECT_LEGACY)]
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_autodetect_legacy(hass, remote):
|
|
|
|
"""Test for send key with autodetection of protocol."""
|
2020-03-10 10:48:09 +00:00
|
|
|
with patch("homeassistant.components.samsungtv.bridge.Remote") as remote:
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["data"][CONF_METHOD] == "legacy"
|
2020-03-10 10:48:09 +00:00
|
|
|
assert remote.call_count == 1
|
|
|
|
assert remote.call_args_list == [call(AUTODETECT_LEGACY)]
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
async def test_autodetect_none(hass, remote, remotews):
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test for send key with autodetection of protocol."""
|
|
|
|
with patch(
|
2020-08-27 11:56:20 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
) as remote, patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWS",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
) as remotews:
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": "user"}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2020-10-05 09:45:35 +00:00
|
|
|
assert result["reason"] == "cannot_connect"
|
2020-03-10 10:48:09 +00:00
|
|
|
assert remote.call_count == 1
|
2020-01-10 02:19:10 +00:00
|
|
|
assert remote.call_args_list == [
|
|
|
|
call(AUTODETECT_LEGACY),
|
|
|
|
]
|
2020-03-10 10:48:09 +00:00
|
|
|
assert remotews.call_count == 2
|
|
|
|
assert remotews.call_args_list == [
|
2020-03-21 15:50:18 +00:00
|
|
|
call(**AUTODETECT_WEBSOCKET_PLAIN),
|
|
|
|
call(**AUTODETECT_WEBSOCKET_SSL),
|
2020-03-10 10:48:09 +00:00
|
|
|
]
|