2016-11-16 05:56:40 +00:00
|
|
|
"""The tests for the Yamaha Media player platform."""
|
2021-01-01 21:31:56 +00:00
|
|
|
from unittest.mock import MagicMock, PropertyMock, call, patch
|
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
import pytest
|
2018-01-17 18:34:21 +00:00
|
|
|
|
|
|
|
import homeassistant.components.media_player as mp
|
2019-03-19 06:07:39 +00:00
|
|
|
from homeassistant.components.yamaha import media_player as yamaha
|
2020-06-08 17:31:58 +00:00
|
|
|
from homeassistant.components.yamaha.const import DOMAIN
|
|
|
|
from homeassistant.helpers.discovery import async_load_platform
|
|
|
|
from homeassistant.setup import async_setup_component
|
2019-12-09 13:57:42 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
CONFIG = {"media_player": {"platform": "yamaha", "host": "127.0.0.1"}}
|
2018-01-17 18:34:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
def _create_zone_mock(name, url):
|
|
|
|
zone = MagicMock()
|
|
|
|
zone.ctrl_url = url
|
|
|
|
zone.zone = name
|
|
|
|
return zone
|
|
|
|
|
|
|
|
|
2018-07-20 08:45:20 +00:00
|
|
|
class FakeYamahaDevice:
|
2018-01-17 18:34:21 +00:00
|
|
|
"""A fake Yamaha device."""
|
|
|
|
|
|
|
|
def __init__(self, ctrl_url, name, zones=None):
|
|
|
|
"""Initialize the fake Yamaha device."""
|
|
|
|
self.ctrl_url = ctrl_url
|
|
|
|
self.name = name
|
2020-06-08 17:31:58 +00:00
|
|
|
self._zones = zones or []
|
2018-01-17 18:34:21 +00:00
|
|
|
|
|
|
|
def zone_controllers(self):
|
|
|
|
"""Return controllers for all available zones."""
|
2020-06-08 17:31:58 +00:00
|
|
|
return self._zones
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(name="main_zone")
|
|
|
|
def main_zone_fixture():
|
|
|
|
"""Mock the main zone."""
|
|
|
|
return _create_zone_mock("Main zone", "http://main")
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(name="device")
|
|
|
|
def device_fixture(main_zone):
|
|
|
|
"""Mock the yamaha device."""
|
|
|
|
device = FakeYamahaDevice("http://receiver", "Receiver", zones=[main_zone])
|
|
|
|
with patch("rxv.RXV", return_value=device):
|
|
|
|
yield device
|
|
|
|
|
|
|
|
|
|
|
|
async def test_setup_host(hass, device, main_zone):
|
|
|
|
"""Test set up integration with host."""
|
|
|
|
assert await async_setup_component(hass, mp.DOMAIN, CONFIG)
|
|
|
|
await hass.async_block_till_done()
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
state = hass.states.get("media_player.yamaha_receiver_main_zone")
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
assert state is not None
|
|
|
|
assert state.state == "off"
|
2016-11-16 05:56:40 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
|
|
|
|
async def test_setup_no_host(hass, device, main_zone):
|
|
|
|
"""Test set up integration without host."""
|
|
|
|
with patch("rxv.find", return_value=[device]):
|
|
|
|
assert await async_setup_component(
|
|
|
|
hass, mp.DOMAIN, {"media_player": {"platform": "yamaha"}}
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2020-06-08 17:31:58 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
state = hass.states.get("media_player.yamaha_receiver_main_zone")
|
|
|
|
|
|
|
|
assert state is not None
|
|
|
|
assert state.state == "off"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_setup_discovery(hass, device, main_zone):
|
|
|
|
"""Test set up integration via discovery."""
|
|
|
|
discovery_info = {
|
|
|
|
"name": "Yamaha Receiver",
|
|
|
|
"model_name": "Yamaha",
|
|
|
|
"control_url": "http://receiver",
|
|
|
|
"description_url": "http://receiver/description",
|
|
|
|
}
|
|
|
|
await async_load_platform(
|
|
|
|
hass, mp.DOMAIN, "yamaha", discovery_info, {mp.DOMAIN: {}}
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
state = hass.states.get("media_player.yamaha_receiver_main_zone")
|
|
|
|
|
|
|
|
assert state is not None
|
|
|
|
assert state.state == "off"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_setup_zone_ignore(hass, device, main_zone):
|
|
|
|
"""Test set up integration without host."""
|
|
|
|
assert await async_setup_component(
|
|
|
|
hass,
|
|
|
|
mp.DOMAIN,
|
|
|
|
{
|
|
|
|
"media_player": {
|
|
|
|
"platform": "yamaha",
|
|
|
|
"host": "127.0.0.1",
|
|
|
|
"zone_ignore": "Main zone",
|
|
|
|
}
|
|
|
|
},
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
state = hass.states.get("media_player.yamaha_receiver_main_zone")
|
|
|
|
|
|
|
|
assert state is None
|
|
|
|
|
|
|
|
|
|
|
|
async def test_enable_output(hass, device, main_zone):
|
|
|
|
"""Test enable output service."""
|
|
|
|
assert await async_setup_component(hass, mp.DOMAIN, CONFIG)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
port = "hdmi1"
|
|
|
|
enabled = True
|
|
|
|
data = {
|
|
|
|
"entity_id": "media_player.yamaha_receiver_main_zone",
|
|
|
|
"port": port,
|
|
|
|
"enabled": enabled,
|
|
|
|
}
|
|
|
|
|
|
|
|
await hass.services.async_call(DOMAIN, yamaha.SERVICE_ENABLE_OUTPUT, data, True)
|
|
|
|
|
|
|
|
assert main_zone.enable_output.call_count == 1
|
|
|
|
assert main_zone.enable_output.call_args == call(port, enabled)
|
|
|
|
|
|
|
|
|
2021-06-15 17:17:10 +00:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"cursor,method",
|
|
|
|
[
|
|
|
|
(yamaha.CURSOR_TYPE_DOWN, "menu_down"),
|
|
|
|
(yamaha.CURSOR_TYPE_LEFT, "menu_left"),
|
|
|
|
(yamaha.CURSOR_TYPE_RETURN, "menu_return"),
|
|
|
|
(yamaha.CURSOR_TYPE_RIGHT, "menu_right"),
|
|
|
|
(yamaha.CURSOR_TYPE_SELECT, "menu_sel"),
|
|
|
|
(yamaha.CURSOR_TYPE_UP, "menu_up"),
|
|
|
|
],
|
|
|
|
)
|
|
|
|
@pytest.mark.usefixtures("device")
|
|
|
|
async def test_menu_cursor(hass, main_zone, cursor, method):
|
|
|
|
"""Verify that the correct menu method is called for the menu_cursor service."""
|
|
|
|
assert await async_setup_component(hass, mp.DOMAIN, CONFIG)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
data = {
|
|
|
|
"entity_id": "media_player.yamaha_receiver_main_zone",
|
|
|
|
"cursor": cursor,
|
|
|
|
}
|
|
|
|
await hass.services.async_call(DOMAIN, yamaha.SERVICE_MENU_CURSOR, data, True)
|
|
|
|
|
|
|
|
getattr(main_zone, method).assert_called_once_with()
|
|
|
|
|
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
async def test_select_scene(hass, device, main_zone, caplog):
|
|
|
|
"""Test select scene service."""
|
|
|
|
scene_prop = PropertyMock(return_value=None)
|
|
|
|
type(main_zone).scene = scene_prop
|
|
|
|
|
|
|
|
assert await async_setup_component(hass, mp.DOMAIN, CONFIG)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
scene = "TV Viewing"
|
|
|
|
data = {
|
|
|
|
"entity_id": "media_player.yamaha_receiver_main_zone",
|
|
|
|
"scene": scene,
|
|
|
|
}
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
await hass.services.async_call(DOMAIN, yamaha.SERVICE_SELECT_SCENE, data, True)
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
assert scene_prop.call_count == 1
|
|
|
|
assert scene_prop.call_args == call(scene)
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
scene = "BD/DVD Movie Viewing"
|
|
|
|
data["scene"] = scene
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
await hass.services.async_call(DOMAIN, yamaha.SERVICE_SELECT_SCENE, data, True)
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
assert scene_prop.call_count == 2
|
|
|
|
assert scene_prop.call_args == call(scene)
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
scene_prop.side_effect = AssertionError()
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
missing_scene = "Missing scene"
|
|
|
|
data["scene"] = missing_scene
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
await hass.services.async_call(DOMAIN, yamaha.SERVICE_SELECT_SCENE, data, True)
|
2018-01-17 18:34:21 +00:00
|
|
|
|
2020-06-08 17:31:58 +00:00
|
|
|
assert f"Scene '{missing_scene}' does not exist!" in caplog.text
|