From 9fdf123a2fa290f7d39f7f6564e327ffb415f1e7 Mon Sep 17 00:00:00 2001 From: Alexei Chetroi Date: Fri, 21 Sep 2018 06:11:23 -0400 Subject: [PATCH] Zha switch schedule update state (#16621) * switch.zha: Schedule state update. if turning switch On or Off operation was successful, then schedule state update * switch.zha: Update debug logging. --- homeassistant/components/switch/zha.py | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/homeassistant/components/switch/zha.py b/homeassistant/components/switch/zha.py index 4fde35653482cb..68a94cc1ca514c 100644 --- a/homeassistant/components/switch/zha.py +++ b/homeassistant/components/switch/zha.py @@ -44,7 +44,10 @@ class Switch(zha.Entity, SwitchDevice): def attribute_updated(self, attribute, value): """Handle attribute update from device.""" - _LOGGER.debug("Attribute updated: %s %s %s", self, attribute, value) + cluster = self._endpoint.on_off + attr_name = cluster.attributes.get(attribute, [attribute])[0] + _LOGGER.debug("%s: Attribute '%s' on cluster '%s' updated to %s", + self.entity_id, attr_name, cluster.ep_attribute, value) if attribute == self.value_attribute: self._state = value self.async_schedule_update_ha_state() @@ -65,23 +68,29 @@ async def async_turn_on(self, **kwargs): """Turn the entity on.""" from zigpy.exceptions import DeliveryError try: - await self._endpoint.on_off.on() + res = await self._endpoint.on_off.on() + _LOGGER.debug("%s: turned 'on': %s", self.entity_id, res[1]) except DeliveryError as ex: - _LOGGER.error("Unable to turn the switch on: %s", ex) + _LOGGER.error("%s: Unable to turn the switch on: %s", + self.entity_id, ex) return self._state = 1 + self.async_schedule_update_ha_state() async def async_turn_off(self, **kwargs): """Turn the entity off.""" from zigpy.exceptions import DeliveryError try: - await self._endpoint.on_off.off() + res = await self._endpoint.on_off.off() + _LOGGER.debug("%s: turned 'off': %s", self.entity_id, res[1]) except DeliveryError as ex: - _LOGGER.error("Unable to turn the switch off: %s", ex) + _LOGGER.error("%s: Unable to turn the switch off: %s", + self.entity_id, ex) return self._state = 0 + self.async_schedule_update_ha_state() async def async_update(self): """Retrieve latest state."""