Coverage for src / bluetooth_sig / gatt / descriptors / process_tolerances.py: 73%
22 statements
« prev ^ index » next coverage.py v7.13.5, created at 2026-03-18 11:17 +0000
« prev ^ index » next coverage.py v7.13.5, created at 2026-03-18 11:17 +0000
1"""Process Tolerances Descriptor implementation."""
3from __future__ import annotations
5import msgspec
7from ..characteristics.utils import DataParser
8from .base import BaseDescriptor
11class ProcessTolerancesData(msgspec.Struct, frozen=True, kw_only=True):
12 """Process Tolerances descriptor data."""
14 tolerance_min: int | float
15 tolerance_max: int | float
18class ProcessTolerancesDescriptor(BaseDescriptor):
19 """Process Tolerances Descriptor (0x2914).
21 Defines process tolerances for characteristic values.
22 Contains minimum and maximum tolerance values.
23 """
25 def _has_structured_data(self) -> bool:
26 return True
28 def _get_data_format(self) -> str:
29 return "struct"
31 def _parse_descriptor_value(self, data: bytes) -> ProcessTolerancesData:
32 """Parse Process Tolerances descriptor value.
34 The format depends on the characteristic's value type.
35 For simplicity, this implementation assumes uint16 tolerance values.
37 Args:
38 data: Raw bytes containing tolerance min and max values
40 Returns:
41 ProcessTolerancesData with process tolerances
43 Raises:
44 ValueError: If data length is incorrect
45 """
46 # Process Tolerances format: tolerance_min + tolerance_max
47 # For now, assume 4 bytes total (2 bytes each for uint16)
49 tolerance_min = DataParser.parse_int16(data, offset=0, endian="little")
50 tolerance_max = DataParser.parse_int16(data, offset=2, endian="little")
52 return ProcessTolerancesData(
53 tolerance_min=tolerance_min,
54 tolerance_max=tolerance_max,
55 )
57 def get_tolerance_min(self, data: bytes) -> int | float:
58 """Get the minimum process tolerance."""
59 parsed = self._parse_descriptor_value(data)
60 return parsed.tolerance_min
62 def get_tolerance_max(self, data: bytes) -> int | float:
63 """Get the maximum process tolerance."""
64 parsed = self._parse_descriptor_value(data)
65 return parsed.tolerance_max