Better checking of child modules not supported by parent device (#966)

Replaces the logic to skip adding child modules to parent devices based
on whether a device is a wall switch and instead relies on the
`_check_supported` method. Is more future proof and will fix issue with
the P300 with child `auto_off` modules
https://github.com/python-kasa/python-kasa/pull/915 not supported on the
parent.
This commit is contained in:
Steven B 2024-06-10 14:13:46 +01:00 committed by GitHub
parent 9e74e1bd40
commit 927fe648ac
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 10 additions and 4 deletions

View File

@ -140,3 +140,13 @@ class LightPreset(SmartModule, LightPresetInterface):
if self._state_in_sysinfo: # Child lights can have states in the child info if self._state_in_sysinfo: # Child lights can have states in the child info
return {} return {}
return {self.QUERY_GETTER_NAME: None} return {self.QUERY_GETTER_NAME: None}
async def _check_supported(self):
"""Additional check to see if the module is supported by the device.
Parent devices that report components of children such as ks240 will not have
the brightness value is sysinfo.
"""
# Look in _device.sys_info here because self.data is either sys_info or
# get_preset_rules depending on whether it's a child device or not.
return "brightness" in self._device.sys_info

View File

@ -202,10 +202,6 @@ class SmartDevice(Device):
child_modules_to_skip = {} child_modules_to_skip = {}
if self._parent and self._parent.device_type != DeviceType.Hub: if self._parent and self._parent.device_type != DeviceType.Hub:
skip_parent_only_modules = True skip_parent_only_modules = True
elif self._children and self.device_type == DeviceType.WallSwitch:
# _initialize_modules is called on the parent after the children
for child in self._children.values():
child_modules_to_skip.update(**child.modules)
for mod in SmartModule.REGISTERED_MODULES.values(): for mod in SmartModule.REGISTERED_MODULES.values():
_LOGGER.debug("%s requires %s", mod, mod.REQUIRED_COMPONENT) _LOGGER.debug("%s requires %s", mod, mod.REQUIRED_COMPONENT)