mirror of
https://github.com/home-assistant/core.git
synced 2025-07-16 09:47:13 +00:00
Add async_remove_config_entry_device support to nexia (#73966)
Co-authored-by: Paulus Schoutsen <balloob@gmail.com>
This commit is contained in:
parent
e67f8720e8
commit
15ed329108
@ -5,11 +5,13 @@ import logging
|
|||||||
import aiohttp
|
import aiohttp
|
||||||
from nexia.const import BRAND_NEXIA
|
from nexia.const import BRAND_NEXIA
|
||||||
from nexia.home import NexiaHome
|
from nexia.home import NexiaHome
|
||||||
|
from nexia.thermostat import NexiaThermostat
|
||||||
|
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
|
from homeassistant.const import CONF_PASSWORD, CONF_USERNAME
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.exceptions import ConfigEntryNotReady
|
from homeassistant.exceptions import ConfigEntryNotReady
|
||||||
|
from homeassistant.helpers import device_registry as dr
|
||||||
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
||||||
import homeassistant.helpers.config_validation as cv
|
import homeassistant.helpers.config_validation as cv
|
||||||
|
|
||||||
@ -66,8 +68,23 @@ async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
|||||||
|
|
||||||
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
async def async_unload_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
||||||
"""Unload a config entry."""
|
"""Unload a config entry."""
|
||||||
unload_ok = await hass.config_entries.async_unload_platforms(entry, PLATFORMS)
|
if unload_ok := await hass.config_entries.async_unload_platforms(entry, PLATFORMS):
|
||||||
if unload_ok:
|
|
||||||
hass.data[DOMAIN].pop(entry.entry_id)
|
hass.data[DOMAIN].pop(entry.entry_id)
|
||||||
|
|
||||||
return unload_ok
|
return unload_ok
|
||||||
|
|
||||||
|
|
||||||
|
async def async_remove_config_entry_device(
|
||||||
|
hass: HomeAssistant, config_entry: ConfigEntry, device_entry: dr.DeviceEntry
|
||||||
|
) -> bool:
|
||||||
|
"""Remove a nexia config entry from a device."""
|
||||||
|
coordinator: NexiaDataUpdateCoordinator = hass.data[DOMAIN][config_entry.entry_id]
|
||||||
|
nexia_home: NexiaHome = coordinator.nexia_home
|
||||||
|
dev_ids = {dev_id[1] for dev_id in device_entry.identifiers if dev_id[0] == DOMAIN}
|
||||||
|
for thermostat_id in nexia_home.get_thermostat_ids():
|
||||||
|
if thermostat_id in dev_ids:
|
||||||
|
return False
|
||||||
|
thermostat: NexiaThermostat = nexia_home.get_thermostat_by_id(thermostat_id)
|
||||||
|
for zone_id in thermostat.get_zone_ids():
|
||||||
|
if zone_id in dev_ids:
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
60
tests/components/nexia/test_init.py
Normal file
60
tests/components/nexia/test_init.py
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
"""The init tests for the nexia platform."""
|
||||||
|
|
||||||
|
|
||||||
|
from homeassistant.components.nexia.const import DOMAIN
|
||||||
|
from homeassistant.helpers import device_registry as dr, entity_registry as er
|
||||||
|
from homeassistant.helpers.entity_registry import EntityRegistry
|
||||||
|
from homeassistant.setup import async_setup_component
|
||||||
|
|
||||||
|
from .util import async_init_integration
|
||||||
|
|
||||||
|
|
||||||
|
async def remove_device(ws_client, device_id, config_entry_id):
|
||||||
|
"""Remove config entry from a device."""
|
||||||
|
await ws_client.send_json(
|
||||||
|
{
|
||||||
|
"id": 5,
|
||||||
|
"type": "config/device_registry/remove_config_entry",
|
||||||
|
"config_entry_id": config_entry_id,
|
||||||
|
"device_id": device_id,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
response = await ws_client.receive_json()
|
||||||
|
return response["success"]
|
||||||
|
|
||||||
|
|
||||||
|
async def test_device_remove_devices(hass, hass_ws_client):
|
||||||
|
"""Test we can only remove a device that no longer exists."""
|
||||||
|
await async_setup_component(hass, "config", {})
|
||||||
|
config_entry = await async_init_integration(hass)
|
||||||
|
entry_id = config_entry.entry_id
|
||||||
|
device_registry = dr.async_get(hass)
|
||||||
|
|
||||||
|
registry: EntityRegistry = er.async_get(hass)
|
||||||
|
entity = registry.entities["sensor.nick_office_temperature"]
|
||||||
|
|
||||||
|
live_zone_device_entry = device_registry.async_get(entity.device_id)
|
||||||
|
assert (
|
||||||
|
await remove_device(
|
||||||
|
await hass_ws_client(hass), live_zone_device_entry.id, entry_id
|
||||||
|
)
|
||||||
|
is False
|
||||||
|
)
|
||||||
|
|
||||||
|
entity = registry.entities["sensor.master_suite_relative_humidity"]
|
||||||
|
live_thermostat_device_entry = device_registry.async_get(entity.device_id)
|
||||||
|
assert (
|
||||||
|
await remove_device(
|
||||||
|
await hass_ws_client(hass), live_thermostat_device_entry.id, entry_id
|
||||||
|
)
|
||||||
|
is False
|
||||||
|
)
|
||||||
|
|
||||||
|
dead_device_entry = device_registry.async_get_or_create(
|
||||||
|
config_entry_id=config_entry.entry_id,
|
||||||
|
identifiers={(DOMAIN, "unused")},
|
||||||
|
)
|
||||||
|
assert (
|
||||||
|
await remove_device(await hass_ws_client(hass), dead_device_entry.id, entry_id)
|
||||||
|
is True
|
||||||
|
)
|
Loading…
x
Reference in New Issue
Block a user