mirror of
https://github.com/home-assistant/core.git
synced 2025-07-26 22:57:17 +00:00
Tests for ZWave climate (#6629)
But wait, there's more! Also a few fixes discovered writing the tests.
This commit is contained in:
parent
1a7ffdca52
commit
5e5d2e8ab8
@ -170,7 +170,6 @@ omit =
|
|||||||
homeassistant/components/climate/oem.py
|
homeassistant/components/climate/oem.py
|
||||||
homeassistant/components/climate/proliphix.py
|
homeassistant/components/climate/proliphix.py
|
||||||
homeassistant/components/climate/radiotherm.py
|
homeassistant/components/climate/radiotherm.py
|
||||||
homeassistant/components/climate/zwave.py
|
|
||||||
homeassistant/components/config/zwave.py
|
homeassistant/components/config/zwave.py
|
||||||
homeassistant/components/cover/garadget.py
|
homeassistant/components/cover/garadget.py
|
||||||
homeassistant/components/cover/homematic.py
|
homeassistant/components/cover/homematic.py
|
||||||
|
@ -126,11 +126,6 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
|||||||
if self.values.fan_state:
|
if self.values.fan_state:
|
||||||
self._fan_state = self.values.fan_state.data
|
self._fan_state = self.values.fan_state.data
|
||||||
|
|
||||||
@property
|
|
||||||
def should_poll(self):
|
|
||||||
"""No polling on Z-Wave."""
|
|
||||||
return False
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def current_fan_mode(self):
|
def current_fan_mode(self):
|
||||||
"""Return the fan speed set."""
|
"""Return the fan speed set."""
|
||||||
@ -189,7 +184,6 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
|||||||
return
|
return
|
||||||
|
|
||||||
self.values.primary.data = temperature
|
self.values.primary.data = temperature
|
||||||
self.schedule_update_ha_state()
|
|
||||||
|
|
||||||
def set_fan_mode(self, fan):
|
def set_fan_mode(self, fan):
|
||||||
"""Set new target fan mode."""
|
"""Set new target fan mode."""
|
||||||
@ -205,14 +199,15 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
|||||||
"""Set new target swing mode."""
|
"""Set new target swing mode."""
|
||||||
if self._zxt_120 == 1:
|
if self._zxt_120 == 1:
|
||||||
if self.values.zxt_120_swing_mode:
|
if self.values.zxt_120_swing_mode:
|
||||||
self.values.zxt_120_swing_mode = bytes(swing_mode, 'utf-8')
|
self.values.zxt_120_swing_mode.data = bytes(
|
||||||
|
swing_mode, 'utf-8')
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def device_state_attributes(self):
|
def device_state_attributes(self):
|
||||||
"""Return the device specific state attributes."""
|
"""Return the device specific state attributes."""
|
||||||
data = super().device_state_attributes
|
data = super().device_state_attributes
|
||||||
if self._operating_state:
|
if self._operating_state:
|
||||||
data[ATTR_OPERATING_STATE] = self._operating_state,
|
data[ATTR_OPERATING_STATE] = self._operating_state
|
||||||
if self._fan_state:
|
if self._fan_state:
|
||||||
data[ATTR_FAN_STATE] = self._fan_state
|
data[ATTR_FAN_STATE] = self._fan_state
|
||||||
return data
|
return data
|
||||||
|
163
tests/components/climate/test_zwave.py
Normal file
163
tests/components/climate/test_zwave.py
Normal file
@ -0,0 +1,163 @@
|
|||||||
|
"""Test Z-Wave climate devices."""
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
from homeassistant.components.climate import zwave
|
||||||
|
from homeassistant.const import (
|
||||||
|
TEMP_CELSIUS, TEMP_FAHRENHEIT, ATTR_TEMPERATURE)
|
||||||
|
|
||||||
|
from tests.mock.zwave import (
|
||||||
|
MockNode, MockValue, MockEntityValues, value_changed)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def device(hass, mock_openzwave):
|
||||||
|
"""Fixture to provide a precreated climate device."""
|
||||||
|
node = MockNode()
|
||||||
|
values = MockEntityValues(
|
||||||
|
primary=MockValue(data=1, node=node),
|
||||||
|
temperature=MockValue(data=5, node=node),
|
||||||
|
mode=MockValue(data=b'test1', data_items=[0, 1, 2], node=node),
|
||||||
|
fan_mode=MockValue(data=b'test2', data_items=[3, 4, 5], node=node),
|
||||||
|
operating_state=MockValue(data=6, node=node),
|
||||||
|
fan_state=MockValue(data=7, node=node),
|
||||||
|
)
|
||||||
|
device = zwave.get_device(hass, node=node, values=values, node_config={})
|
||||||
|
|
||||||
|
yield device
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def device_zxt_120(hass, mock_openzwave):
|
||||||
|
"""Fixture to provide a precreated climate device."""
|
||||||
|
node = MockNode(manufacturer_id='5254', product_id='8377')
|
||||||
|
values = MockEntityValues(
|
||||||
|
primary=MockValue(data=1, node=node),
|
||||||
|
temperature=MockValue(data=5, node=node),
|
||||||
|
mode=MockValue(data=b'test1', data_items=[0, 1, 2], node=node),
|
||||||
|
fan_mode=MockValue(data=b'test2', data_items=[3, 4, 5], node=node),
|
||||||
|
operating_state=MockValue(data=6, node=node),
|
||||||
|
fan_state=MockValue(data=7, node=node),
|
||||||
|
zxt_120_swing_mode=MockValue(
|
||||||
|
data=b'test3', data_items=[6, 7, 8], node=node),
|
||||||
|
)
|
||||||
|
device = zwave.get_device(hass, node=node, values=values, node_config={})
|
||||||
|
|
||||||
|
yield device
|
||||||
|
|
||||||
|
|
||||||
|
def test_zxt_120_swing_mode(device_zxt_120):
|
||||||
|
"""Test operation of the zxt 120 swing mode."""
|
||||||
|
device = device_zxt_120
|
||||||
|
|
||||||
|
assert device.swing_list == [6, 7, 8]
|
||||||
|
assert device._zxt_120 == 1
|
||||||
|
|
||||||
|
# Test set mode
|
||||||
|
assert device.values.zxt_120_swing_mode.data == b'test3'
|
||||||
|
device.set_swing_mode('test_swing_set')
|
||||||
|
assert device.values.zxt_120_swing_mode.data == b'test_swing_set'
|
||||||
|
|
||||||
|
# Test mode changed
|
||||||
|
value_changed(device.values.zxt_120_swing_mode)
|
||||||
|
assert device.current_swing_mode == b'test_swing_set'
|
||||||
|
device.values.zxt_120_swing_mode.data = b'test_swing_updated'
|
||||||
|
value_changed(device.values.zxt_120_swing_mode)
|
||||||
|
assert device.current_swing_mode == b'test_swing_updated'
|
||||||
|
|
||||||
|
|
||||||
|
def test_temperature_unit(device):
|
||||||
|
"""Test temperature unit."""
|
||||||
|
assert device.temperature_unit == TEMP_CELSIUS
|
||||||
|
device.values.temperature.units = 'F'
|
||||||
|
value_changed(device.values.temperature)
|
||||||
|
assert device.temperature_unit == TEMP_FAHRENHEIT
|
||||||
|
device.values.temperature.units = 'C'
|
||||||
|
value_changed(device.values.temperature)
|
||||||
|
assert device.temperature_unit == TEMP_CELSIUS
|
||||||
|
|
||||||
|
|
||||||
|
def test_default_target_temperature(device):
|
||||||
|
"""Test default setting of target temperature."""
|
||||||
|
assert device.target_temperature == 1
|
||||||
|
device.values.primary.data = 0
|
||||||
|
value_changed(device.values.primary)
|
||||||
|
assert device.target_temperature == 5 # Current Temperature
|
||||||
|
|
||||||
|
|
||||||
|
def test_data_lists(device):
|
||||||
|
"""Test data lists from zwave value items."""
|
||||||
|
assert device.fan_list == [3, 4, 5]
|
||||||
|
assert device.operation_list == [0, 1, 2]
|
||||||
|
|
||||||
|
|
||||||
|
def test_target_value_set(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.values.primary.data == 1
|
||||||
|
device.set_temperature()
|
||||||
|
assert device.values.primary.data == 1
|
||||||
|
device.set_temperature(**{
|
||||||
|
ATTR_TEMPERATURE: 2
|
||||||
|
})
|
||||||
|
assert device.values.primary.data == 2
|
||||||
|
|
||||||
|
|
||||||
|
def test_operation_value_set(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.values.mode.data == b'test1'
|
||||||
|
device.set_operation_mode('test_set')
|
||||||
|
assert device.values.mode.data == b'test_set'
|
||||||
|
|
||||||
|
|
||||||
|
def test_fan_mode_value_set(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.values.fan_mode.data == b'test2'
|
||||||
|
device.set_fan_mode('test_fan_set')
|
||||||
|
assert device.values.fan_mode.data == b'test_fan_set'
|
||||||
|
|
||||||
|
|
||||||
|
def test_target_value_changed(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.target_temperature == 1
|
||||||
|
device.values.primary.data = 2
|
||||||
|
value_changed(device.values.primary)
|
||||||
|
assert device.target_temperature == 2
|
||||||
|
|
||||||
|
|
||||||
|
def test_temperature_value_changed(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.current_temperature == 5
|
||||||
|
device.values.temperature.data = 3
|
||||||
|
value_changed(device.values.temperature)
|
||||||
|
assert device.current_temperature == 3
|
||||||
|
|
||||||
|
|
||||||
|
def test_operation_value_changed(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.current_operation == b'test1'
|
||||||
|
device.values.mode.data = b'test_updated'
|
||||||
|
value_changed(device.values.mode)
|
||||||
|
assert device.current_operation == b'test_updated'
|
||||||
|
|
||||||
|
|
||||||
|
def test_fan_mode_value_changed(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.current_fan_mode == b'test2'
|
||||||
|
device.values.fan_mode.data = b'test_updated_fan'
|
||||||
|
value_changed(device.values.fan_mode)
|
||||||
|
assert device.current_fan_mode == b'test_updated_fan'
|
||||||
|
|
||||||
|
|
||||||
|
def test_operating_state_value_changed(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.device_state_attributes[zwave.ATTR_OPERATING_STATE] == 6
|
||||||
|
device.values.operating_state.data = 8
|
||||||
|
value_changed(device.values.operating_state)
|
||||||
|
assert device.device_state_attributes[zwave.ATTR_OPERATING_STATE] == 8
|
||||||
|
|
||||||
|
|
||||||
|
def test_fan_state_value_changed(device):
|
||||||
|
"""Test values changed for climate device."""
|
||||||
|
assert device.device_state_attributes[zwave.ATTR_FAN_STATE] == 7
|
||||||
|
device.values.fan_state.data = 9
|
||||||
|
value_changed(device.values.fan_state)
|
||||||
|
assert device.device_state_attributes[zwave.ATTR_FAN_STATE] == 9
|
@ -52,19 +52,23 @@ class MockValue(MagicMock):
|
|||||||
def __init__(self, *,
|
def __init__(self, *,
|
||||||
label='Mock Value',
|
label='Mock Value',
|
||||||
data=None,
|
data=None,
|
||||||
|
data_items=None,
|
||||||
node=None,
|
node=None,
|
||||||
instance=0,
|
instance=0,
|
||||||
index=0,
|
index=0,
|
||||||
command_class=None,
|
command_class=None,
|
||||||
|
units=None,
|
||||||
value_id=None):
|
value_id=None):
|
||||||
"""Initialize a Z-Wave mock value."""
|
"""Initialize a Z-Wave mock value."""
|
||||||
super().__init__()
|
super().__init__()
|
||||||
self.label = label
|
self.label = label
|
||||||
self.data = data
|
self.data = data
|
||||||
|
self.data_items = data_items
|
||||||
self.node = node
|
self.node = node
|
||||||
self.instance = instance
|
self.instance = instance
|
||||||
self.index = 0
|
self.index = 0
|
||||||
self.command_class = command_class
|
self.command_class = command_class
|
||||||
|
self.units = units
|
||||||
if value_id is None:
|
if value_id is None:
|
||||||
MockValue._mock_value_id += 1
|
MockValue._mock_value_id += 1
|
||||||
value_id = MockValue._mock_value_id
|
value_id = MockValue._mock_value_id
|
||||||
|
Loading…
x
Reference in New Issue
Block a user