core/tests/components/recorder/test_backup.py

63 lines
2.0 KiB
Python

"""Test backup platform for the Recorder integration."""
from unittest.mock import patch
import pytest
from homeassistant.components.recorder import Recorder
from homeassistant.components.recorder.backup import async_post_backup, async_pre_backup
from homeassistant.core import HomeAssistant
from homeassistant.exceptions import HomeAssistantError
async def test_async_pre_backup(recorder_mock: Recorder, hass: HomeAssistant) -> None:
"""Test pre backup."""
with patch(
"homeassistant.components.recorder.core.Recorder.lock_database"
) as lock_mock:
await async_pre_backup(hass)
assert lock_mock.called
async def test_async_pre_backup_with_timeout(
recorder_mock: Recorder, hass: HomeAssistant
) -> None:
"""Test pre backup with timeout."""
with patch(
"homeassistant.components.recorder.core.Recorder.lock_database",
side_effect=TimeoutError(),
) as lock_mock, pytest.raises(TimeoutError):
await async_pre_backup(hass)
assert lock_mock.called
async def test_async_pre_backup_with_migration(
recorder_mock: Recorder, hass: HomeAssistant
) -> None:
"""Test pre backup with migration."""
with patch(
"homeassistant.components.recorder.backup.async_migration_in_progress",
return_value=True,
), pytest.raises(HomeAssistantError):
await async_pre_backup(hass)
async def test_async_post_backup(recorder_mock: Recorder, hass: HomeAssistant) -> None:
"""Test post backup."""
with patch(
"homeassistant.components.recorder.core.Recorder.unlock_database"
) as unlock_mock:
await async_post_backup(hass)
assert unlock_mock.called
async def test_async_post_backup_failure(
recorder_mock: Recorder, hass: HomeAssistant
) -> None:
"""Test post backup failure."""
with patch(
"homeassistant.components.recorder.core.Recorder.unlock_database",
return_value=False,
) as unlock_mock, pytest.raises(HomeAssistantError):
await async_post_backup(hass)
assert unlock_mock.called