mirror of
https://github.com/python-kasa/python-kasa.git
synced 2025-01-22 04:37:06 +00:00
Add childlock module for vacuums (#1461)
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
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
Add new configuration feature: ``` Child lock (child_lock): False ``` --------- Co-authored-by: Steven B. <51370195+sdb9696@users.noreply.github.com>
This commit is contained in:
parent
773801cad5
commit
980f6a38ca
@ -448,7 +448,7 @@ COMPONENT_REQUESTS = {
|
|||||||
"battery": [SmartRequest.get_raw_request("getBatteryInfo")],
|
"battery": [SmartRequest.get_raw_request("getBatteryInfo")],
|
||||||
"consumables": [SmartRequest.get_raw_request("getConsumablesInfo")],
|
"consumables": [SmartRequest.get_raw_request("getConsumablesInfo")],
|
||||||
"direction_control": [],
|
"direction_control": [],
|
||||||
"button_and_led": [],
|
"button_and_led": [SmartRequest.get_raw_request("getChildLockInfo")],
|
||||||
"speaker": [
|
"speaker": [
|
||||||
SmartRequest.get_raw_request("getSupportVoiceLanguage"),
|
SmartRequest.get_raw_request("getSupportVoiceLanguage"),
|
||||||
SmartRequest.get_raw_request("getCurrentVoiceLanguage"),
|
SmartRequest.get_raw_request("getCurrentVoiceLanguage"),
|
||||||
|
@ -152,6 +152,7 @@ class Module(ABC):
|
|||||||
ChildProtection: Final[ModuleName[smart.ChildProtection]] = ModuleName(
|
ChildProtection: Final[ModuleName[smart.ChildProtection]] = ModuleName(
|
||||||
"ChildProtection"
|
"ChildProtection"
|
||||||
)
|
)
|
||||||
|
ChildLock: Final[ModuleName[smart.ChildLock]] = ModuleName("ChildLock")
|
||||||
TriggerLogs: Final[ModuleName[smart.TriggerLogs]] = ModuleName("TriggerLogs")
|
TriggerLogs: Final[ModuleName[smart.TriggerLogs]] = ModuleName("TriggerLogs")
|
||||||
|
|
||||||
HomeKit: Final[ModuleName[smart.HomeKit]] = ModuleName("HomeKit")
|
HomeKit: Final[ModuleName[smart.HomeKit]] = ModuleName("HomeKit")
|
||||||
|
@ -6,6 +6,7 @@ from .autooff import AutoOff
|
|||||||
from .batterysensor import BatterySensor
|
from .batterysensor import BatterySensor
|
||||||
from .brightness import Brightness
|
from .brightness import Brightness
|
||||||
from .childdevice import ChildDevice
|
from .childdevice import ChildDevice
|
||||||
|
from .childlock import ChildLock
|
||||||
from .childprotection import ChildProtection
|
from .childprotection import ChildProtection
|
||||||
from .clean import Clean
|
from .clean import Clean
|
||||||
from .cloud import Cloud
|
from .cloud import Cloud
|
||||||
@ -45,6 +46,7 @@ __all__ = [
|
|||||||
"Energy",
|
"Energy",
|
||||||
"DeviceModule",
|
"DeviceModule",
|
||||||
"ChildDevice",
|
"ChildDevice",
|
||||||
|
"ChildLock",
|
||||||
"BatterySensor",
|
"BatterySensor",
|
||||||
"HumiditySensor",
|
"HumiditySensor",
|
||||||
"TemperatureSensor",
|
"TemperatureSensor",
|
||||||
|
37
kasa/smart/modules/childlock.py
Normal file
37
kasa/smart/modules/childlock.py
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
"""Child lock module."""
|
||||||
|
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from ...feature import Feature
|
||||||
|
from ..smartmodule import SmartModule
|
||||||
|
|
||||||
|
|
||||||
|
class ChildLock(SmartModule):
|
||||||
|
"""Implementation for child lock."""
|
||||||
|
|
||||||
|
REQUIRED_COMPONENT = "button_and_led"
|
||||||
|
QUERY_GETTER_NAME = "getChildLockInfo"
|
||||||
|
|
||||||
|
def _initialize_features(self) -> None:
|
||||||
|
"""Initialize features after the initial update."""
|
||||||
|
self._add_feature(
|
||||||
|
Feature(
|
||||||
|
device=self._device,
|
||||||
|
id="child_lock",
|
||||||
|
name="Child lock",
|
||||||
|
container=self,
|
||||||
|
attribute_getter="enabled",
|
||||||
|
attribute_setter="set_enabled",
|
||||||
|
type=Feature.Type.Switch,
|
||||||
|
category=Feature.Category.Config,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def enabled(self) -> bool:
|
||||||
|
"""Return True if child lock is enabled."""
|
||||||
|
return self.data["child_lock_status"]
|
||||||
|
|
||||||
|
async def set_enabled(self, enabled: bool) -> dict:
|
||||||
|
"""Set child lock."""
|
||||||
|
return await self.call("setChildLockInfo", {"child_lock_status": enabled})
|
@ -165,6 +165,9 @@
|
|||||||
"getCarpetClean": {
|
"getCarpetClean": {
|
||||||
"carpet_clean_prefer": "boost"
|
"carpet_clean_prefer": "boost"
|
||||||
},
|
},
|
||||||
|
"getChildLockInfo": {
|
||||||
|
"child_lock_status": false
|
||||||
|
},
|
||||||
"getCleanAttr": {
|
"getCleanAttr": {
|
||||||
"cistern": 2,
|
"cistern": 2,
|
||||||
"clean_number": 1,
|
"clean_number": 1,
|
||||||
|
44
tests/smart/modules/test_childlock.py
Normal file
44
tests/smart/modules/test_childlock.py
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import pytest
|
||||||
|
|
||||||
|
from kasa import Module
|
||||||
|
from kasa.smart.modules import ChildLock
|
||||||
|
|
||||||
|
from ...device_fixtures import parametrize
|
||||||
|
|
||||||
|
childlock = parametrize(
|
||||||
|
"has child lock",
|
||||||
|
component_filter="button_and_led",
|
||||||
|
protocol_filter={"SMART"},
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@childlock
|
||||||
|
@pytest.mark.parametrize(
|
||||||
|
("feature", "prop_name", "type"),
|
||||||
|
[
|
||||||
|
("child_lock", "enabled", bool),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
async def test_features(dev, feature, prop_name, type):
|
||||||
|
"""Test that features are registered and work as expected."""
|
||||||
|
protect: ChildLock = dev.modules[Module.ChildLock]
|
||||||
|
assert protect is not None
|
||||||
|
|
||||||
|
prop = getattr(protect, prop_name)
|
||||||
|
assert isinstance(prop, type)
|
||||||
|
|
||||||
|
feat = protect._device.features[feature]
|
||||||
|
assert feat.value == prop
|
||||||
|
assert isinstance(feat.value, type)
|
||||||
|
|
||||||
|
|
||||||
|
@childlock
|
||||||
|
async def test_enabled(dev):
|
||||||
|
"""Test the API."""
|
||||||
|
protect: ChildLock = dev.modules[Module.ChildLock]
|
||||||
|
assert protect is not None
|
||||||
|
|
||||||
|
assert isinstance(protect.enabled, bool)
|
||||||
|
await protect.set_enabled(False)
|
||||||
|
await dev.update()
|
||||||
|
assert protect.enabled is False
|
Loading…
Reference in New Issue
Block a user