2020-03-11 16:37:02 +00:00
|
|
|
"""Tests for Plex server."""
|
|
|
|
import copy
|
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
from asynctest import ClockedTestCase, patch
|
2020-03-11 16:37:02 +00:00
|
|
|
|
|
|
|
from homeassistant.components.media_player import DOMAIN as MP_DOMAIN
|
|
|
|
from homeassistant.components.plex.const import (
|
|
|
|
CONF_IGNORE_NEW_SHARED_USERS,
|
|
|
|
CONF_MONITORED_USERS,
|
2020-04-04 05:34:42 +00:00
|
|
|
DEBOUNCE_TIMEOUT,
|
2020-03-11 16:37:02 +00:00
|
|
|
DOMAIN,
|
|
|
|
PLEX_UPDATE_PLATFORMS_SIGNAL,
|
|
|
|
SERVERS,
|
|
|
|
)
|
|
|
|
from homeassistant.helpers.dispatcher import async_dispatcher_send
|
|
|
|
|
|
|
|
from .const import DEFAULT_DATA, DEFAULT_OPTIONS
|
|
|
|
from .mock_classes import MockPlexServer
|
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
from tests.common import MockConfigEntry, async_test_home_assistant, mock_storage
|
2020-03-11 16:37:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_new_users_available(hass):
|
|
|
|
"""Test setting up when new users available on Plex server."""
|
|
|
|
|
|
|
|
MONITORED_USERS = {"Owner": {"enabled": True}}
|
|
|
|
OPTIONS_WITH_USERS = copy.deepcopy(DEFAULT_OPTIONS)
|
|
|
|
OPTIONS_WITH_USERS[MP_DOMAIN][CONF_MONITORED_USERS] = MONITORED_USERS
|
|
|
|
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=DEFAULT_DATA,
|
|
|
|
options=OPTIONS_WITH_USERS,
|
|
|
|
unique_id=DEFAULT_DATA["server_id"],
|
|
|
|
)
|
|
|
|
|
|
|
|
mock_plex_server = MockPlexServer(config_entry=entry)
|
|
|
|
|
|
|
|
with patch("plexapi.server.PlexServer", return_value=mock_plex_server), patch(
|
|
|
|
"homeassistant.components.plex.PlexWebsocket.listen"
|
|
|
|
):
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
assert await hass.config_entries.async_setup(entry.entry_id)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
server_id = mock_plex_server.machineIdentifier
|
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
async_dispatcher_send(hass, PLEX_UPDATE_PLATFORMS_SIGNAL.format(server_id))
|
|
|
|
await hass.async_block_till_done()
|
2020-03-11 16:37:02 +00:00
|
|
|
|
|
|
|
monitored_users = hass.data[DOMAIN][SERVERS][server_id].option_monitored_users
|
|
|
|
|
|
|
|
ignored_users = [x for x in monitored_users if not monitored_users[x]["enabled"]]
|
|
|
|
assert len(monitored_users) == 1
|
|
|
|
assert len(ignored_users) == 0
|
|
|
|
|
|
|
|
sensor = hass.states.get("sensor.plex_plex_server_1")
|
|
|
|
assert sensor.state == str(len(mock_plex_server.accounts))
|
|
|
|
|
|
|
|
|
|
|
|
async def test_new_ignored_users_available(hass, caplog):
|
|
|
|
"""Test setting up when new users available on Plex server but are ignored."""
|
|
|
|
|
|
|
|
MONITORED_USERS = {"Owner": {"enabled": True}}
|
|
|
|
OPTIONS_WITH_USERS = copy.deepcopy(DEFAULT_OPTIONS)
|
|
|
|
OPTIONS_WITH_USERS[MP_DOMAIN][CONF_MONITORED_USERS] = MONITORED_USERS
|
|
|
|
OPTIONS_WITH_USERS[MP_DOMAIN][CONF_IGNORE_NEW_SHARED_USERS] = True
|
|
|
|
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=DEFAULT_DATA,
|
|
|
|
options=OPTIONS_WITH_USERS,
|
|
|
|
unique_id=DEFAULT_DATA["server_id"],
|
|
|
|
)
|
|
|
|
|
|
|
|
mock_plex_server = MockPlexServer(config_entry=entry)
|
|
|
|
|
|
|
|
with patch("plexapi.server.PlexServer", return_value=mock_plex_server), patch(
|
|
|
|
"homeassistant.components.plex.PlexWebsocket.listen"
|
|
|
|
):
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
assert await hass.config_entries.async_setup(entry.entry_id)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
server_id = mock_plex_server.machineIdentifier
|
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
async_dispatcher_send(hass, PLEX_UPDATE_PLATFORMS_SIGNAL.format(server_id))
|
|
|
|
await hass.async_block_till_done()
|
2020-03-11 16:37:02 +00:00
|
|
|
|
|
|
|
monitored_users = hass.data[DOMAIN][SERVERS][server_id].option_monitored_users
|
|
|
|
|
|
|
|
ignored_users = [x for x in mock_plex_server.accounts if x not in monitored_users]
|
|
|
|
assert len(monitored_users) == 1
|
|
|
|
assert len(ignored_users) == 2
|
|
|
|
for ignored_user in ignored_users:
|
2020-04-05 06:21:20 +00:00
|
|
|
assert f"Ignoring Plex client owned by '{ignored_user}'" in caplog.text
|
2020-03-11 16:37:02 +00:00
|
|
|
|
|
|
|
sensor = hass.states.get("sensor.plex_plex_server_1")
|
|
|
|
assert sensor.state == str(len(mock_plex_server.accounts))
|
|
|
|
|
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
class TestClockedPlex(ClockedTestCase):
|
|
|
|
"""Create clock-controlled asynctest class."""
|
2020-03-11 16:37:02 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
async def setUp(self):
|
|
|
|
"""Initialize this test class."""
|
|
|
|
self.hass = await async_test_home_assistant(self.loop)
|
|
|
|
self.mock_storage = mock_storage()
|
|
|
|
self.mock_storage.__enter__()
|
2020-03-11 16:37:02 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
async def tearDown(self):
|
|
|
|
"""Clean up the HomeAssistant instance."""
|
|
|
|
await self.hass.async_stop()
|
|
|
|
self.mock_storage.__exit__(None, None, None)
|
2020-03-11 16:37:02 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
async def test_mark_sessions_idle(self):
|
|
|
|
"""Test marking media_players as idle when sessions end."""
|
|
|
|
hass = self.hass
|
2020-03-11 16:37:02 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=DEFAULT_DATA,
|
|
|
|
options=DEFAULT_OPTIONS,
|
|
|
|
unique_id=DEFAULT_DATA["server_id"],
|
|
|
|
)
|
2020-03-11 16:37:02 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
mock_plex_server = MockPlexServer(config_entry=entry)
|
2020-03-11 16:37:02 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
with patch("plexapi.server.PlexServer", return_value=mock_plex_server), patch(
|
|
|
|
"homeassistant.components.plex.PlexWebsocket.listen"
|
|
|
|
):
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
assert await hass.config_entries.async_setup(entry.entry_id)
|
|
|
|
await hass.async_block_till_done()
|
2020-03-11 16:37:02 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
server_id = mock_plex_server.machineIdentifier
|
2020-04-04 05:34:42 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
async_dispatcher_send(hass, PLEX_UPDATE_PLATFORMS_SIGNAL.format(server_id))
|
2020-04-04 05:34:42 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
sensor = hass.states.get("sensor.plex_plex_server_1")
|
|
|
|
assert sensor.state == str(len(mock_plex_server.accounts))
|
2020-04-04 05:34:42 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
mock_plex_server.clear_clients()
|
|
|
|
mock_plex_server.clear_sessions()
|
2020-04-04 05:34:42 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
await self.advance(DEBOUNCE_TIMEOUT)
|
|
|
|
async_dispatcher_send(hass, PLEX_UPDATE_PLATFORMS_SIGNAL.format(server_id))
|
|
|
|
await hass.async_block_till_done()
|
2020-04-04 05:34:42 +00:00
|
|
|
|
2020-04-09 22:49:09 +00:00
|
|
|
sensor = hass.states.get("sensor.plex_plex_server_1")
|
|
|
|
assert sensor.state == "0"
|
|
|
|
|
|
|
|
async def test_debouncer(self):
|
|
|
|
"""Test debouncer behavior."""
|
|
|
|
hass = self.hass
|
|
|
|
|
|
|
|
entry = MockConfigEntry(
|
|
|
|
domain=DOMAIN,
|
|
|
|
data=DEFAULT_DATA,
|
|
|
|
options=DEFAULT_OPTIONS,
|
|
|
|
unique_id=DEFAULT_DATA["server_id"],
|
|
|
|
)
|
|
|
|
|
|
|
|
mock_plex_server = MockPlexServer(config_entry=entry)
|
|
|
|
|
|
|
|
with patch("plexapi.server.PlexServer", return_value=mock_plex_server), patch(
|
|
|
|
"homeassistant.components.plex.PlexWebsocket.listen"
|
|
|
|
):
|
|
|
|
entry.add_to_hass(hass)
|
|
|
|
assert await hass.config_entries.async_setup(entry.entry_id)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
server_id = mock_plex_server.machineIdentifier
|
|
|
|
|
|
|
|
with patch.object(mock_plex_server, "clients", return_value=[]), patch.object(
|
|
|
|
mock_plex_server, "sessions", return_value=[]
|
|
|
|
) as mock_update:
|
|
|
|
# Called immediately
|
|
|
|
async_dispatcher_send(hass, PLEX_UPDATE_PLATFORMS_SIGNAL.format(server_id))
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_update.call_count == 1
|
|
|
|
|
|
|
|
# Throttled
|
|
|
|
async_dispatcher_send(hass, PLEX_UPDATE_PLATFORMS_SIGNAL.format(server_id))
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_update.call_count == 1
|
|
|
|
|
|
|
|
# Throttled
|
|
|
|
async_dispatcher_send(hass, PLEX_UPDATE_PLATFORMS_SIGNAL.format(server_id))
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_update.call_count == 1
|
|
|
|
|
|
|
|
# Called from scheduler
|
|
|
|
await self.advance(DEBOUNCE_TIMEOUT)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_update.call_count == 2
|
|
|
|
|
|
|
|
# Throttled
|
|
|
|
async_dispatcher_send(hass, PLEX_UPDATE_PLATFORMS_SIGNAL.format(server_id))
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_update.call_count == 2
|
|
|
|
|
|
|
|
# Called from scheduler
|
|
|
|
await self.advance(DEBOUNCE_TIMEOUT)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_update.call_count == 3
|