176 lines
4.8 KiB
Python
176 lines
4.8 KiB
Python
"""The tests for the LG webOS media player platform."""
|
|
import json
|
|
import os
|
|
from unittest.mock import patch
|
|
|
|
import pytest
|
|
from sqlitedict import SqliteDict
|
|
|
|
from homeassistant.components import media_player
|
|
from homeassistant.components.media_player.const import (
|
|
ATTR_INPUT_SOURCE,
|
|
ATTR_MEDIA_VOLUME_MUTED,
|
|
SERVICE_SELECT_SOURCE,
|
|
)
|
|
from homeassistant.components.webostv.const import (
|
|
ATTR_BUTTON,
|
|
ATTR_PAYLOAD,
|
|
DOMAIN,
|
|
SERVICE_BUTTON,
|
|
SERVICE_COMMAND,
|
|
WEBOSTV_CONFIG_FILE,
|
|
)
|
|
from homeassistant.const import (
|
|
ATTR_COMMAND,
|
|
ATTR_ENTITY_ID,
|
|
CONF_HOST,
|
|
CONF_NAME,
|
|
SERVICE_VOLUME_MUTE,
|
|
)
|
|
from homeassistant.setup import async_setup_component
|
|
|
|
NAME = "fake"
|
|
ENTITY_ID = f"{media_player.DOMAIN}.{NAME}"
|
|
|
|
|
|
@pytest.fixture(name="client")
|
|
def client_fixture():
|
|
"""Patch of client library for tests."""
|
|
with patch(
|
|
"homeassistant.components.webostv.WebOsClient", autospec=True
|
|
) as mock_client_class:
|
|
mock_client_class.create.return_value = mock_client_class.return_value
|
|
client = mock_client_class.return_value
|
|
client.software_info = {"device_id": "a1:b1:c1:d1:e1:f1"}
|
|
client.client_key = "0123456789"
|
|
yield client
|
|
|
|
|
|
async def setup_webostv(hass):
|
|
"""Initialize webostv and media_player for tests."""
|
|
assert await async_setup_component(
|
|
hass,
|
|
DOMAIN,
|
|
{DOMAIN: {CONF_HOST: "fake", CONF_NAME: NAME}},
|
|
)
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
@pytest.fixture
|
|
def cleanup_config(hass):
|
|
"""Test cleanup, remove the config file."""
|
|
yield
|
|
os.remove(hass.config.path(WEBOSTV_CONFIG_FILE))
|
|
|
|
|
|
async def test_mute(hass, client):
|
|
"""Test simple service call."""
|
|
|
|
await setup_webostv(hass)
|
|
|
|
data = {
|
|
ATTR_ENTITY_ID: ENTITY_ID,
|
|
ATTR_MEDIA_VOLUME_MUTED: True,
|
|
}
|
|
await hass.services.async_call(media_player.DOMAIN, SERVICE_VOLUME_MUTE, data)
|
|
await hass.async_block_till_done()
|
|
|
|
client.set_mute.assert_called_once()
|
|
|
|
|
|
async def test_select_source_with_empty_source_list(hass, client):
|
|
"""Ensure we don't call client methods when we don't have sources."""
|
|
|
|
await setup_webostv(hass)
|
|
|
|
data = {
|
|
ATTR_ENTITY_ID: ENTITY_ID,
|
|
ATTR_INPUT_SOURCE: "nonexistent",
|
|
}
|
|
await hass.services.async_call(media_player.DOMAIN, SERVICE_SELECT_SOURCE, data)
|
|
await hass.async_block_till_done()
|
|
|
|
client.launch_app.assert_not_called()
|
|
client.set_input.assert_not_called()
|
|
|
|
|
|
async def test_button(hass, client):
|
|
"""Test generic button functionality."""
|
|
|
|
await setup_webostv(hass)
|
|
|
|
data = {
|
|
ATTR_ENTITY_ID: ENTITY_ID,
|
|
ATTR_BUTTON: "test",
|
|
}
|
|
await hass.services.async_call(DOMAIN, SERVICE_BUTTON, data)
|
|
await hass.async_block_till_done()
|
|
|
|
client.button.assert_called_once()
|
|
client.button.assert_called_with("test")
|
|
|
|
|
|
async def test_command(hass, client):
|
|
"""Test generic command functionality."""
|
|
await setup_webostv(hass)
|
|
|
|
data = {
|
|
ATTR_ENTITY_ID: ENTITY_ID,
|
|
ATTR_COMMAND: "test",
|
|
}
|
|
await hass.services.async_call(DOMAIN, SERVICE_COMMAND, data)
|
|
await hass.async_block_till_done()
|
|
|
|
client.request.assert_called_with("test", payload=None)
|
|
|
|
|
|
async def test_command_with_optional_arg(hass, client):
|
|
"""Test generic command functionality."""
|
|
await setup_webostv(hass)
|
|
|
|
data = {
|
|
ATTR_ENTITY_ID: ENTITY_ID,
|
|
ATTR_COMMAND: "test",
|
|
ATTR_PAYLOAD: {"target": "https://www.google.com"},
|
|
}
|
|
await hass.services.async_call(DOMAIN, SERVICE_COMMAND, data)
|
|
await hass.async_block_till_done()
|
|
|
|
client.request.assert_called_with(
|
|
"test", payload={"target": "https://www.google.com"}
|
|
)
|
|
|
|
|
|
async def test_migrate_keyfile_to_sqlite(hass, client, cleanup_config):
|
|
"""Test migration from JSON key-file to Sqlite based one."""
|
|
key = "3d5b1aeeb98e"
|
|
# Create config file with JSON content
|
|
config_file = hass.config.path(WEBOSTV_CONFIG_FILE)
|
|
with open(config_file, "w+") as file:
|
|
json.dump({"host": key}, file)
|
|
|
|
# Run the component setup
|
|
await setup_webostv(hass)
|
|
|
|
# Assert that the config file is a Sqlite database which contains the key
|
|
with SqliteDict(config_file) as conf:
|
|
assert conf.get("host") == key
|
|
|
|
|
|
async def test_dont_migrate_sqlite_keyfile(hass, client, cleanup_config):
|
|
"""Test that migration is not performed and setup still succeeds when config file is already an Sqlite DB."""
|
|
key = "3d5b1aeeb98e"
|
|
|
|
# Create config file with Sqlite DB
|
|
config_file = hass.config.path(WEBOSTV_CONFIG_FILE)
|
|
with SqliteDict(config_file) as conf:
|
|
conf["host"] = key
|
|
conf.commit()
|
|
|
|
# Run the component setup
|
|
await setup_webostv(hass)
|
|
|
|
# Assert that the config file is still an Sqlite database and setup didn't fail
|
|
with SqliteDict(config_file) as conf:
|
|
assert conf.get("host") == key
|