Fix iot strip turn on and off from parent (#639)
Some checks are pending
CI / Perform linting checks (3.13) (push) Waiting to run
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, macos-latest, 3.11) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, macos-latest, 3.12) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, macos-latest, 3.13) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, ubuntu-latest, 3.11) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, ubuntu-latest, 3.12) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, ubuntu-latest, 3.13) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, windows-latest, 3.11) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, windows-latest, 3.12) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (false, windows-latest, 3.13) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (true, ubuntu-latest, 3.11) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (true, ubuntu-latest, 3.12) (push) Blocked by required conditions
CI / Python ${{ matrix.python-version}} on ${{ matrix.os }}${{ fromJSON('[" (extras)", ""]')[matrix.extras == ''] }} (true, ubuntu-latest, 3.13) (push) Blocked by required conditions
CodeQL checks / Analyze (python) (push) Waiting to run

Co-authored-by: Steven B <51370195+sdb9696@users.noreply.github.com>
This commit is contained in:
Nathan Wreggit 2025-01-23 07:05:38 -08:00 committed by GitHub
parent b6a584971a
commit b701441215
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 15 additions and 8 deletions

View File

@ -161,11 +161,17 @@ class IotStrip(IotDevice):
async def turn_on(self, **kwargs) -> dict: async def turn_on(self, **kwargs) -> dict:
"""Turn the strip on.""" """Turn the strip on."""
return await self._query_helper("system", "set_relay_state", {"state": 1}) for plug in self.children:
if plug.is_off:
await plug.turn_on()
return {}
async def turn_off(self, **kwargs) -> dict: async def turn_off(self, **kwargs) -> dict:
"""Turn the strip off.""" """Turn the strip off."""
return await self._query_helper("system", "set_relay_state", {"state": 0}) for plug in self.children:
if plug.is_on:
await plug.turn_off()
return {}
@property # type: ignore @property # type: ignore
@requires_update @requires_update

View File

@ -308,10 +308,6 @@ class FakeIotTransport(BaseTransport):
child_ids = [] child_ids = []
_LOGGER.debug("Setting relay state to %s", x["state"]) _LOGGER.debug("Setting relay state to %s", x["state"])
if not child_ids and "children" in self.proto["system"]["get_sysinfo"]:
for child in self.proto["system"]["get_sysinfo"]["children"]:
child_ids.append(child["id"])
_LOGGER.info("child_ids: %s", child_ids) _LOGGER.info("child_ids: %s", child_ids)
if child_ids: if child_ids:
for child in self.proto["system"]["get_sysinfo"]["children"]: for child in self.proto["system"]["get_sysinfo"]["children"]:

View File

@ -137,8 +137,9 @@ async def test_query_helper(dev):
@device_iot @device_iot
@turn_on @turn_on
async def test_state(dev, turn_on): async def test_state(dev, turn_on):
await handle_turn_on(dev, turn_on)
orig_state = dev.is_on orig_state = dev.is_on
await handle_turn_on(dev, turn_on)
await dev.update()
if orig_state: if orig_state:
await dev.turn_off() await dev.turn_off()
await dev.update() await dev.update()

View File

@ -5,6 +5,7 @@ import pytest
from pytest_mock import MockerFixture from pytest_mock import MockerFixture
from kasa import Device, Feature, KasaException from kasa import Device, Feature, KasaException
from kasa.iot import IotStrip
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@ -168,7 +169,10 @@ async def test_feature_setters(dev: Device, mocker: MockerFixture):
if feat.attribute_setter is None: if feat.attribute_setter is None:
return return
expecting_call = feat.id not in internal_setters # IotStrip makes calls via it's children
expecting_call = feat.id not in internal_setters and not isinstance(
dev, IotStrip
)
if feat.type == Feature.Type.Number: if feat.type == Feature.Type.Number:
await feat.set_value(feat.minimum_value) await feat.set_value(feat.minimum_value)