core/tests/components/tts/conftest.py

96 lines
2.8 KiB
Python
Raw Normal View History

2020-04-05 10:15:29 +00:00
"""Conftest for TTS tests.
From http://doc.pytest.org/en/latest/example/simple.html#making-test-result-information-available-in-fixtures
"""
2022-02-14 16:54:12 +00:00
from unittest.mock import patch
2020-04-05 10:15:29 +00:00
import pytest
2022-02-14 16:54:12 +00:00
from homeassistant.components.tts import _get_cache_files
from homeassistant.config import async_process_ha_core_config
from homeassistant.core import HomeAssistant
from .common import MockTTS
from tests.common import MockModule, mock_integration, mock_platform
2022-02-14 16:54:12 +00:00
2020-04-05 10:15:29 +00:00
@pytest.hookimpl(tryfirst=True, hookwrapper=True)
def pytest_runtest_makereport(item, call):
"""Add test report to node."""
# execute all other hooks to obtain the report object
outcome = yield
rep = outcome.get_result()
# set a report attribute for each phase of a call, which can
# be "setup", "call", "teardown"
2020-04-07 21:14:28 +00:00
setattr(item, f"rep_{rep.when}", rep)
2022-02-14 16:54:12 +00:00
@pytest.fixture(autouse=True)
def mock_get_cache_files():
"""Mock the list TTS cache function."""
with patch(
"homeassistant.components.tts._get_cache_files", return_value={}
) as mock_cache_files:
yield mock_cache_files
@pytest.fixture(autouse=True)
def mock_init_cache_dir():
"""Mock the TTS cache dir in memory."""
with patch(
"homeassistant.components.tts._init_tts_cache_dir",
side_effect=lambda hass, cache_dir: hass.config.path(cache_dir),
) as mock_cache_dir:
yield mock_cache_dir
@pytest.fixture
def empty_cache_dir(tmp_path, mock_init_cache_dir, mock_get_cache_files, request):
"""Mock the TTS cache dir with empty dir."""
mock_init_cache_dir.side_effect = None
mock_init_cache_dir.return_value = str(tmp_path)
# Restore original get cache files behavior, we're working with a real dir.
mock_get_cache_files.side_effect = _get_cache_files
yield tmp_path
if request.node.rep_call.passed:
return
# Print contents of dir if failed
print("Content of dir for", request.node.nodeid) # noqa: T201
2022-02-14 16:54:12 +00:00
for fil in tmp_path.iterdir():
print(fil.relative_to(tmp_path)) # noqa: T201
2022-02-14 16:54:12 +00:00
# To show the log.
2023-01-27 10:10:29 +00:00
pytest.fail("Test failed, see log for details")
2022-02-14 16:54:12 +00:00
@pytest.fixture(autouse=True)
def mutagen_mock():
"""Mock writing tags."""
with patch(
"homeassistant.components.tts.SpeechManager.write_tags",
side_effect=lambda *args: args[1],
) as mock_write_tags:
yield mock_write_tags
@pytest.fixture(autouse=True)
async def internal_url_mock(hass: HomeAssistant) -> None:
"""Mock internal URL of the instance."""
await async_process_ha_core_config(
hass,
{"internal_url": "http://example.local:8123"},
)
@pytest.fixture
async def mock_tts(hass: HomeAssistant) -> None:
"""Mock TTS."""
mock_integration(hass, MockModule(domain="test"))
mock_platform(hass, "test.tts", MockTTS())