mirror of
https://github.com/python-kasa/python-kasa.git
synced 2025-08-09 20:24:02 +00:00
Add common Thermostat module (#977)
This commit is contained in:
@@ -449,6 +449,17 @@ class FakeSmartTransport(BaseTransport):
|
||||
info["get_preset_rules"]["states"][params["index"]] = params["state"]
|
||||
return {"error_code": 0}
|
||||
|
||||
def _set_temperature_unit(self, info, params):
|
||||
"""Set or remove values as per the device behaviour."""
|
||||
unit = params["temp_unit"]
|
||||
if unit not in {"celsius", "fahrenheit"}:
|
||||
raise ValueError(f"Invalid value for temperature unit {unit}")
|
||||
if "temp_unit" not in info["get_device_info"]:
|
||||
return {"error_code": SmartErrorCode.UNKNOWN_METHOD_ERROR}
|
||||
else:
|
||||
info["get_device_info"]["temp_unit"] = unit
|
||||
return {"error_code": 0}
|
||||
|
||||
def _update_sysinfo_key(self, info: dict, key: str, value: str) -> dict:
|
||||
"""Update a single key in the main system info.
|
||||
|
||||
@@ -551,6 +562,8 @@ class FakeSmartTransport(BaseTransport):
|
||||
return self._set_preset_rules(info, params)
|
||||
elif method == "edit_preset_rules":
|
||||
return self._edit_preset_rules(info, params)
|
||||
elif method == "set_temperature_unit":
|
||||
return self._set_temperature_unit(info, params)
|
||||
elif method == "set_on_off_gradually_info":
|
||||
return self._set_on_off_gradually_info(info, params)
|
||||
elif method == "set_child_protection":
|
||||
|
@@ -4,7 +4,7 @@ from zoneinfo import ZoneInfo
|
||||
import pytest
|
||||
from pytest_mock import MockerFixture
|
||||
|
||||
from kasa import Device, LightState, Module
|
||||
from kasa import Device, LightState, Module, ThermostatState
|
||||
|
||||
from .device_fixtures import (
|
||||
bulb_iot,
|
||||
@@ -57,6 +57,12 @@ light_preset = parametrize_combine([light_preset_smart, bulb_iot])
|
||||
|
||||
light = parametrize_combine([bulb_smart, bulb_iot, dimmable])
|
||||
|
||||
temp_control_smart = parametrize(
|
||||
"has temp control smart",
|
||||
component_filter="temp_control",
|
||||
protocol_filter={"SMART.CHILD"},
|
||||
)
|
||||
|
||||
|
||||
@led
|
||||
async def test_led_module(dev: Device, mocker: MockerFixture):
|
||||
@@ -325,6 +331,39 @@ async def test_light_preset_save(dev: Device, mocker: MockerFixture):
|
||||
assert new_preset_state.color_temp == new_preset.color_temp
|
||||
|
||||
|
||||
@temp_control_smart
|
||||
async def test_thermostat(dev: Device, mocker: MockerFixture):
|
||||
"""Test saving a new preset value."""
|
||||
therm_mod = next(get_parent_and_child_modules(dev, Module.Thermostat))
|
||||
assert therm_mod
|
||||
|
||||
await therm_mod.set_state(False)
|
||||
await dev.update()
|
||||
assert therm_mod.state is False
|
||||
assert therm_mod.mode is ThermostatState.Off
|
||||
|
||||
await therm_mod.set_target_temperature(10)
|
||||
await dev.update()
|
||||
assert therm_mod.state is True
|
||||
assert therm_mod.mode is ThermostatState.Heating
|
||||
assert therm_mod.target_temperature == 10
|
||||
|
||||
target_temperature_feature = therm_mod.get_feature(therm_mod.set_target_temperature)
|
||||
temp_control = dev.modules.get(Module.TemperatureControl)
|
||||
assert temp_control
|
||||
allowed_range = temp_control.allowed_temperature_range
|
||||
assert target_temperature_feature.minimum_value == allowed_range[0]
|
||||
assert target_temperature_feature.maximum_value == allowed_range[1]
|
||||
|
||||
await therm_mod.set_temperature_unit("celsius")
|
||||
await dev.update()
|
||||
assert therm_mod.temperature_unit == "celsius"
|
||||
|
||||
await therm_mod.set_temperature_unit("fahrenheit")
|
||||
await dev.update()
|
||||
assert therm_mod.temperature_unit == "fahrenheit"
|
||||
|
||||
|
||||
async def test_set_time(dev: Device):
|
||||
"""Test setting the device time."""
|
||||
time_mod = dev.modules[Module.Time]
|
||||
|
Reference in New Issue
Block a user