2021-01-20 13:44:24 +00:00
|
|
|
"""Test fixtures for the stream component.
|
|
|
|
|
|
|
|
The tests encode stream (as an h264 video), then load the stream and verify
|
|
|
|
that it is decoded properly. The background worker thread responsible for
|
|
|
|
decoding will decode the stream as fast as possible, and when completed
|
|
|
|
clears all output buffers. This can be a problem for the test that wishes
|
|
|
|
to retrieve and verify decoded segments. If the worker finishes first, there is
|
|
|
|
nothing for the test to verify. The solution is the WorkerSync class that
|
|
|
|
allows the tests to pause the worker thread before finalizing the stream
|
|
|
|
so that it can inspect the output.
|
|
|
|
"""
|
|
|
|
import logging
|
|
|
|
import threading
|
|
|
|
from unittest.mock import patch
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2021-02-08 15:19:41 +00:00
|
|
|
from homeassistant.components.stream import Stream
|
2021-01-20 13:44:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
class WorkerSync:
|
|
|
|
"""Test fixture that intercepts stream worker calls to StreamOutput."""
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
"""Initialize WorkerSync."""
|
|
|
|
self._event = None
|
2021-02-08 15:19:41 +00:00
|
|
|
self._original = Stream._worker_finished
|
2021-01-20 13:44:24 +00:00
|
|
|
|
|
|
|
def pause(self):
|
|
|
|
"""Pause the worker before it finalizes the stream."""
|
|
|
|
self._event = threading.Event()
|
|
|
|
|
|
|
|
def resume(self):
|
|
|
|
"""Allow the worker thread to finalize the stream."""
|
|
|
|
self._event.set()
|
|
|
|
|
2021-02-08 15:19:41 +00:00
|
|
|
def blocking_finish(self, stream: Stream):
|
|
|
|
"""Intercept call to pause stream worker."""
|
|
|
|
# Worker is ending the stream, which clears all output buffers.
|
|
|
|
# Block the worker thread until the test has a chance to verify
|
|
|
|
# the segments under test.
|
|
|
|
logging.debug("blocking worker")
|
2021-02-10 05:59:49 +00:00
|
|
|
if self._event:
|
|
|
|
self._event.wait()
|
2021-01-20 13:44:24 +00:00
|
|
|
|
2021-02-08 15:19:41 +00:00
|
|
|
# Forward to actual implementation
|
|
|
|
self._original(stream)
|
2021-01-20 13:44:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture()
|
|
|
|
def stream_worker_sync(hass):
|
|
|
|
"""Patch StreamOutput to allow test to synchronize worker stream end."""
|
|
|
|
sync = WorkerSync()
|
|
|
|
with patch(
|
2021-02-08 15:19:41 +00:00
|
|
|
"homeassistant.components.stream.Stream._worker_finished",
|
|
|
|
side_effect=sync.blocking_finish,
|
2021-01-20 13:44:24 +00:00
|
|
|
autospec=True,
|
|
|
|
):
|
|
|
|
yield sync
|