Add type hints to feature set_value (#974)

To prevent untyped call mypy errors in consumers
This commit is contained in:
Steven B 2024-06-12 20:58:21 +01:00 committed by GitHub
parent 7f24408c32
commit 4cf395483f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -10,7 +10,6 @@ from typing import TYPE_CHECKING, Any, Callable
if TYPE_CHECKING: if TYPE_CHECKING:
from .device import Device from .device import Device
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@ -140,22 +139,24 @@ class Feature:
raise ValueError("Not an action and no attribute_getter set") raise ValueError("Not an action and no attribute_getter set")
container = self.container if self.container is not None else self.device container = self.container if self.container is not None else self.device
if isinstance(self.attribute_getter, Callable): if callable(self.attribute_getter):
return self.attribute_getter(container) return self.attribute_getter(container)
return getattr(container, self.attribute_getter) return getattr(container, self.attribute_getter)
async def set_value(self, value): async def set_value(self, value: int | float | bool | str | Enum | None) -> Any:
"""Set the value.""" """Set the value."""
if self.attribute_setter is None: if self.attribute_setter is None:
raise ValueError("Tried to set read-only feature.") raise ValueError("Tried to set read-only feature.")
if self.type == Feature.Type.Number: # noqa: SIM102 if self.type == Feature.Type.Number: # noqa: SIM102
if not isinstance(value, (int, float)):
raise ValueError("value must be a number")
if value < self.minimum_value or value > self.maximum_value: if value < self.minimum_value or value > self.maximum_value:
raise ValueError( raise ValueError(
f"Value {value} out of range " f"Value {value} out of range "
f"[{self.minimum_value}, {self.maximum_value}]" f"[{self.minimum_value}, {self.maximum_value}]"
) )
elif self.type == Feature.Type.Choice: # noqa: SIM102 elif self.type == Feature.Type.Choice: # noqa: SIM102
if value not in self.choices: if not self.choices or value not in self.choices:
raise ValueError( raise ValueError(
f"Unexpected value for {self.name}: {value}" f"Unexpected value for {self.name}: {value}"
f" - allowed: {self.choices}" f" - allowed: {self.choices}"