Add logic to avoid creating the same scene multiple times (#65207)

pull/65222/head
Robert Svensson 2022-01-30 00:11:28 +01:00 committed by GitHub
parent 3ca1b2fc6e
commit 30440cd1ba
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 39 additions and 2 deletions

View File

@ -7,7 +7,7 @@ from typing import Any
from pydeconz.group import DeconzScene as PydeconzScene from pydeconz.group import DeconzScene as PydeconzScene
from homeassistant.components.scene import Scene from homeassistant.components.scene import DOMAIN, Scene
from homeassistant.config_entries import ConfigEntry from homeassistant.config_entries import ConfigEntry
from homeassistant.core import HomeAssistant, callback from homeassistant.core import HomeAssistant, callback
from homeassistant.helpers.dispatcher import async_dispatcher_connect from homeassistant.helpers.dispatcher import async_dispatcher_connect
@ -23,6 +23,7 @@ async def async_setup_entry(
) -> None: ) -> None:
"""Set up scenes for deCONZ component.""" """Set up scenes for deCONZ component."""
gateway = get_gateway_from_config_entry(hass, config_entry) gateway = get_gateway_from_config_entry(hass, config_entry)
gateway.entities[DOMAIN] = set()
@callback @callback
def async_add_scene( def async_add_scene(
@ -30,7 +31,11 @@ async def async_setup_entry(
| ValuesView[PydeconzScene] = gateway.api.scenes.values(), | ValuesView[PydeconzScene] = gateway.api.scenes.values(),
) -> None: ) -> None:
"""Add scene from deCONZ.""" """Add scene from deCONZ."""
entities = [DeconzScene(scene, gateway) for scene in scenes] entities = [
DeconzScene(scene, gateway)
for scene in scenes
if scene.deconz_id not in gateway.entities[DOMAIN]
]
if entities: if entities:
async_add_entities(entities) async_add_entities(entities)
@ -59,10 +64,12 @@ class DeconzScene(Scene):
async def async_added_to_hass(self) -> None: async def async_added_to_hass(self) -> None:
"""Subscribe to sensors events.""" """Subscribe to sensors events."""
self.gateway.deconz_ids[self.entity_id] = self._scene.deconz_id self.gateway.deconz_ids[self.entity_id] = self._scene.deconz_id
self.gateway.entities[DOMAIN].add(self._scene.deconz_id)
async def async_will_remove_from_hass(self) -> None: async def async_will_remove_from_hass(self) -> None:
"""Disconnect scene object when removed.""" """Disconnect scene object when removed."""
del self.gateway.deconz_ids[self.entity_id] del self.gateway.deconz_ids[self.entity_id]
self.gateway.entities[DOMAIN].remove(self._scene.deconz_id)
self._scene = None self._scene = None
async def async_activate(self, **kwargs: Any) -> None: async def async_activate(self, **kwargs: Any) -> None:

View File

@ -55,6 +55,7 @@ async def test_entry_diagnostics(
str(Platform.LIGHT): [], str(Platform.LIGHT): [],
str(Platform.LOCK): [], str(Platform.LOCK): [],
str(Platform.NUMBER): [], str(Platform.NUMBER): [],
str(Platform.SCENE): [],
str(Platform.SENSOR): [], str(Platform.SENSOR): [],
str(Platform.SIREN): [], str(Platform.SIREN): [],
str(Platform.SWITCH): [], str(Platform.SWITCH): [],

View File

@ -2,8 +2,10 @@
from unittest.mock import patch from unittest.mock import patch
from homeassistant.components.deconz.gateway import get_gateway_from_config_entry
from homeassistant.components.scene import DOMAIN as SCENE_DOMAIN, SERVICE_TURN_ON from homeassistant.components.scene import DOMAIN as SCENE_DOMAIN, SERVICE_TURN_ON
from homeassistant.const import ATTR_ENTITY_ID from homeassistant.const import ATTR_ENTITY_ID
from homeassistant.helpers.dispatcher import async_dispatcher_send
from .test_gateway import ( from .test_gateway import (
DECONZ_WEB_REQUEST, DECONZ_WEB_REQUEST,
@ -58,3 +60,30 @@ async def test_scenes(hass, aioclient_mock):
await hass.config_entries.async_unload(config_entry.entry_id) await hass.config_entries.async_unload(config_entry.entry_id)
assert len(hass.states.async_all()) == 0 assert len(hass.states.async_all()) == 0
async def test_only_new_scenes_are_created(hass, aioclient_mock):
"""Test that scenes works."""
data = {
"groups": {
"1": {
"id": "Light group id",
"name": "Light group",
"type": "LightGroup",
"state": {"all_on": False, "any_on": True},
"action": {},
"scenes": [{"id": "1", "name": "Scene"}],
"lights": [],
}
}
}
with patch.dict(DECONZ_WEB_REQUEST, data):
config_entry = await setup_deconz_integration(hass, aioclient_mock)
assert len(hass.states.async_all()) == 1
gateway = get_gateway_from_config_entry(hass, config_entry)
async_dispatcher_send(hass, gateway.signal_new_scene)
await hass.async_block_till_done()
assert len(hass.states.async_all()) == 1