1
0
mirror of https://github.com/home-assistant/core.git synced 2026-05-08 17:49:37 +01:00

Use a config entry migration instead of migrating in async_setup in Ping (#155403)

Co-authored-by: Robert Resch <robert@resch.dev>
This commit is contained in:
Jan-Philipp Benecke
2025-10-29 11:19:23 +01:00
committed by GitHub
parent 67baa2c737
commit d9d4cc9004
3 changed files with 26 additions and 13 deletions
+22 -13
View File
@@ -23,6 +23,28 @@ PLATFORMS = [Platform.BINARY_SENSOR, Platform.DEVICE_TRACKER, Platform.SENSOR]
DATA_PRIVILEGED_KEY: HassKey[bool | None] = HassKey(DOMAIN)
async def async_migrate_entry(hass: HomeAssistant, entry: PingConfigEntry) -> bool:
"""Migrate old config entries."""
if entry.version == 1 and entry.minor_version == 1:
_LOGGER.debug("Migrating to minor version 2")
# Migrate device registry identifiers from homeassistant domain to ping domain
registry = dr.async_get(hass)
if (
device := registry.async_get_device(
identifiers={(HOMEASSISTANT_DOMAIN, entry.entry_id)}
)
) is not None and entry.entry_id in device.config_entries:
registry.async_update_device(
device_id=device.id,
new_identifiers={(DOMAIN, entry.entry_id)},
)
hass.config_entries.async_update_entry(entry, minor_version=2)
return True
async def async_setup(hass: HomeAssistant, config: ConfigType) -> bool:
"""Set up the ping integration."""
hass.data[DATA_PRIVILEGED_KEY] = await _can_use_icmp_lib_with_privilege()
@@ -32,19 +54,6 @@ async def async_setup(hass: HomeAssistant, config: ConfigType) -> bool:
async def async_setup_entry(hass: HomeAssistant, entry: PingConfigEntry) -> bool:
"""Set up Ping (ICMP) from a config entry."""
# Migrate device registry identifiers from homeassistant domain to ping domain
registry = dr.async_get(hass)
if (
device := registry.async_get_device(
identifiers={(HOMEASSISTANT_DOMAIN, entry.entry_id)}
)
) is not None and entry.entry_id in device.config_entries:
registry.async_update_device(
device_id=device.id,
new_identifiers={(DOMAIN, entry.entry_id)},
)
privileged = hass.data[DATA_PRIVILEGED_KEY]
host: str = entry.options[CONF_HOST]
@@ -37,6 +37,7 @@ class PingConfigFlow(ConfigFlow, domain=DOMAIN):
"""Handle a config flow for Ping."""
VERSION = 1
MINOR_VERSION = 2
async def async_step_user(
self, user_input: dict[str, Any] | None = None
+3
View File
@@ -33,6 +33,8 @@ async def test_device_migration(
identifiers={(HOMEASSISTANT_DOMAIN, config_entry.entry_id)},
)
assert config_entry.minor_version == 1
await hass.config_entries.async_setup(config_entry.entry_id)
await hass.async_block_till_done()
@@ -44,3 +46,4 @@ async def test_device_migration(
assert device is not None
assert device.id == old_device.id
assert device.config_entries == {config_entry.entry_id}
assert config_entry.minor_version == 2