2020-01-10 02:19:10 +00:00
|
|
|
"""Tests for Samsung TV config flow."""
|
2021-05-22 15:41:18 +00:00
|
|
|
import socket
|
2022-02-28 19:53:42 +00:00
|
|
|
from unittest.mock import ANY, AsyncMock, Mock, call, patch
|
2021-01-01 21:31:56 +00:00
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
import pytest
|
2020-01-10 02:19:10 +00:00
|
|
|
from samsungctl.exceptions import AccessDenied, UnhandledResponse
|
2022-03-02 19:30:33 +00:00
|
|
|
from samsungtvws.async_remote import SamsungTVWSAsyncRemote
|
2021-07-15 12:43:35 +00:00
|
|
|
from samsungtvws.exceptions import ConnectionFailure, HttpApiError
|
2022-03-15 07:20:24 +00:00
|
|
|
from websockets import frames
|
|
|
|
from websockets.exceptions import (
|
|
|
|
ConnectionClosedError,
|
|
|
|
WebSocketException,
|
|
|
|
WebSocketProtocolError,
|
|
|
|
)
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-04-25 09:27:40 +00:00
|
|
|
from homeassistant import config_entries
|
2021-11-25 17:46:20 +00:00
|
|
|
from homeassistant.components import dhcp, ssdp, zeroconf
|
2020-01-10 02:19:10 +00:00
|
|
|
from homeassistant.components.samsungtv.const import (
|
|
|
|
CONF_MANUFACTURER,
|
|
|
|
CONF_MODEL,
|
2021-05-22 15:41:18 +00:00
|
|
|
DEFAULT_MANUFACTURER,
|
2020-01-10 02:19:10 +00:00
|
|
|
DOMAIN,
|
2021-06-24 18:15:16 +00:00
|
|
|
LEGACY_PORT,
|
2021-05-22 15:41:18 +00:00
|
|
|
METHOD_LEGACY,
|
|
|
|
METHOD_WEBSOCKET,
|
|
|
|
RESULT_AUTH_MISSING,
|
|
|
|
RESULT_CANNOT_CONNECT,
|
|
|
|
RESULT_NOT_SUPPORTED,
|
|
|
|
RESULT_UNKNOWN_HOST,
|
|
|
|
TIMEOUT_REQUEST,
|
|
|
|
TIMEOUT_WEBSOCKET,
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
from homeassistant.components.ssdp import (
|
|
|
|
ATTR_UPNP_FRIENDLY_NAME,
|
|
|
|
ATTR_UPNP_MANUFACTURER,
|
|
|
|
ATTR_UPNP_MODEL_NAME,
|
|
|
|
ATTR_UPNP_UDN,
|
|
|
|
)
|
2021-05-22 15:41:18 +00:00
|
|
|
from homeassistant.const import (
|
|
|
|
CONF_HOST,
|
|
|
|
CONF_ID,
|
|
|
|
CONF_IP_ADDRESS,
|
|
|
|
CONF_MAC,
|
|
|
|
CONF_METHOD,
|
|
|
|
CONF_NAME,
|
|
|
|
CONF_PORT,
|
|
|
|
CONF_TOKEN,
|
|
|
|
)
|
|
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
from homeassistant.setup import async_setup_component
|
|
|
|
|
2022-03-08 06:54:12 +00:00
|
|
|
from .const import SAMPLE_APP_LIST, SAMPLE_DEVICE_INFO_FRAME
|
2022-02-18 21:33:49 +00:00
|
|
|
|
2021-05-22 15:41:18 +00:00
|
|
|
from tests.common import MockConfigEntry
|
2022-02-16 08:29:52 +00:00
|
|
|
|
|
|
|
RESULT_ALREADY_CONFIGURED = "already_configured"
|
|
|
|
RESULT_ALREADY_IN_PROGRESS = "already_in_progress"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-05-22 15:41:18 +00:00
|
|
|
MOCK_IMPORT_DATA = {
|
|
|
|
CONF_HOST: "fake_host",
|
|
|
|
CONF_NAME: "fake",
|
|
|
|
CONF_PORT: 55000,
|
|
|
|
}
|
2021-05-28 14:06:17 +00:00
|
|
|
MOCK_IMPORT_DATA_WITHOUT_NAME = {
|
|
|
|
CONF_HOST: "fake_host",
|
|
|
|
}
|
2021-05-22 15:41:18 +00:00
|
|
|
MOCK_IMPORT_WSDATA = {
|
|
|
|
CONF_HOST: "fake_host",
|
|
|
|
CONF_NAME: "fake",
|
|
|
|
CONF_PORT: 8002,
|
|
|
|
}
|
2020-01-10 02:19:10 +00:00
|
|
|
MOCK_USER_DATA = {CONF_HOST: "fake_host", CONF_NAME: "fake_name"}
|
2021-11-25 17:46:20 +00:00
|
|
|
MOCK_SSDP_DATA = ssdp.SsdpServiceInfo(
|
|
|
|
ssdp_usn="mock_usn",
|
|
|
|
ssdp_st="mock_st",
|
|
|
|
ssdp_location="https://fake_host:12345/test",
|
|
|
|
upnp={
|
|
|
|
ATTR_UPNP_FRIENDLY_NAME: "[TV] fake_name",
|
|
|
|
ATTR_UPNP_MANUFACTURER: "Samsung fake_manufacturer",
|
|
|
|
ATTR_UPNP_MODEL_NAME: "fake_model",
|
|
|
|
ATTR_UPNP_UDN: "uuid:0d1cef00-00dc-1000-9c80-4844f7b172de",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
MOCK_SSDP_DATA_NOPREFIX = ssdp.SsdpServiceInfo(
|
|
|
|
ssdp_usn="mock_usn",
|
|
|
|
ssdp_st="mock_st",
|
|
|
|
ssdp_location="http://fake2_host:12345/test",
|
|
|
|
upnp={
|
|
|
|
ATTR_UPNP_FRIENDLY_NAME: "fake2_name",
|
|
|
|
ATTR_UPNP_MANUFACTURER: "Samsung fake2_manufacturer",
|
|
|
|
ATTR_UPNP_MODEL_NAME: "fake2_model",
|
|
|
|
ATTR_UPNP_UDN: "uuid:0d1cef00-00dc-1000-9c80-4844f7b172df",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
MOCK_SSDP_DATA_WRONGMODEL = ssdp.SsdpServiceInfo(
|
|
|
|
ssdp_usn="mock_usn",
|
|
|
|
ssdp_st="mock_st",
|
|
|
|
ssdp_location="http://fake2_host:12345/test",
|
|
|
|
upnp={
|
|
|
|
ATTR_UPNP_FRIENDLY_NAME: "fake2_name",
|
|
|
|
ATTR_UPNP_MANUFACTURER: "fake2_manufacturer",
|
|
|
|
ATTR_UPNP_MODEL_NAME: "HW-Qfake",
|
|
|
|
ATTR_UPNP_UDN: "uuid:0d1cef00-00dc-1000-9c80-4844f7b172df",
|
|
|
|
},
|
|
|
|
)
|
2021-11-23 12:35:53 +00:00
|
|
|
MOCK_DHCP_DATA = dhcp.DhcpServiceInfo(
|
2022-03-03 18:07:08 +00:00
|
|
|
ip="fake_host", macaddress="aa:bb:dd:hh:cc:pp", hostname="fake_hostname"
|
2021-11-23 12:35:53 +00:00
|
|
|
)
|
2021-07-15 12:43:35 +00:00
|
|
|
EXISTING_IP = "192.168.40.221"
|
2021-11-21 22:00:59 +00:00
|
|
|
MOCK_ZEROCONF_DATA = zeroconf.ZeroconfServiceInfo(
|
|
|
|
host="fake_host",
|
2022-02-11 22:46:17 +00:00
|
|
|
addresses=["fake_host"],
|
2021-11-23 16:35:44 +00:00
|
|
|
hostname="mock_hostname",
|
|
|
|
name="mock_name",
|
2021-11-21 22:00:59 +00:00
|
|
|
port=1234,
|
|
|
|
properties={
|
2022-03-03 18:07:08 +00:00
|
|
|
"deviceid": "aa:bb:zz:ee:rr:oo",
|
2021-05-22 15:41:18 +00:00
|
|
|
"manufacturer": "fake_manufacturer",
|
|
|
|
"model": "fake_model",
|
|
|
|
"serialNumber": "fake_serial",
|
|
|
|
},
|
2021-11-23 16:35:44 +00:00
|
|
|
type="mock_type",
|
2021-11-21 22:00:59 +00:00
|
|
|
)
|
2021-05-22 15:41:18 +00:00
|
|
|
MOCK_OLD_ENTRY = {
|
|
|
|
CONF_HOST: "fake_host",
|
|
|
|
CONF_ID: "0d1cef00-00dc-1000-9c80-4844f7b172de_old",
|
2021-07-15 12:43:35 +00:00
|
|
|
CONF_IP_ADDRESS: EXISTING_IP,
|
|
|
|
CONF_METHOD: "legacy",
|
|
|
|
CONF_PORT: None,
|
|
|
|
}
|
|
|
|
MOCK_LEGACY_ENTRY = {
|
|
|
|
CONF_HOST: EXISTING_IP,
|
|
|
|
CONF_ID: "0d1cef00-00dc-1000-9c80-4844f7b172de_old",
|
2021-05-22 15:41:18 +00:00
|
|
|
CONF_METHOD: "legacy",
|
|
|
|
CONF_PORT: None,
|
|
|
|
}
|
|
|
|
MOCK_WS_ENTRY = {
|
|
|
|
CONF_HOST: "fake_host",
|
|
|
|
CONF_METHOD: METHOD_WEBSOCKET,
|
|
|
|
CONF_PORT: 8002,
|
|
|
|
CONF_MODEL: "any",
|
|
|
|
CONF_NAME: "any",
|
2020-01-10 02:19:10 +00:00
|
|
|
}
|
2021-07-12 06:58:53 +00:00
|
|
|
MOCK_DEVICE_INFO = {
|
|
|
|
"device": {
|
|
|
|
"type": "Samsung SmartTV",
|
|
|
|
"name": "fake_name",
|
|
|
|
"modelName": "fake_model",
|
|
|
|
},
|
|
|
|
"id": "123",
|
|
|
|
}
|
2021-11-23 10:56:16 +00:00
|
|
|
MOCK_DEVICE_INFO_2 = {
|
|
|
|
"device": {
|
|
|
|
"type": "Samsung SmartTV",
|
|
|
|
"name": "fake2_name",
|
|
|
|
"modelName": "fake2_model",
|
|
|
|
},
|
|
|
|
"id": "345",
|
|
|
|
}
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
AUTODETECT_LEGACY = {
|
|
|
|
"name": "HomeAssistant",
|
|
|
|
"description": "HomeAssistant",
|
|
|
|
"id": "ha.component.samsung",
|
|
|
|
"method": "legacy",
|
|
|
|
"port": None,
|
|
|
|
"host": "fake_host",
|
2021-05-22 15:41:18 +00:00
|
|
|
"timeout": TIMEOUT_REQUEST,
|
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,
|
2021-05-22 15:41:18 +00:00
|
|
|
"timeout": TIMEOUT_REQUEST,
|
2020-03-21 15:50:18 +00:00
|
|
|
"token": None,
|
|
|
|
}
|
|
|
|
AUTODETECT_WEBSOCKET_SSL = {
|
|
|
|
"host": "fake_host",
|
|
|
|
"name": "HomeAssistant",
|
|
|
|
"port": 8002,
|
2021-05-22 15:41:18 +00:00
|
|
|
"timeout": TIMEOUT_REQUEST,
|
2020-03-21 15:50:18 +00:00
|
|
|
"token": None,
|
|
|
|
}
|
2021-05-22 15:41:18 +00:00
|
|
|
DEVICEINFO_WEBSOCKET_SSL = {
|
|
|
|
"host": "fake_host",
|
2022-02-28 19:53:42 +00:00
|
|
|
"session": ANY,
|
2021-05-22 15:41:18 +00:00
|
|
|
"port": 8002,
|
|
|
|
"timeout": TIMEOUT_WEBSOCKET,
|
|
|
|
}
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
|
|
|
async def test_user_legacy(hass: HomeAssistant) -> None:
|
2020-03-10 10:48:09 +00:00
|
|
|
"""Test starting a flow by user."""
|
2020-01-10 02:19:10 +00:00
|
|
|
# show form
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
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"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["data"][CONF_MANUFACTURER] == DEFAULT_MANUFACTURER
|
2020-01-10 02:19:10 +00:00
|
|
|
assert result["data"][CONF_MODEL] is None
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["result"].unique_id is None
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_user_websocket(hass: HomeAssistant) -> None:
|
2020-03-10 10:48:09 +00:00
|
|
|
"""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(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}
|
2020-03-10 10:48:09 +00:00
|
|
|
)
|
|
|
|
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
|
|
|
|
)
|
2021-05-22 15:41:18 +00:00
|
|
|
# websocket tv entry created
|
2020-03-10 10:48:09 +00:00
|
|
|
assert result["type"] == "create_entry"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["title"] == "Living Room (82GXARRS)"
|
2020-03-10 10:48:09 +00:00
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["data"][CONF_NAME] == "Living Room"
|
2020-03-10 10:48:09 +00:00
|
|
|
assert result["data"][CONF_METHOD] == "websocket"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung"
|
|
|
|
assert result["data"][CONF_MODEL] == "82GXARRS"
|
|
|
|
assert result["result"].unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
2020-03-10 10:48:09 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_user_legacy_missing_auth(hass: HomeAssistant) -> None:
|
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"),
|
2021-05-22 15:41:18 +00:00
|
|
|
):
|
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(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_AUTH_MISSING
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_user_legacy_not_supported(hass: HomeAssistant) -> None:
|
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"),
|
2021-05-22 15:41:18 +00:00
|
|
|
):
|
2020-03-10 10:48:09 +00:00
|
|
|
# legacy device not supported
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-03-10 10:48:09 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_NOT_SUPPORTED
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_user_websocket_not_supported(hass: HomeAssistant) -> None:
|
2020-03-10 10:48:09 +00:00
|
|
|
"""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(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote.open",
|
|
|
|
side_effect=WebSocketProtocolError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
):
|
|
|
|
# websocket device not supported
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_NOT_SUPPORTED
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-03-15 07:20:24 +00:00
|
|
|
async def test_user_websocket_access_denied(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
|
|
|
"""Test starting a flow by user for not supported device."""
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote.open",
|
|
|
|
side_effect=ConnectionClosedError(rcvd=None, sent=frames.Close(1002, "")),
|
|
|
|
):
|
|
|
|
# websocket device not supported
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == RESULT_NOT_SUPPORTED
|
|
|
|
assert "Please check the Device Connection Manager on your TV" in caplog.text
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_user_not_successful(hass: HomeAssistant) -> None:
|
2020-02-03 19:34:02 +00:00
|
|
|
"""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(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote.open",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=OSError("Boom"),
|
2020-03-10 10:48:09 +00:00
|
|
|
):
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-03-10 10:48:09 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_CANNOT_CONNECT
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2020-03-10 10:48:09 +00:00
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_user_not_successful_2(hass: HomeAssistant) -> None:
|
2020-03-10 10:48:09 +00:00
|
|
|
"""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(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote.open",
|
2020-03-10 10:48:09 +00:00
|
|
|
side_effect=ConnectionFailure("Boom"),
|
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_CANNOT_CONNECT
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
2022-03-03 18:07:08 +00:00
|
|
|
async def test_ssdp(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow from discovery."""
|
2021-11-23 10:56:16 +00:00
|
|
|
with patch(
|
2022-02-22 18:31:16 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSBridge.async_device_info",
|
2021-11-23 10:56:16 +00:00
|
|
|
return_value=MOCK_DEVICE_INFO,
|
2021-11-24 21:54:49 +00:00
|
|
|
):
|
2021-11-23 10:56:16 +00:00
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-11-23 10:56:16 +00:00
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "fake_name (fake_model)"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "fake_name"
|
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung fake_manufacturer"
|
|
|
|
assert result["data"][CONF_MODEL] == "fake_model"
|
2022-03-08 06:53:59 +00:00
|
|
|
assert result["result"].unique_id == "123"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
2022-03-03 18:07:08 +00:00
|
|
|
async def test_ssdp_noprefix(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow from discovery without prefixes."""
|
2021-07-12 06:58:53 +00:00
|
|
|
with patch(
|
2022-02-22 18:31:16 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSBridge.async_device_info",
|
2021-11-23 10:56:16 +00:00
|
|
|
return_value=MOCK_DEVICE_INFO_2,
|
2021-11-24 21:54:49 +00:00
|
|
|
):
|
2021-11-23 10:56:16 +00:00
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_SSDP},
|
|
|
|
data=MOCK_SSDP_DATA_NOPREFIX,
|
2021-07-12 06:58:53 +00:00
|
|
|
)
|
2021-11-23 10:56:16 +00:00
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-11-23 10:56:16 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.Remote.__enter__",
|
|
|
|
return_value=True,
|
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-11-23 10:56:16 +00:00
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "fake2_name (fake2_model)"
|
|
|
|
assert result["data"][CONF_HOST] == "fake2_host"
|
|
|
|
assert result["data"][CONF_NAME] == "fake2_name"
|
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung fake2_manufacturer"
|
|
|
|
assert result["data"][CONF_MODEL] == "fake2_model"
|
2022-03-08 06:53:59 +00:00
|
|
|
assert result["result"].unique_id == "345"
|
2021-11-23 10:56:16 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_ssdp_legacy_missing_auth(hass: HomeAssistant) -> None:
|
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"),
|
2021-05-22 15:41:18 +00:00
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
# missing authentication
|
2021-07-12 06:58:53 +00:00
|
|
|
|
|
|
|
with patch(
|
2022-02-22 18:31:16 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVLegacyBridge.async_try_connect",
|
2021-07-12 06:58:53 +00:00
|
|
|
return_value=RESULT_AUTH_MISSING,
|
|
|
|
):
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == RESULT_AUTH_MISSING
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote", "remotews")
|
|
|
|
async def test_ssdp_legacy_not_supported(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow from discovery for not supported device."""
|
|
|
|
|
2021-07-12 06:58:53 +00:00
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-07-12 06:58:53 +00:00
|
|
|
with patch(
|
2022-02-22 18:31:16 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVLegacyBridge.async_try_connect",
|
2021-07-12 06:58:53 +00:00
|
|
|
return_value=RESULT_NOT_SUPPORTED,
|
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
# device not supported
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_NOT_SUPPORTED
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote", "remotews")
|
2021-06-24 18:15:16 +00:00
|
|
|
async def test_ssdp_websocket_success_populates_mac_address(
|
2021-09-19 08:24:27 +00:00
|
|
|
hass: HomeAssistant,
|
2022-02-17 20:47:58 +00:00
|
|
|
) -> None:
|
2021-06-24 18:15:16 +00:00
|
|
|
"""Test starting a flow from ssdp for a supported device populates the mac."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"], user_input="whatever"
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "Living Room (82GXARRS)"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "Living Room"
|
2022-03-03 18:07:08 +00:00
|
|
|
assert result["data"][CONF_MAC] == "aa:bb:ww:ii:ff:ii"
|
2021-06-24 18:15:16 +00:00
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung fake_manufacturer"
|
|
|
|
assert result["data"][CONF_MODEL] == "82GXARRS"
|
2022-03-08 06:53:59 +00:00
|
|
|
assert result["result"].unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
2021-06-24 18:15:16 +00:00
|
|
|
|
|
|
|
|
2022-02-28 19:53:42 +00:00
|
|
|
async def test_ssdp_websocket_not_supported(
|
|
|
|
hass: HomeAssistant, rest_api: Mock
|
|
|
|
) -> None:
|
2020-02-08 11:03:35 +00:00
|
|
|
"""Test starting a flow from discovery for not supported device."""
|
2022-02-28 19:53:42 +00:00
|
|
|
rest_api.rest_device_info.return_value = None
|
2020-02-08 11:03:35 +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(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote",
|
2022-02-16 22:04:50 +00:00
|
|
|
) as remotews, patch.object(
|
2022-03-02 19:30:33 +00:00
|
|
|
remotews, "open", side_effect=WebSocketProtocolError("Boom")
|
2020-03-10 10:48:09 +00:00
|
|
|
):
|
2021-07-12 06:58:53 +00:00
|
|
|
# device not supported
|
2020-02-08 11:03:35 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
2020-02-08 11:03:35 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_NOT_SUPPORTED
|
2020-02-08 11:03:35 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
|
|
|
async def test_ssdp_model_not_supported(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test starting a flow from discovery."""
|
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_SSDP},
|
|
|
|
data=MOCK_SSDP_DATA_WRONGMODEL,
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == RESULT_NOT_SUPPORTED
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_ssdp_not_successful(hass: HomeAssistant) -> None:
|
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(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote.open",
|
2020-01-10 02:19:10 +00:00
|
|
|
side_effect=OSError("Boom"),
|
2021-07-12 06:58:53 +00:00
|
|
|
), patch(
|
2022-02-22 18:31:16 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSBridge.async_device_info",
|
2021-07-12 06:58:53 +00:00
|
|
|
return_value=MOCK_DEVICE_INFO,
|
2020-03-10 10:48:09 +00:00
|
|
|
):
|
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
2020-03-10 10:48:09 +00:00
|
|
|
)
|
|
|
|
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"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_CANNOT_CONNECT
|
2020-03-10 10:48:09 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_ssdp_not_successful_2(hass: HomeAssistant) -> None:
|
2020-03-10 10:48:09 +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(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote.open",
|
2020-03-10 10:48:09 +00:00
|
|
|
side_effect=ConnectionFailure("Boom"),
|
2021-07-12 06:58:53 +00:00
|
|
|
), patch(
|
2022-02-22 18:31:16 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSBridge.async_device_info",
|
2021-07-12 06:58:53 +00:00
|
|
|
return_value=MOCK_DEVICE_INFO,
|
2020-03-10 10:48:09 +00:00
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
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"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_CANNOT_CONNECT
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
2022-03-03 18:07:08 +00:00
|
|
|
async def test_ssdp_already_in_progress(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow from discovery twice."""
|
2021-11-23 10:56:16 +00:00
|
|
|
with patch(
|
2022-02-22 18:31:16 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSBridge.async_device_info",
|
2021-11-23 10:56:16 +00:00
|
|
|
return_value=MOCK_DEVICE_INFO,
|
2021-11-24 21:54:49 +00:00
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-11-23 10:56:16 +00:00
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.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": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == RESULT_ALREADY_IN_PROGRESS
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
2022-03-03 18:07:08 +00:00
|
|
|
async def test_ssdp_already_configured(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test starting a flow from discovery when already configured."""
|
2021-11-23 10:56:16 +00:00
|
|
|
with patch(
|
2022-02-22 18:31:16 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSBridge.async_device_info",
|
2021-11-23 10:56:16 +00:00
|
|
|
return_value=MOCK_DEVICE_INFO,
|
2021-11-24 21:54:49 +00:00
|
|
|
):
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-11-23 10:56:16 +00:00
|
|
|
# entry was added
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
entry = result["result"]
|
|
|
|
assert entry.data[CONF_MANUFACTURER] == DEFAULT_MANUFACTURER
|
|
|
|
assert entry.data[CONF_MODEL] is None
|
|
|
|
assert entry.unique_id is None
|
2020-01-10 02:19:10 +00:00
|
|
|
|
2021-11-23 10:56:16 +00:00
|
|
|
# failed as already configured
|
|
|
|
result2 = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result2["type"] == "abort"
|
|
|
|
assert result2["reason"] == RESULT_ALREADY_CONFIGURED
|
|
|
|
|
|
|
|
# check updated device info
|
2022-03-08 06:53:59 +00:00
|
|
|
assert entry.unique_id == "123"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
2022-03-03 18:07:08 +00:00
|
|
|
async def test_import_legacy(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test importing from yaml with hostname."""
|
2022-02-16 08:29:52 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_IMPORT},
|
|
|
|
data=MOCK_IMPORT_DATA,
|
|
|
|
)
|
2021-05-22 15:41:18 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "fake"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "fake"
|
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung"
|
|
|
|
assert result["result"].unique_id is None
|
2021-05-28 14:06:17 +00:00
|
|
|
|
2021-06-24 18:15:16 +00:00
|
|
|
entries = hass.config_entries.async_entries(DOMAIN)
|
|
|
|
assert len(entries) == 1
|
|
|
|
assert entries[0].data[CONF_METHOD] == METHOD_LEGACY
|
|
|
|
assert entries[0].data[CONF_PORT] == LEGACY_PORT
|
|
|
|
|
2021-05-28 14:06:17 +00:00
|
|
|
|
2022-03-03 18:07:08 +00:00
|
|
|
@pytest.mark.usefixtures("remote", "remotews")
|
2022-02-28 19:53:42 +00:00
|
|
|
async def test_import_legacy_without_name(hass: HomeAssistant, rest_api: Mock) -> None:
|
2021-05-28 14:06:17 +00:00
|
|
|
"""Test importing from yaml without a name."""
|
2022-02-28 19:53:42 +00:00
|
|
|
rest_api.rest_device_info.return_value = None
|
2022-02-16 08:29:52 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_IMPORT},
|
|
|
|
data=MOCK_IMPORT_DATA_WITHOUT_NAME,
|
|
|
|
)
|
2021-05-28 14:06:17 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "fake_host"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung"
|
|
|
|
assert result["result"].unique_id is None
|
2020-03-21 15:50:18 +00:00
|
|
|
|
2021-06-24 18:15:16 +00:00
|
|
|
entries = hass.config_entries.async_entries(DOMAIN)
|
|
|
|
assert len(entries) == 1
|
|
|
|
assert entries[0].data[CONF_METHOD] == METHOD_LEGACY
|
|
|
|
assert entries[0].data[CONF_PORT] == LEGACY_PORT
|
|
|
|
|
2021-05-22 15:41:18 +00:00
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_import_websocket(hass: HomeAssistant):
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test importing from yaml with hostname."""
|
2022-02-16 08:29:52 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_IMPORT},
|
|
|
|
data=MOCK_IMPORT_WSDATA,
|
|
|
|
)
|
2021-05-22 15:41:18 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "fake"
|
|
|
|
assert result["data"][CONF_METHOD] == METHOD_WEBSOCKET
|
2021-06-24 18:15:16 +00:00
|
|
|
assert result["data"][CONF_PORT] == 8002
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "fake"
|
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung"
|
|
|
|
assert result["result"].unique_id is None
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_import_websocket_without_port(hass: HomeAssistant):
|
2021-06-24 18:15:16 +00:00
|
|
|
"""Test importing from yaml with hostname by no port."""
|
2022-02-16 08:29:52 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_IMPORT},
|
|
|
|
data=MOCK_IMPORT_WSDATA,
|
|
|
|
)
|
2021-06-24 18:15:16 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["title"] == "fake"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "fake"
|
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung"
|
|
|
|
assert result["result"].unique_id is None
|
|
|
|
|
2021-06-24 18:15:16 +00:00
|
|
|
entries = hass.config_entries.async_entries(DOMAIN)
|
|
|
|
assert len(entries) == 1
|
|
|
|
assert entries[0].data[CONF_METHOD] == METHOD_WEBSOCKET
|
|
|
|
assert entries[0].data[CONF_PORT] == 8002
|
|
|
|
|
2021-05-22 15:41:18 +00:00
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_import_unknown_host(hass: HomeAssistant):
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test importing from yaml with hostname that does not resolve."""
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.config_flow.socket.gethostbyname",
|
|
|
|
side_effect=socket.gaierror,
|
|
|
|
):
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_IMPORT},
|
|
|
|
data=MOCK_IMPORT_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == RESULT_UNKNOWN_HOST
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote", "remotews")
|
2022-03-08 06:54:12 +00:00
|
|
|
async def test_dhcp_wireless(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test starting a flow from dhcp."""
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_DHCP},
|
|
|
|
data=MOCK_DHCP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
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"
|
|
|
|
assert result["title"] == "Living Room (82GXARRS)"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "Living Room"
|
2022-03-03 18:07:08 +00:00
|
|
|
assert result["data"][CONF_MAC] == "aa:bb:ww:ii:ff:ii"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung"
|
|
|
|
assert result["data"][CONF_MODEL] == "82GXARRS"
|
|
|
|
assert result["result"].unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
|
|
|
|
|
|
|
|
2022-03-08 06:54:12 +00:00
|
|
|
@pytest.mark.usefixtures("remote", "remotews")
|
|
|
|
async def test_dhcp_wired(hass: HomeAssistant, rest_api: Mock) -> None:
|
|
|
|
"""Test starting a flow from dhcp."""
|
|
|
|
# Even though it is named "wifiMac", it matches the mac of the wired connection
|
|
|
|
rest_api.rest_device_info.return_value = SAMPLE_DEVICE_INFO_FRAME
|
|
|
|
# confirm to add the entry
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_DHCP},
|
|
|
|
data=MOCK_DHCP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
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"
|
|
|
|
assert result["title"] == "Samsung Frame (43) (UE43LS003)"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "Samsung Frame (43)"
|
|
|
|
assert result["data"][CONF_MAC] == "aa:ee:tt:hh:ee:rr"
|
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung"
|
|
|
|
assert result["data"][CONF_MODEL] == "UE43LS003"
|
|
|
|
assert result["result"].unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote", "remotews")
|
|
|
|
async def test_zeroconf(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test starting a flow from zeroconf."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_ZEROCONF},
|
|
|
|
data=MOCK_ZEROCONF_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
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"
|
|
|
|
assert result["title"] == "Living Room (82GXARRS)"
|
|
|
|
assert result["data"][CONF_HOST] == "fake_host"
|
|
|
|
assert result["data"][CONF_NAME] == "Living Room"
|
2022-03-03 18:07:08 +00:00
|
|
|
assert result["data"][CONF_MAC] == "aa:bb:ww:ii:ff:ii"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["data"][CONF_MANUFACTURER] == "Samsung"
|
|
|
|
assert result["data"][CONF_MODEL] == "82GXARRS"
|
|
|
|
assert result["result"].unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
2020-03-21 15:50:18 +00:00
|
|
|
|
|
|
|
|
2022-02-28 19:53:42 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_zeroconf_ignores_soundbar(hass: HomeAssistant, rest_api: Mock) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test starting a flow from zeroconf where the device is actually a soundbar."""
|
2022-02-28 19:53:42 +00:00
|
|
|
rest_api.rest_device_info.return_value = {
|
|
|
|
"id": "uuid:be9554b9-c9fb-41f4-8920-22da015376a4",
|
|
|
|
"device": {
|
|
|
|
"modelName": "82GXARRS",
|
|
|
|
"wifiMac": "aa:bb:cc:dd:ee:ff",
|
|
|
|
"mac": "aa:bb:cc:dd:ee:ff",
|
|
|
|
"name": "[TV] Living Room",
|
|
|
|
"type": "Samsung SoundBar",
|
|
|
|
},
|
|
|
|
}
|
2021-05-22 15:41:18 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_ZEROCONF},
|
|
|
|
data=MOCK_ZEROCONF_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "not_supported"
|
|
|
|
|
|
|
|
|
2022-02-28 19:53:42 +00:00
|
|
|
@pytest.mark.usefixtures("remote", "remotews")
|
|
|
|
async def test_zeroconf_no_device_info(hass: HomeAssistant, rest_api: Mock) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test starting a flow from zeroconf where device_info returns None."""
|
2022-02-28 19:53:42 +00:00
|
|
|
rest_api.rest_device_info.return_value = None
|
2021-05-22 15:41:18 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_ZEROCONF},
|
|
|
|
data=MOCK_ZEROCONF_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "not_supported"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_zeroconf_and_dhcp_same_time(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test starting a flow from zeroconf and dhcp."""
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_DHCP},
|
|
|
|
data=MOCK_DHCP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
|
|
|
|
result2 = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_ZEROCONF},
|
|
|
|
data=MOCK_ZEROCONF_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result2["type"] == "abort"
|
|
|
|
assert result2["reason"] == "already_in_progress"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_autodetect_websocket(hass: HomeAssistant) -> None:
|
2020-03-21 15:50:18 +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"),
|
2022-02-28 19:53:42 +00:00
|
|
|
), patch(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote"
|
2022-02-28 19:53:42 +00:00
|
|
|
) as remotews, patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVAsyncRest",
|
|
|
|
) as rest_api_class:
|
2022-03-02 19:30:33 +00:00
|
|
|
remote = Mock(SamsungTVWSAsyncRemote)
|
|
|
|
remote.__aenter__ = AsyncMock(return_value=remote)
|
|
|
|
remote.__aexit__ = AsyncMock(return_value=False)
|
2022-02-18 21:33:49 +00:00
|
|
|
remote.app_list.return_value = SAMPLE_APP_LIST
|
2022-02-28 19:53:42 +00:00
|
|
|
rest_api_class.return_value.rest_device_info = AsyncMock(
|
|
|
|
return_value={
|
|
|
|
"id": "uuid:be9554b9-c9fb-41f4-8920-22da015376a4",
|
|
|
|
"device": {
|
|
|
|
"modelName": "82GXARRS",
|
|
|
|
"networkType": "wireless",
|
|
|
|
"wifiMac": "aa:bb:cc:dd:ee:ff",
|
|
|
|
"udn": "uuid:be9554b9-c9fb-41f4-8920-22da015376a4",
|
|
|
|
"mac": "aa:bb:cc:dd:ee:ff",
|
|
|
|
"name": "[TV] Living Room",
|
|
|
|
"type": "Samsung SmartTV",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
)
|
2022-02-16 20:13:11 +00:00
|
|
|
remote.token = "123456789"
|
2020-03-21 15:50:18 +00:00
|
|
|
remotews.return_value = remote
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-03-21 15:50:18 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["data"][CONF_METHOD] == "websocket"
|
|
|
|
assert result["data"][CONF_TOKEN] == "123456789"
|
2022-02-28 19:53:42 +00:00
|
|
|
remotews.assert_called_once_with(**AUTODETECT_WEBSOCKET_SSL)
|
|
|
|
rest_api_class.assert_called_once_with(**DEVICEINFO_WEBSOCKET_SSL)
|
2021-06-24 18:15:16 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
entries = hass.config_entries.async_entries(DOMAIN)
|
|
|
|
assert len(entries) == 1
|
|
|
|
assert entries[0].data[CONF_MAC] == "aa:bb:cc:dd:ee:ff"
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-03-03 18:07:08 +00:00
|
|
|
async def test_websocket_no_mac(hass: HomeAssistant, mac_address: Mock) -> None:
|
2021-07-26 14:43:05 +00:00
|
|
|
"""Test for send key with autodetection of protocol."""
|
2022-03-03 18:07:08 +00:00
|
|
|
mac_address.return_value = "gg:ee:tt:mm:aa:cc"
|
2021-07-26 14:43:05 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.Remote",
|
|
|
|
side_effect=OSError("Boom"),
|
|
|
|
), patch(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote"
|
2021-07-26 14:43:05 +00:00
|
|
|
) as remotews, patch(
|
2022-02-28 19:53:42 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVAsyncRest",
|
2022-03-03 18:07:08 +00:00
|
|
|
) as rest_api_class:
|
2022-03-02 19:30:33 +00:00
|
|
|
remote = Mock(SamsungTVWSAsyncRemote)
|
|
|
|
remote.__aenter__ = AsyncMock(return_value=remote)
|
|
|
|
remote.__aexit__ = AsyncMock(return_value=False)
|
2022-02-18 21:33:49 +00:00
|
|
|
remote.app_list.return_value = SAMPLE_APP_LIST
|
2022-02-28 19:53:42 +00:00
|
|
|
rest_api_class.return_value.rest_device_info = AsyncMock(
|
|
|
|
return_value={
|
|
|
|
"id": "uuid:be9554b9-c9fb-41f4-8920-22da015376a4",
|
|
|
|
"device": {
|
|
|
|
"modelName": "82GXARRS",
|
|
|
|
"networkType": "lan",
|
|
|
|
"udn": "uuid:be9554b9-c9fb-41f4-8920-22da015376a4",
|
|
|
|
"name": "[TV] Living Room",
|
|
|
|
"type": "Samsung SmartTV",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
2022-02-16 20:13:11 +00:00
|
|
|
remote.token = "123456789"
|
2021-07-26 14:43:05 +00:00
|
|
|
remotews.return_value = remote
|
|
|
|
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["data"][CONF_METHOD] == "websocket"
|
|
|
|
assert result["data"][CONF_TOKEN] == "123456789"
|
2022-03-03 18:07:08 +00:00
|
|
|
assert result["data"][CONF_MAC] == "gg:ee:tt:mm:aa:cc"
|
2022-02-28 19:53:42 +00:00
|
|
|
remotews.assert_called_once_with(**AUTODETECT_WEBSOCKET_SSL)
|
|
|
|
rest_api_class.assert_called_once_with(**DEVICEINFO_WEBSOCKET_SSL)
|
2021-07-26 14:43:05 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
entries = hass.config_entries.async_entries(DOMAIN)
|
|
|
|
assert len(entries) == 1
|
2022-03-03 18:07:08 +00:00
|
|
|
assert entries[0].data[CONF_MAC] == "gg:ee:tt:mm:aa:cc"
|
2021-07-26 14:43:05 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_autodetect_auth_missing(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""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")],
|
2022-02-16 08:29:52 +00:00
|
|
|
) as remote:
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_AUTH_MISSING
|
2020-01-10 02:19:10 +00:00
|
|
|
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
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_autodetect_not_supported(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""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")],
|
2022-02-16 08:29:52 +00:00
|
|
|
) as remote:
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_NOT_SUPPORTED
|
2020-01-10 02:19:10 +00:00
|
|
|
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
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
|
|
|
async def test_autodetect_legacy(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test for send key with autodetection of protocol."""
|
2021-06-24 18:15:16 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "create_entry"
|
|
|
|
assert result["data"][CONF_METHOD] == "legacy"
|
|
|
|
assert result["data"][CONF_NAME] == "fake_name"
|
|
|
|
assert result["data"][CONF_MAC] is None
|
|
|
|
assert result["data"][CONF_PORT] == LEGACY_PORT
|
2020-01-10 02:19:10 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_autodetect_none(hass: HomeAssistant) -> None:
|
2020-01-10 02:19:10 +00:00
|
|
|
"""Test for send key with autodetection of protocol."""
|
2022-02-16 20:40:11 +00:00
|
|
|
mock_remotews = Mock()
|
2022-03-02 19:30:33 +00:00
|
|
|
mock_remotews.__aenter__ = AsyncMock(return_value=mock_remotews)
|
|
|
|
mock_remotews.__aexit__ = AsyncMock()
|
2022-02-16 20:40:11 +00:00
|
|
|
mock_remotews.open = Mock(side_effect=OSError("Boom"))
|
|
|
|
|
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
|
|
|
) as remote, patch(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote",
|
2022-02-16 20:40:11 +00:00
|
|
|
return_value=mock_remotews,
|
2022-02-16 08:29:52 +00:00
|
|
|
) as remotews:
|
2020-01-10 02:19:10 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
2021-04-25 09:27:40 +00:00
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_USER}, data=MOCK_USER_DATA
|
2020-01-10 02:19:10 +00:00
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["reason"] == RESULT_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_SSL),
|
2021-05-22 15:41:18 +00:00
|
|
|
call(**AUTODETECT_WEBSOCKET_PLAIN),
|
2020-03-10 10:48:09 +00:00
|
|
|
]
|
2021-05-22 15:41:18 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_update_old_entry(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test update of old entry."""
|
|
|
|
with patch("homeassistant.components.samsungtv.bridge.Remote") as remote:
|
|
|
|
remote().rest_device_info.return_value = {
|
|
|
|
"device": {
|
|
|
|
"modelName": "fake_model2",
|
|
|
|
"name": "[TV] Fake Name",
|
|
|
|
"udn": "uuid:fake_serial",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_OLD_ENTRY)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
|
|
|
|
config_entries_domain = hass.config_entries.async_entries(DOMAIN)
|
|
|
|
assert len(config_entries_domain) == 1
|
|
|
|
assert entry is config_entries_domain[0]
|
|
|
|
assert entry.data[CONF_ID] == "0d1cef00-00dc-1000-9c80-4844f7b172de_old"
|
2021-07-15 12:43:35 +00:00
|
|
|
assert entry.data[CONF_IP_ADDRESS] == EXISTING_IP
|
2021-05-22 15:41:18 +00:00
|
|
|
assert not entry.unique_id
|
|
|
|
|
|
|
|
assert await async_setup_component(hass, DOMAIN, {}) is True
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
# failed as already configured
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN, context={"source": config_entries.SOURCE_SSDP}, data=MOCK_SSDP_DATA
|
|
|
|
)
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == RESULT_ALREADY_CONFIGURED
|
|
|
|
|
|
|
|
config_entries_domain = hass.config_entries.async_entries(DOMAIN)
|
|
|
|
assert len(config_entries_domain) == 1
|
|
|
|
entry2 = config_entries_domain[0]
|
|
|
|
|
|
|
|
# check updated device info
|
|
|
|
assert entry2.data.get(CONF_ID) is not None
|
|
|
|
assert entry2.data.get(CONF_IP_ADDRESS) is not None
|
2022-03-08 06:53:59 +00:00
|
|
|
assert entry2.unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
2021-05-22 15:41:18 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_update_missing_mac_unique_id_added_from_dhcp(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test missing mac and unique id added."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_OLD_ENTRY, unique_id=None)
|
|
|
|
entry.add_to_hass(hass)
|
2021-06-25 20:31:33 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_DHCP},
|
|
|
|
data=MOCK_DHCP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
2022-03-03 18:07:08 +00:00
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:dd:hh:cc:pp"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert entry.unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_update_missing_mac_unique_id_added_from_zeroconf(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test missing mac and unique id added."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_OLD_ENTRY, unique_id=None)
|
|
|
|
entry.add_to_hass(hass)
|
2021-06-25 20:31:33 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_ZEROCONF},
|
|
|
|
data=MOCK_ZEROCONF_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
2022-03-03 18:07:08 +00:00
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:zz:ee:rr:oo"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert entry.unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_update_missing_mac_unique_id_added_from_ssdp(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
2021-06-25 20:31:33 +00:00
|
|
|
"""Test missing mac and unique id added via ssdp."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_OLD_ENTRY, unique_id=None)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_SSDP},
|
|
|
|
data=MOCK_SSDP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
2022-03-03 18:07:08 +00:00
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:ww:ii:ff:ii"
|
2022-03-08 06:53:59 +00:00
|
|
|
assert entry.unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
2021-06-25 20:31:33 +00:00
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
2021-05-22 15:41:18 +00:00
|
|
|
async def test_update_missing_mac_added_unique_id_preserved_from_zeroconf(
|
2022-02-17 20:47:58 +00:00
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test missing mac and unique id added."""
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=MOCK_OLD_ENTRY,
|
|
|
|
unique_id="0d1cef00-00dc-1000-9c80-4844f7b172de",
|
|
|
|
)
|
|
|
|
entry.add_to_hass(hass)
|
2021-06-25 20:31:33 +00:00
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_ZEROCONF},
|
|
|
|
data=MOCK_ZEROCONF_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
2021-05-22 15:41:18 +00:00
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
2022-03-03 18:07:08 +00:00
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:zz:ee:rr:oo"
|
2021-05-22 15:41:18 +00:00
|
|
|
assert entry.unique_id == "0d1cef00-00dc-1000-9c80-4844f7b172de"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
|
|
|
async def test_update_legacy_missing_mac_from_dhcp(hass: HomeAssistant) -> None:
|
2021-07-15 12:43:35 +00:00
|
|
|
"""Test missing mac added."""
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=MOCK_LEGACY_ENTRY,
|
|
|
|
unique_id="0d1cef00-00dc-1000-9c80-4844f7b172de",
|
|
|
|
)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_DHCP},
|
2021-11-23 12:35:53 +00:00
|
|
|
data=dhcp.DhcpServiceInfo(
|
|
|
|
ip=EXISTING_IP, macaddress="aa:bb:cc:dd:ee:ff", hostname="fake_hostname"
|
|
|
|
),
|
2021-07-15 12:43:35 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:cc:dd:ee:ff"
|
|
|
|
assert entry.unique_id == "0d1cef00-00dc-1000-9c80-4844f7b172de"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
|
|
|
async def test_update_legacy_missing_mac_from_dhcp_no_unique_id(
|
2022-02-28 19:53:42 +00:00
|
|
|
hass: HomeAssistant, rest_api: Mock
|
2022-02-17 20:47:58 +00:00
|
|
|
) -> None:
|
2021-07-15 12:43:35 +00:00
|
|
|
"""Test missing mac added when there is no unique id."""
|
2022-02-28 19:53:42 +00:00
|
|
|
rest_api.rest_device_info.side_effect = HttpApiError
|
2021-07-15 12:43:35 +00:00
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=MOCK_LEGACY_ENTRY,
|
|
|
|
)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.bridge.Remote.__enter__",
|
|
|
|
return_value=True,
|
|
|
|
), patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_DHCP},
|
2021-11-23 12:35:53 +00:00
|
|
|
data=dhcp.DhcpServiceInfo(
|
|
|
|
ip=EXISTING_IP, macaddress="aa:bb:cc:dd:ee:ff", hostname="fake_hostname"
|
|
|
|
),
|
2021-07-15 12:43:35 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "not_supported"
|
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:cc:dd:ee:ff"
|
|
|
|
assert entry.unique_id is None
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remote")
|
|
|
|
async def test_form_reauth_legacy(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test reauthenticate legacy."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_OLD_ENTRY)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"entry_id": entry.entry_id, "source": config_entries.SOURCE_REAUTH},
|
|
|
|
data=entry.data,
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["errors"] == {}
|
|
|
|
|
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
{},
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result2["type"] == "abort"
|
|
|
|
assert result2["reason"] == "reauth_successful"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_form_reauth_websocket(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test reauthenticate websocket."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_WS_ENTRY)
|
|
|
|
entry.add_to_hass(hass)
|
2021-06-10 17:23:00 +00:00
|
|
|
assert entry.state == config_entries.ConfigEntryState.NOT_LOADED
|
|
|
|
|
2021-05-22 15:41:18 +00:00
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"entry_id": entry.entry_id, "source": config_entries.SOURCE_REAUTH},
|
|
|
|
data=entry.data,
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["errors"] == {}
|
|
|
|
|
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
{},
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert result2["type"] == "abort"
|
|
|
|
assert result2["reason"] == "reauth_successful"
|
2021-06-10 17:23:00 +00:00
|
|
|
assert entry.state == config_entries.ConfigEntryState.LOADED
|
2021-05-22 15:41:18 +00:00
|
|
|
|
|
|
|
|
2022-02-17 21:04:48 +00:00
|
|
|
async def test_form_reauth_websocket_cannot_connect(
|
|
|
|
hass: HomeAssistant, remotews: Mock
|
|
|
|
) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test reauthenticate websocket when we cannot connect on the first attempt."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_WS_ENTRY)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"entry_id": entry.entry_id, "source": config_entries.SOURCE_REAUTH},
|
|
|
|
data=entry.data,
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["errors"] == {}
|
|
|
|
|
2022-02-16 20:40:11 +00:00
|
|
|
with patch.object(remotews, "open", side_effect=ConnectionFailure):
|
2021-05-22 15:41:18 +00:00
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
{},
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert result2["type"] == "form"
|
|
|
|
assert result2["errors"] == {"base": RESULT_AUTH_MISSING}
|
|
|
|
|
|
|
|
result3 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
{},
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert result3["type"] == "abort"
|
|
|
|
assert result3["reason"] == "reauth_successful"
|
|
|
|
|
|
|
|
|
2022-02-17 20:47:58 +00:00
|
|
|
async def test_form_reauth_websocket_not_supported(hass: HomeAssistant) -> None:
|
2021-05-22 15:41:18 +00:00
|
|
|
"""Test reauthenticate websocket when the device is not supported."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_WS_ENTRY)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"entry_id": entry.entry_id, "source": config_entries.SOURCE_REAUTH},
|
|
|
|
data=entry.data,
|
|
|
|
)
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["errors"] == {}
|
|
|
|
|
|
|
|
with patch(
|
2022-03-02 19:30:33 +00:00
|
|
|
"homeassistant.components.samsungtv.bridge.SamsungTVWSAsyncRemote.open",
|
2021-05-22 15:41:18 +00:00
|
|
|
side_effect=WebSocketException,
|
|
|
|
):
|
|
|
|
result2 = await hass.config_entries.flow.async_configure(
|
|
|
|
result["flow_id"],
|
|
|
|
{},
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert result2["type"] == "abort"
|
|
|
|
assert result2["reason"] == "not_supported"
|
2022-03-08 06:53:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_update_incorrect_udn_matching_upnp_udn_unique_id_added_from_ssdp(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
|
|
|
"""Test updating the wrong udn from ssdp via upnp udn match."""
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=MOCK_OLD_ENTRY,
|
|
|
|
unique_id="0d1cef00-00dc-1000-9c80-4844f7b172de",
|
|
|
|
)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_SSDP},
|
|
|
|
data=MOCK_SSDP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:ww:ii:ff:ii"
|
|
|
|
assert entry.unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_update_incorrect_udn_matching_mac_unique_id_added_from_ssdp(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
|
|
|
"""Test updating the wrong udn from ssdp via mac match."""
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data={**MOCK_OLD_ENTRY, CONF_MAC: "aa:bb:ww:ii:ff:ii"},
|
|
|
|
unique_id=None,
|
|
|
|
)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_SSDP},
|
|
|
|
data=MOCK_SSDP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:ww:ii:ff:ii"
|
|
|
|
assert entry.unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
2022-03-08 21:27:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_update_incorrect_udn_matching_mac_from_dhcp(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
|
|
|
"""Test that DHCP updates the wrong udn from ssdp via mac match."""
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data={**MOCK_WS_ENTRY, CONF_MAC: "aa:bb:ww:ii:ff:ii"},
|
|
|
|
source=config_entries.SOURCE_SSDP,
|
|
|
|
unique_id="0d1cef00-00dc-1000-9c80-4844f7b172de",
|
|
|
|
)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_DHCP},
|
|
|
|
data=MOCK_DHCP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 1
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
|
|
|
|
assert result["type"] == "abort"
|
|
|
|
assert result["reason"] == "already_configured"
|
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:ww:ii:ff:ii"
|
|
|
|
assert entry.unique_id == "be9554b9-c9fb-41f4-8920-22da015376a4"
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.usefixtures("remotews")
|
|
|
|
async def test_no_update_incorrect_udn_not_matching_mac_from_dhcp(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
|
|
|
"""Test that DHCP does not update the wrong udn from ssdp via host match."""
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data={**MOCK_WS_ENTRY, CONF_MAC: "aa:bb:ss:ss:dd:pp"},
|
|
|
|
source=config_entries.SOURCE_SSDP,
|
|
|
|
unique_id="0d1cef00-00dc-1000-9c80-4844f7b172de",
|
|
|
|
)
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
with patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup, patch(
|
|
|
|
"homeassistant.components.samsungtv.async_setup_entry",
|
|
|
|
return_value=True,
|
|
|
|
) as mock_setup_entry:
|
|
|
|
result = await hass.config_entries.flow.async_init(
|
|
|
|
DOMAIN,
|
|
|
|
context={"source": config_entries.SOURCE_DHCP},
|
|
|
|
data=MOCK_DHCP_DATA,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup.mock_calls) == 0
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 0
|
|
|
|
|
|
|
|
assert result["type"] == "form"
|
|
|
|
assert result["step_id"] == "confirm"
|
|
|
|
assert entry.data[CONF_MAC] == "aa:bb:ss:ss:dd:pp"
|
|
|
|
assert entry.unique_id == "0d1cef00-00dc-1000-9c80-4844f7b172de"
|