mirror of https://github.com/home-assistant/core
187 lines
5.7 KiB
Python
187 lines
5.7 KiB
Python
"""Tests for Transmission init."""
|
|
|
|
from unittest.mock import MagicMock, patch
|
|
|
|
import pytest
|
|
from transmission_rpc.error import (
|
|
TransmissionAuthError,
|
|
TransmissionConnectError,
|
|
TransmissionError,
|
|
)
|
|
|
|
from homeassistant.components.sensor import DOMAIN as SENSOR_DOMAIN
|
|
from homeassistant.components.switch import DOMAIN as SWITCH_DOMAIN
|
|
from homeassistant.components.transmission.const import (
|
|
DEFAULT_PATH,
|
|
DEFAULT_SSL,
|
|
DOMAIN,
|
|
)
|
|
from homeassistant.config_entries import ConfigEntryState
|
|
from homeassistant.const import CONF_PATH, CONF_SSL
|
|
from homeassistant.core import HomeAssistant
|
|
from homeassistant.helpers import entity_registry as er
|
|
|
|
from . import MOCK_CONFIG_DATA, MOCK_CONFIG_DATA_VERSION_1_1, OLD_MOCK_CONFIG_DATA
|
|
|
|
from tests.common import MockConfigEntry
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
def mock_api():
|
|
"""Mock an api."""
|
|
with patch("transmission_rpc.Client") as api:
|
|
yield api
|
|
|
|
|
|
async def test_successful_config_entry(hass: HomeAssistant) -> None:
|
|
"""Test settings up integration from config entry."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_CONFIG_DATA)
|
|
entry.add_to_hass(hass)
|
|
|
|
await hass.config_entries.async_setup(entry.entry_id)
|
|
|
|
assert entry.state is ConfigEntryState.LOADED
|
|
|
|
|
|
async def test_config_flow_entry_migrate_1_1_to_1_2(hass: HomeAssistant) -> None:
|
|
"""Test that config flow entry is migrated correctly from v1.1 to v1.2."""
|
|
entry = MockConfigEntry(
|
|
domain=DOMAIN,
|
|
data=MOCK_CONFIG_DATA_VERSION_1_1,
|
|
version=1,
|
|
minor_version=1,
|
|
)
|
|
entry.add_to_hass(hass)
|
|
|
|
await hass.config_entries.async_setup(entry.entry_id)
|
|
await hass.async_block_till_done()
|
|
|
|
# Test that config entry is at the current version.
|
|
assert entry.version == 1
|
|
assert entry.minor_version == 2
|
|
|
|
assert entry.data[CONF_SSL] == DEFAULT_SSL
|
|
assert entry.data[CONF_PATH] == DEFAULT_PATH
|
|
|
|
|
|
async def test_setup_failed_connection_error(
|
|
hass: HomeAssistant, mock_api: MagicMock
|
|
) -> None:
|
|
"""Test integration failed due to connection error."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_CONFIG_DATA)
|
|
entry.add_to_hass(hass)
|
|
|
|
mock_api.side_effect = TransmissionConnectError()
|
|
|
|
await hass.config_entries.async_setup(entry.entry_id)
|
|
assert entry.state is ConfigEntryState.SETUP_RETRY
|
|
|
|
|
|
async def test_setup_failed_auth_error(
|
|
hass: HomeAssistant, mock_api: MagicMock
|
|
) -> None:
|
|
"""Test integration failed due to invalid credentials error."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_CONFIG_DATA)
|
|
entry.add_to_hass(hass)
|
|
|
|
mock_api.side_effect = TransmissionAuthError()
|
|
|
|
await hass.config_entries.async_setup(entry.entry_id)
|
|
assert entry.state is ConfigEntryState.SETUP_ERROR
|
|
|
|
|
|
async def test_setup_failed_unexpected_error(
|
|
hass: HomeAssistant, mock_api: MagicMock
|
|
) -> None:
|
|
"""Test integration failed due to unexpected error."""
|
|
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_CONFIG_DATA)
|
|
entry.add_to_hass(hass)
|
|
|
|
mock_api.side_effect = TransmissionError()
|
|
|
|
await hass.config_entries.async_setup(entry.entry_id)
|
|
assert entry.state is ConfigEntryState.SETUP_ERROR
|
|
|
|
|
|
async def test_unload_entry(hass: HomeAssistant) -> None:
|
|
"""Test removing integration."""
|
|
entry = MockConfigEntry(domain=DOMAIN, data=MOCK_CONFIG_DATA)
|
|
entry.add_to_hass(hass)
|
|
|
|
await hass.config_entries.async_setup(entry.entry_id)
|
|
await hass.async_block_till_done()
|
|
|
|
assert await hass.config_entries.async_unload(entry.entry_id)
|
|
await hass.async_block_till_done()
|
|
|
|
assert entry.state is ConfigEntryState.NOT_LOADED
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
("domain", "old_unique_id", "new_unique_id"),
|
|
[
|
|
(SENSOR_DOMAIN, "0.0.0.0-Transmission Down Speed", "1234-download"),
|
|
(SENSOR_DOMAIN, "0.0.0.0-Transmission Up Speed", "1234-upload"),
|
|
(SENSOR_DOMAIN, "0.0.0.0-Transmission Status", "1234-status"),
|
|
(
|
|
SENSOR_DOMAIN,
|
|
"0.0.0.0-Transmission Active Torrents",
|
|
"1234-active_torrents",
|
|
),
|
|
(
|
|
SENSOR_DOMAIN,
|
|
"0.0.0.0-Transmission Paused Torrents",
|
|
"1234-paused_torrents",
|
|
),
|
|
(SENSOR_DOMAIN, "0.0.0.0-Transmission Total Torrents", "1234-total_torrents"),
|
|
(
|
|
SENSOR_DOMAIN,
|
|
"0.0.0.0-Transmission Completed Torrents",
|
|
"1234-completed_torrents",
|
|
),
|
|
(
|
|
SENSOR_DOMAIN,
|
|
"0.0.0.0-Transmission Started Torrents",
|
|
"1234-started_torrents",
|
|
),
|
|
# no change on correct sensor unique id
|
|
(SENSOR_DOMAIN, "1234-started_torrents", "1234-started_torrents"),
|
|
(SWITCH_DOMAIN, "0.0.0.0-Transmission Switch", "1234-on_off"),
|
|
(SWITCH_DOMAIN, "0.0.0.0-Transmission Turtle Mode", "1234-turtle_mode"),
|
|
# no change on correct switch unique id
|
|
(SWITCH_DOMAIN, "1234-turtle_mode", "1234-turtle_mode"),
|
|
],
|
|
)
|
|
async def test_migrate_unique_id(
|
|
hass: HomeAssistant,
|
|
entity_registry: er.EntityRegistry,
|
|
domain: str,
|
|
old_unique_id: str,
|
|
new_unique_id: str,
|
|
) -> None:
|
|
"""Test unique id migration."""
|
|
entry = MockConfigEntry(domain=DOMAIN, data=OLD_MOCK_CONFIG_DATA, entry_id="1234")
|
|
entry.add_to_hass(hass)
|
|
|
|
entity: er.RegistryEntry = entity_registry.async_get_or_create(
|
|
suggested_object_id=f"my_{domain}",
|
|
disabled_by=None,
|
|
domain=domain,
|
|
platform=DOMAIN,
|
|
unique_id=old_unique_id,
|
|
config_entry=entry,
|
|
)
|
|
assert entity.unique_id == old_unique_id
|
|
|
|
await hass.config_entries.async_setup(entry.entry_id)
|
|
await hass.async_block_till_done()
|
|
|
|
migrated_entity = entity_registry.async_get(entity.entity_id)
|
|
|
|
assert migrated_entity
|
|
assert migrated_entity.unique_id == new_unique_id
|