* Dont remove api key during migration * Fix return * Fix test * Make lambda more readable * Move fixtures to init, move migration test to test_init.py * Refactor config_entry data assignment * Refactor system_bridge migration tests * Fix type for debug message * Fix type for debug message * Remove duplicated unused code (rebase error) * Refactor test_migration_minor_2_to_1 to test_migration_minor_future_to_2 * Fix version check in async_migrate_entry * Update migration logic to handle future minor version * Add ConfigEntryState assertion in test_init.py * Change condition to minor_version < 2 Co-authored-by: Martin Hjelmare <marhje52@gmail.com> * Refactor system bridge migration tests * Remove minor downgrade code * Update tests/components/system_bridge/test_init.py Co-authored-by: Martin Hjelmare <marhje52@gmail.com> * Update tests/components/system_bridge/test_init.py Co-authored-by: Martin Hjelmare <marhje52@gmail.com> * Apply suggestions from code review Co-authored-by: Martin Hjelmare <marhje52@gmail.com> * Move dataclass to store requested data to data.py * Use dataclass in config flow * Move media player and sensor onto data.py dataclass * Move data and handler inside validate --------- Co-authored-by: Martin Hjelmare <marhje52@gmail.com>
83 lines
3 KiB
Python
83 lines
3 KiB
Python
"""Test the System Bridge integration."""
|
|
|
|
from unittest.mock import patch
|
|
|
|
from homeassistant.components.system_bridge.config_flow import SystemBridgeConfigFlow
|
|
from homeassistant.components.system_bridge.const import DOMAIN
|
|
from homeassistant.config_entries import ConfigEntryState
|
|
from homeassistant.const import CONF_API_KEY, CONF_HOST, CONF_PORT, CONF_TOKEN
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
from . import FIXTURE_USER_INPUT, FIXTURE_UUID
|
|
|
|
from tests.common import MockConfigEntry
|
|
|
|
|
|
async def test_migration_minor_1_to_2(hass: HomeAssistant) -> None:
|
|
"""Test migration."""
|
|
config_entry = MockConfigEntry(
|
|
domain=DOMAIN,
|
|
unique_id=FIXTURE_UUID,
|
|
data={
|
|
CONF_API_KEY: FIXTURE_USER_INPUT[CONF_TOKEN],
|
|
CONF_HOST: FIXTURE_USER_INPUT[CONF_HOST],
|
|
CONF_PORT: FIXTURE_USER_INPUT[CONF_PORT],
|
|
},
|
|
version=SystemBridgeConfigFlow.VERSION,
|
|
minor_version=1,
|
|
)
|
|
|
|
with patch(
|
|
"homeassistant.components.system_bridge.async_setup_entry",
|
|
return_value=True,
|
|
) as mock_setup_entry:
|
|
config_entry.add_to_hass(hass)
|
|
await hass.config_entries.async_setup(config_entry.entry_id)
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
# Check that the version has been updated and the api_key has been moved to token
|
|
assert config_entry.version == SystemBridgeConfigFlow.VERSION
|
|
assert config_entry.minor_version == SystemBridgeConfigFlow.MINOR_VERSION
|
|
assert config_entry.data == {
|
|
CONF_API_KEY: FIXTURE_USER_INPUT[CONF_TOKEN],
|
|
CONF_HOST: FIXTURE_USER_INPUT[CONF_HOST],
|
|
CONF_PORT: FIXTURE_USER_INPUT[CONF_PORT],
|
|
CONF_TOKEN: FIXTURE_USER_INPUT[CONF_TOKEN],
|
|
}
|
|
assert config_entry.state == ConfigEntryState.LOADED
|
|
|
|
|
|
async def test_migration_minor_future_version(hass: HomeAssistant) -> None:
|
|
"""Test migration."""
|
|
config_entry_data = {
|
|
CONF_API_KEY: FIXTURE_USER_INPUT[CONF_TOKEN],
|
|
CONF_HOST: FIXTURE_USER_INPUT[CONF_HOST],
|
|
CONF_PORT: FIXTURE_USER_INPUT[CONF_PORT],
|
|
CONF_TOKEN: FIXTURE_USER_INPUT[CONF_TOKEN],
|
|
}
|
|
config_entry_version = SystemBridgeConfigFlow.VERSION
|
|
config_entry_minor_version = SystemBridgeConfigFlow.MINOR_VERSION + 1
|
|
config_entry = MockConfigEntry(
|
|
domain=DOMAIN,
|
|
unique_id=FIXTURE_UUID,
|
|
data=config_entry_data,
|
|
version=config_entry_version,
|
|
minor_version=config_entry_minor_version,
|
|
)
|
|
|
|
with patch(
|
|
"homeassistant.components.system_bridge.async_setup_entry",
|
|
return_value=True,
|
|
) as mock_setup_entry:
|
|
config_entry.add_to_hass(hass)
|
|
await hass.config_entries.async_setup(config_entry.entry_id)
|
|
await hass.async_block_till_done()
|
|
|
|
assert len(mock_setup_entry.mock_calls) == 1
|
|
|
|
assert config_entry.version == config_entry_version
|
|
assert config_entry.minor_version == config_entry_minor_version
|
|
assert config_entry.data == config_entry_data
|
|
assert config_entry.state == ConfigEntryState.LOADED
|