mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 13:17:32 +00:00
Feature zwave preset modes (#25537)
* Initial commit * Add some more code * Local tests passing * Remove unnecessary line * Add preset attributes to __init__ * Remove some more debugger lines * Add some tests * Fix comparision to None * Improve test coverage * Use unknown modes as presets * Bugfixes and test improvements * Add tests for unknown preset modes * linting * Improve mappings * Move PRESET_MANUFACTURER_SPECIFIC to zwave * Replace isinstance with cast * Add test for hvac_action * hvac_mode is never None * Improved mapping of current mode to hvac/preset modes * Fix bugs where hvac_mode is None * Add default hvac mode * Fixed default hvac mode * Fix linting * Make flake happy * Another linting * Make black happy * Complete list of default hvac modes * Add mapping to heat/cool eco * Fixed another bug where mapping goes wrong
This commit is contained in:
parent
7ee3dd137b
commit
944cd70753
@ -10,15 +10,19 @@ from homeassistant.components.climate.const import (
|
||||
CURRENT_HVAC_IDLE,
|
||||
CURRENT_HVAC_OFF,
|
||||
DOMAIN,
|
||||
HVAC_MODE_AUTO,
|
||||
HVAC_MODE_COOL,
|
||||
HVAC_MODE_HEAT,
|
||||
HVAC_MODE_HEAT_COOL,
|
||||
HVAC_MODE_DRY,
|
||||
HVAC_MODE_FAN_ONLY,
|
||||
HVAC_MODE_OFF,
|
||||
PRESET_BOOST,
|
||||
PRESET_NONE,
|
||||
SUPPORT_FAN_MODE,
|
||||
SUPPORT_SWING_MODE,
|
||||
SUPPORT_TARGET_TEMPERATURE,
|
||||
SUPPORT_PRESET_MODE,
|
||||
)
|
||||
from homeassistant.const import ATTR_TEMPERATURE, TEMP_CELSIUS, TEMP_FAHRENHEIT
|
||||
from homeassistant.core import callback
|
||||
@ -37,38 +41,57 @@ REMOTEC_ZXT_120_THERMOSTAT = (REMOTEC, REMOTEC_ZXT_120)
|
||||
ATTR_OPERATING_STATE = "operating_state"
|
||||
ATTR_FAN_STATE = "fan_state"
|
||||
|
||||
|
||||
# Device is in manufacturer specific mode (e.g. setting the valve manually)
|
||||
PRESET_MANUFACTURER_SPECIFIC = "Manufacturer Specific"
|
||||
|
||||
WORKAROUND_ZXT_120 = "zxt_120"
|
||||
|
||||
DEVICE_MAPPINGS = {REMOTEC_ZXT_120_THERMOSTAT: WORKAROUND_ZXT_120}
|
||||
|
||||
HVAC_STATE_MAPPINGS = {
|
||||
"Off": HVAC_MODE_OFF,
|
||||
"Heat": HVAC_MODE_HEAT,
|
||||
"Heat Mode": HVAC_MODE_HEAT,
|
||||
"Heat (Default)": HVAC_MODE_HEAT,
|
||||
"Aux Heat": HVAC_MODE_HEAT,
|
||||
"Furnace": HVAC_MODE_HEAT,
|
||||
"Fan Only": HVAC_MODE_FAN_ONLY,
|
||||
"Dry Air": HVAC_MODE_DRY,
|
||||
"Moist Air": HVAC_MODE_DRY,
|
||||
"Cool": HVAC_MODE_COOL,
|
||||
"Auto": HVAC_MODE_HEAT_COOL,
|
||||
"off": HVAC_MODE_OFF,
|
||||
"heat": HVAC_MODE_HEAT,
|
||||
"heat mode": HVAC_MODE_HEAT,
|
||||
"heat (default)": HVAC_MODE_HEAT,
|
||||
"aux heat": HVAC_MODE_HEAT,
|
||||
"furnace": HVAC_MODE_HEAT,
|
||||
"fan only": HVAC_MODE_FAN_ONLY,
|
||||
"dry air": HVAC_MODE_DRY,
|
||||
"moist air": HVAC_MODE_DRY,
|
||||
"cool": HVAC_MODE_COOL,
|
||||
"heat_cool": HVAC_MODE_HEAT_COOL,
|
||||
"auto": HVAC_MODE_HEAT_COOL,
|
||||
}
|
||||
|
||||
|
||||
HVAC_CURRENT_MAPPINGS = {
|
||||
"Idle": CURRENT_HVAC_IDLE,
|
||||
"Heat": CURRENT_HVAC_HEAT,
|
||||
"Pending Heat": CURRENT_HVAC_IDLE,
|
||||
"Heating": CURRENT_HVAC_HEAT,
|
||||
"Cool": CURRENT_HVAC_COOL,
|
||||
"Pending Cool": CURRENT_HVAC_IDLE,
|
||||
"Cooling": CURRENT_HVAC_COOL,
|
||||
"Fan Only": CURRENT_HVAC_FAN,
|
||||
"Vent / Economiser": CURRENT_HVAC_FAN,
|
||||
"Off": CURRENT_HVAC_OFF,
|
||||
"idle": CURRENT_HVAC_IDLE,
|
||||
"heat": CURRENT_HVAC_HEAT,
|
||||
"pending heat": CURRENT_HVAC_IDLE,
|
||||
"heating": CURRENT_HVAC_HEAT,
|
||||
"cool": CURRENT_HVAC_COOL,
|
||||
"pending cool": CURRENT_HVAC_IDLE,
|
||||
"cooling": CURRENT_HVAC_COOL,
|
||||
"fan only": CURRENT_HVAC_FAN,
|
||||
"vent / economiser": CURRENT_HVAC_FAN,
|
||||
"off": CURRENT_HVAC_OFF,
|
||||
}
|
||||
|
||||
PRESET_MAPPINGS = {
|
||||
"full power": PRESET_BOOST,
|
||||
"manufacturer specific": PRESET_MANUFACTURER_SPECIFIC,
|
||||
}
|
||||
|
||||
DEFAULT_HVAC_MODES = [
|
||||
HVAC_MODE_HEAT_COOL,
|
||||
HVAC_MODE_HEAT,
|
||||
HVAC_MODE_COOL,
|
||||
HVAC_MODE_FAN_ONLY,
|
||||
HVAC_MODE_DRY,
|
||||
HVAC_MODE_OFF,
|
||||
HVAC_MODE_AUTO,
|
||||
]
|
||||
|
||||
|
||||
async def async_setup_platform(hass, config, async_add_entities, discovery_info=None):
|
||||
"""Old method of setting up Z-Wave climate devices."""
|
||||
@ -101,9 +124,13 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
||||
self._target_temperature = None
|
||||
self._current_temperature = None
|
||||
self._hvac_action = None
|
||||
self._hvac_list = None
|
||||
self._hvac_mapping = None
|
||||
self._hvac_mode = None
|
||||
self._hvac_list = None # [zwave_mode]
|
||||
self._hvac_mapping = None # {ha_mode:zwave_mode}
|
||||
self._hvac_mode = None # ha_mode
|
||||
self._default_hvac_mode = None # ha_mode
|
||||
self._preset_mapping = None # {ha_mode:zwave_mode}
|
||||
self._preset_list = None # [zwave_mode]
|
||||
self._preset_mode = None # ha_mode if exists, else zwave_mode
|
||||
self._current_fan_mode = None
|
||||
self._fan_modes = None
|
||||
self._fan_state = None
|
||||
@ -132,6 +159,8 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
||||
support |= SUPPORT_FAN_MODE
|
||||
if self._zxt_120 == 1 and self.values.zxt_120_swing_mode:
|
||||
support |= SUPPORT_SWING_MODE
|
||||
if self._preset_list:
|
||||
support |= SUPPORT_PRESET_MODE
|
||||
return support
|
||||
|
||||
def update_properties(self):
|
||||
@ -140,26 +169,86 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
||||
if self.values.mode:
|
||||
self._hvac_list = []
|
||||
self._hvac_mapping = {}
|
||||
hvac_list = self.values.mode.data_items
|
||||
if hvac_list:
|
||||
for mode in hvac_list:
|
||||
ha_mode = HVAC_STATE_MAPPINGS.get(mode)
|
||||
self._preset_list = []
|
||||
self._preset_mapping = {}
|
||||
|
||||
mode_list = self.values.mode.data_items
|
||||
if mode_list:
|
||||
for mode in mode_list:
|
||||
ha_mode = HVAC_STATE_MAPPINGS.get(str(mode).lower())
|
||||
ha_preset = PRESET_MAPPINGS.get(str(mode).lower())
|
||||
if ha_mode and ha_mode not in self._hvac_mapping:
|
||||
self._hvac_mapping[ha_mode] = mode
|
||||
self._hvac_list.append(ha_mode)
|
||||
continue
|
||||
self._hvac_list.append(mode)
|
||||
elif ha_preset and ha_preset not in self._preset_mapping:
|
||||
self._preset_mapping[ha_preset] = mode
|
||||
self._preset_list.append(ha_preset)
|
||||
else:
|
||||
# If nothing matches
|
||||
self._preset_list.append(mode)
|
||||
|
||||
# Default operation mode
|
||||
for mode in DEFAULT_HVAC_MODES:
|
||||
if mode in self._hvac_mapping.keys():
|
||||
self._default_hvac_mode = mode
|
||||
break
|
||||
|
||||
if self._preset_list:
|
||||
# Presets are supported
|
||||
self._preset_list.append(PRESET_NONE)
|
||||
|
||||
current_mode = self.values.mode.data
|
||||
self._hvac_mode = next(
|
||||
_LOGGER.debug("current_mode=%s", current_mode)
|
||||
_hvac_temp = next(
|
||||
(
|
||||
key
|
||||
for key, value in self._hvac_mapping.items()
|
||||
if value == current_mode
|
||||
),
|
||||
current_mode,
|
||||
None,
|
||||
)
|
||||
|
||||
if _hvac_temp is None:
|
||||
# The current mode is not a hvac mode
|
||||
if (
|
||||
"heat" in current_mode.lower()
|
||||
and HVAC_MODE_HEAT in self._hvac_mapping.keys()
|
||||
):
|
||||
# The current preset modes maps to HVAC_MODE_HEAT
|
||||
_LOGGER.debug("Mapped to HEAT")
|
||||
self._hvac_mode = HVAC_MODE_HEAT
|
||||
elif (
|
||||
"cool" in current_mode.lower()
|
||||
and HVAC_MODE_COOL in self._hvac_mapping.keys()
|
||||
):
|
||||
# The current preset modes maps to HVAC_MODE_COOL
|
||||
_LOGGER.debug("Mapped to COOL")
|
||||
self._hvac_mode = HVAC_MODE_COOL
|
||||
else:
|
||||
# The current preset modes maps to self._default_hvac_mode
|
||||
_LOGGER.debug("Mapped to DEFAULT")
|
||||
self._hvac_mode = self._default_hvac_mode
|
||||
self._preset_mode = next(
|
||||
(
|
||||
key
|
||||
for key, value in self._preset_mapping.items()
|
||||
if value == current_mode
|
||||
),
|
||||
current_mode,
|
||||
)
|
||||
else:
|
||||
# The current mode is a hvac mode
|
||||
self._hvac_mode = _hvac_temp
|
||||
self._preset_mode = PRESET_NONE
|
||||
|
||||
_LOGGER.debug("self._hvac_mapping=%s", self._hvac_mapping)
|
||||
_LOGGER.debug("self._hvac_list=%s", self._hvac_list)
|
||||
_LOGGER.debug("self._hvac_mode=%s", self._hvac_mode)
|
||||
_LOGGER.debug("self._default_hvac_mode=%s", self._default_hvac_mode)
|
||||
_LOGGER.debug("self._hvac_action=%s", self._hvac_action)
|
||||
_LOGGER.debug("self._preset_mapping=%s", self._preset_mapping)
|
||||
_LOGGER.debug("self._preset_list=%s", self._preset_list)
|
||||
_LOGGER.debug("self._preset_mode=%s", self._preset_mode)
|
||||
|
||||
# Current Temp
|
||||
if self.values.temperature:
|
||||
@ -199,7 +288,7 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
||||
# Operating state
|
||||
if self.values.operating_state:
|
||||
mode = self.values.operating_state.data
|
||||
self._hvac_action = HVAC_CURRENT_MAPPINGS.get(mode)
|
||||
self._hvac_action = HVAC_CURRENT_MAPPINGS.get(str(mode).lower(), mode)
|
||||
|
||||
# Fan operating state
|
||||
if self.values.fan_state:
|
||||
@ -247,7 +336,7 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
||||
"""
|
||||
if self.values.mode:
|
||||
return self._hvac_mode
|
||||
return HVAC_MODE_HEAT
|
||||
return self._default_hvac_mode
|
||||
|
||||
@property
|
||||
def hvac_modes(self):
|
||||
@ -267,6 +356,26 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
||||
"""
|
||||
return self._hvac_action
|
||||
|
||||
@property
|
||||
def preset_mode(self):
|
||||
"""Return preset operation ie. eco, away.
|
||||
|
||||
Need to be one of PRESET_*.
|
||||
"""
|
||||
if self.values.mode:
|
||||
return self._preset_mode
|
||||
return PRESET_NONE
|
||||
|
||||
@property
|
||||
def preset_modes(self):
|
||||
"""Return the list of available preset operation modes.
|
||||
|
||||
Need to be a subset of PRESET_MODES.
|
||||
"""
|
||||
if self.values.mode:
|
||||
return self._preset_list
|
||||
return []
|
||||
|
||||
@property
|
||||
def target_temperature(self):
|
||||
"""Return the temperature we try to reach."""
|
||||
@ -274,24 +383,46 @@ class ZWaveClimate(ZWaveDeviceEntity, ClimateDevice):
|
||||
|
||||
def set_temperature(self, **kwargs):
|
||||
"""Set new target temperature."""
|
||||
_LOGGER.debug("Set temperature to %s", kwargs.get(ATTR_TEMPERATURE))
|
||||
if kwargs.get(ATTR_TEMPERATURE) is None:
|
||||
return
|
||||
self.values.primary.data = kwargs.get(ATTR_TEMPERATURE)
|
||||
|
||||
def set_fan_mode(self, fan_mode):
|
||||
"""Set new target fan mode."""
|
||||
_LOGGER.debug("Set fan mode to %s", fan_mode)
|
||||
if not self.values.fan_mode:
|
||||
return
|
||||
self.values.fan_mode.data = fan_mode
|
||||
|
||||
def set_hvac_mode(self, hvac_mode):
|
||||
"""Set new target hvac mode."""
|
||||
_LOGGER.debug("Set hvac_mode to %s", hvac_mode)
|
||||
if not self.values.mode:
|
||||
return
|
||||
self.values.mode.data = self._hvac_mapping.get(hvac_mode, hvac_mode)
|
||||
operation_mode = self._hvac_mapping.get(hvac_mode)
|
||||
_LOGGER.debug("Set operation_mode to %s", operation_mode)
|
||||
self.values.mode.data = operation_mode
|
||||
|
||||
def set_preset_mode(self, preset_mode):
|
||||
"""Set new target preset mode."""
|
||||
_LOGGER.debug("Set preset_mode to %s", preset_mode)
|
||||
if not self.values.mode:
|
||||
return
|
||||
if preset_mode == PRESET_NONE:
|
||||
# Activate the current hvac mode
|
||||
self.update_properties()
|
||||
operation_mode = self._hvac_mapping.get(self.hvac_mode)
|
||||
_LOGGER.debug("Set operation_mode to %s", operation_mode)
|
||||
self.values.mode.data = operation_mode
|
||||
else:
|
||||
operation_mode = self._preset_mapping.get(preset_mode, preset_mode)
|
||||
_LOGGER.debug("Set operation_mode to %s", operation_mode)
|
||||
self.values.mode.data = operation_mode
|
||||
|
||||
def set_swing_mode(self, swing_mode):
|
||||
"""Set new target swing mode."""
|
||||
_LOGGER.debug("Set swing_mode to %s", swing_mode)
|
||||
if self._zxt_120 == 1:
|
||||
if self.values.zxt_120_swing_mode:
|
||||
self.values.zxt_120_swing_mode.data = swing_mode
|
||||
|
@ -2,11 +2,23 @@
|
||||
import pytest
|
||||
|
||||
from homeassistant.components.climate.const import (
|
||||
CURRENT_HVAC_HEAT,
|
||||
CURRENT_HVAC_COOL,
|
||||
HVAC_MODES,
|
||||
HVAC_MODE_COOL,
|
||||
HVAC_MODE_HEAT,
|
||||
HVAC_MODE_HEAT_COOL,
|
||||
HVAC_MODE_OFF,
|
||||
PRESET_BOOST,
|
||||
PRESET_ECO,
|
||||
PRESET_NONE,
|
||||
SUPPORT_FAN_MODE,
|
||||
SUPPORT_PRESET_MODE,
|
||||
SUPPORT_SWING_MODE,
|
||||
SUPPORT_TARGET_TEMPERATURE,
|
||||
)
|
||||
from homeassistant.components.zwave import climate
|
||||
from homeassistant.components.zwave.climate import DEFAULT_HVAC_MODES
|
||||
from homeassistant.const import ATTR_TEMPERATURE, TEMP_CELSIUS, TEMP_FAHRENHEIT
|
||||
|
||||
from tests.mock.zwave import MockEntityValues, MockNode, MockValue, value_changed
|
||||
@ -19,9 +31,18 @@ def device(hass, mock_openzwave):
|
||||
values = MockEntityValues(
|
||||
primary=MockValue(data=1, node=node),
|
||||
temperature=MockValue(data=5, node=node, units=None),
|
||||
mode=MockValue(data="test1", data_items=[0, 1, 2], node=node),
|
||||
mode=MockValue(
|
||||
data=HVAC_MODE_HEAT,
|
||||
data_items=[
|
||||
HVAC_MODE_OFF,
|
||||
HVAC_MODE_HEAT,
|
||||
HVAC_MODE_COOL,
|
||||
HVAC_MODE_HEAT_COOL,
|
||||
],
|
||||
node=node,
|
||||
),
|
||||
fan_mode=MockValue(data="test2", data_items=[3, 4, 5], node=node),
|
||||
operating_state=MockValue(data=6, node=node),
|
||||
operating_state=MockValue(data=CURRENT_HVAC_HEAT, node=node),
|
||||
fan_state=MockValue(data=7, node=node),
|
||||
)
|
||||
device = climate.get_device(hass, node=node, values=values, node_config={})
|
||||
@ -37,9 +58,18 @@ def device_zxt_120(hass, mock_openzwave):
|
||||
values = MockEntityValues(
|
||||
primary=MockValue(data=1, node=node),
|
||||
temperature=MockValue(data=5, node=node, units=None),
|
||||
mode=MockValue(data="test1", data_items=[0, 1, 2], node=node),
|
||||
mode=MockValue(
|
||||
data=HVAC_MODE_HEAT,
|
||||
data_items=[
|
||||
HVAC_MODE_OFF,
|
||||
HVAC_MODE_HEAT,
|
||||
HVAC_MODE_COOL,
|
||||
HVAC_MODE_HEAT_COOL,
|
||||
],
|
||||
node=node,
|
||||
),
|
||||
fan_mode=MockValue(data="test2", data_items=[3, 4, 5], node=node),
|
||||
operating_state=MockValue(data=6, node=node),
|
||||
operating_state=MockValue(data=CURRENT_HVAC_HEAT, node=node),
|
||||
fan_state=MockValue(data=7, node=node),
|
||||
zxt_120_swing_mode=MockValue(data="test3", data_items=[6, 7, 8], node=node),
|
||||
)
|
||||
@ -55,9 +85,13 @@ def device_mapping(hass, mock_openzwave):
|
||||
values = MockEntityValues(
|
||||
primary=MockValue(data=1, node=node),
|
||||
temperature=MockValue(data=5, node=node, units=None),
|
||||
mode=MockValue(data="Off", data_items=["Off", "Cool", "Heat"], node=node),
|
||||
mode=MockValue(
|
||||
data="Heat",
|
||||
data_items=["Off", "Cool", "Heat", "Full Power", "heat_cool"],
|
||||
node=node,
|
||||
),
|
||||
fan_mode=MockValue(data="test2", data_items=[3, 4, 5], node=node),
|
||||
operating_state=MockValue(data=6, node=node),
|
||||
operating_state=MockValue(data="heating", node=node),
|
||||
fan_state=MockValue(data=7, node=node),
|
||||
)
|
||||
device = climate.get_device(hass, node=node, values=values, node_config={})
|
||||
@ -65,6 +99,83 @@ def device_mapping(hass, mock_openzwave):
|
||||
yield device
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def device_unknown(hass, mock_openzwave):
|
||||
"""Fixture to provide a precreated climate device. Test state unknown."""
|
||||
node = MockNode()
|
||||
values = MockEntityValues(
|
||||
primary=MockValue(data=1, node=node),
|
||||
temperature=MockValue(data=5, node=node, units=None),
|
||||
mode=MockValue(
|
||||
data="Heat",
|
||||
data_items=["Off", "Cool", "Heat", "heat_cool", "Abcdefg"],
|
||||
node=node,
|
||||
),
|
||||
fan_mode=MockValue(data="test2", data_items=[3, 4, 5], node=node),
|
||||
operating_state=MockValue(data="test4", node=node),
|
||||
fan_state=MockValue(data=7, node=node),
|
||||
)
|
||||
device = climate.get_device(hass, node=node, values=values, node_config={})
|
||||
|
||||
yield device
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def device_heat_cool(hass, mock_openzwave):
|
||||
"""Fixture to provide a precreated climate device. Test state heat only."""
|
||||
node = MockNode()
|
||||
values = MockEntityValues(
|
||||
primary=MockValue(data=1, node=node),
|
||||
temperature=MockValue(data=5, node=node, units=None),
|
||||
mode=MockValue(
|
||||
data=HVAC_MODE_HEAT,
|
||||
data_items=[
|
||||
HVAC_MODE_OFF,
|
||||
HVAC_MODE_HEAT,
|
||||
HVAC_MODE_COOL,
|
||||
"Heat Eco",
|
||||
"Cool Eco",
|
||||
],
|
||||
node=node,
|
||||
),
|
||||
fan_mode=MockValue(data="test2", data_items=[3, 4, 5], node=node),
|
||||
operating_state=MockValue(data="test4", node=node),
|
||||
fan_state=MockValue(data=7, node=node),
|
||||
)
|
||||
device = climate.get_device(hass, node=node, values=values, node_config={})
|
||||
|
||||
yield device
|
||||
|
||||
|
||||
def test_default_hvac_modes():
|
||||
"""Test wether all hvac modes are included in default_hvac_modes."""
|
||||
for hvac_mode in HVAC_MODES:
|
||||
assert hvac_mode in DEFAULT_HVAC_MODES
|
||||
|
||||
|
||||
def test_supported_features(device):
|
||||
"""Test supported features flags."""
|
||||
assert device.supported_features == SUPPORT_FAN_MODE + SUPPORT_TARGET_TEMPERATURE
|
||||
|
||||
|
||||
def test_supported_features_preset_mode(device_mapping):
|
||||
"""Test supported features flags with swing mode."""
|
||||
device = device_mapping
|
||||
assert (
|
||||
device.supported_features
|
||||
== SUPPORT_FAN_MODE + SUPPORT_TARGET_TEMPERATURE + SUPPORT_PRESET_MODE
|
||||
)
|
||||
|
||||
|
||||
def test_supported_features_swing_mode(device_zxt_120):
|
||||
"""Test supported features flags with swing mode."""
|
||||
device = device_zxt_120
|
||||
assert (
|
||||
device.supported_features
|
||||
== SUPPORT_FAN_MODE + SUPPORT_TARGET_TEMPERATURE + SUPPORT_SWING_MODE
|
||||
)
|
||||
|
||||
|
||||
def test_zxt_120_swing_mode(device_zxt_120):
|
||||
"""Test operation of the zxt 120 swing mode."""
|
||||
device = device_zxt_120
|
||||
@ -107,7 +218,24 @@ def test_default_target_temperature(device):
|
||||
def test_data_lists(device):
|
||||
"""Test data lists from zwave value items."""
|
||||
assert device.fan_modes == [3, 4, 5]
|
||||
assert device.hvac_modes == [0, 1, 2]
|
||||
assert device.hvac_modes == [
|
||||
HVAC_MODE_OFF,
|
||||
HVAC_MODE_HEAT,
|
||||
HVAC_MODE_COOL,
|
||||
HVAC_MODE_HEAT_COOL,
|
||||
]
|
||||
assert device.preset_modes == []
|
||||
device.values.mode = None
|
||||
assert device.preset_modes == []
|
||||
|
||||
|
||||
def test_data_lists_mapping(device_mapping):
|
||||
"""Test data lists from zwave value items."""
|
||||
device = device_mapping
|
||||
assert device.hvac_modes == ["off", "cool", "heat", "heat_cool"]
|
||||
assert device.preset_modes == ["boost", "none"]
|
||||
device.values.mode = None
|
||||
assert device.preset_modes == []
|
||||
|
||||
|
||||
def test_target_value_set(device):
|
||||
@ -121,21 +249,56 @@ def test_target_value_set(device):
|
||||
|
||||
def test_operation_value_set(device):
|
||||
"""Test values changed for climate device."""
|
||||
assert device.values.mode.data == "test1"
|
||||
device.set_hvac_mode("test_set")
|
||||
assert device.values.mode.data == "test_set"
|
||||
assert device.values.mode.data == HVAC_MODE_HEAT
|
||||
device.set_hvac_mode(HVAC_MODE_COOL)
|
||||
assert device.values.mode.data == HVAC_MODE_COOL
|
||||
device.set_preset_mode(PRESET_ECO)
|
||||
assert device.values.mode.data == PRESET_ECO
|
||||
device.set_preset_mode(PRESET_NONE)
|
||||
assert device.values.mode.data == HVAC_MODE_HEAT_COOL
|
||||
device.values.mode = None
|
||||
device.set_hvac_mode("test_set_failes")
|
||||
assert device.values.mode is None
|
||||
device.set_preset_mode("test_set_failes")
|
||||
assert device.values.mode is None
|
||||
|
||||
|
||||
def test_operation_value_set_mapping(device_mapping):
|
||||
"""Test values changed for climate device. Mapping."""
|
||||
device = device_mapping
|
||||
assert device.values.mode.data == "Off"
|
||||
device.set_hvac_mode(HVAC_MODE_HEAT)
|
||||
assert device.values.mode.data == "Heat"
|
||||
device.set_hvac_mode(HVAC_MODE_COOL)
|
||||
assert device.values.mode.data == "Cool"
|
||||
device.set_hvac_mode(HVAC_MODE_OFF)
|
||||
assert device.values.mode.data == "Off"
|
||||
device.set_preset_mode(PRESET_BOOST)
|
||||
assert device.values.mode.data == "Full Power"
|
||||
device.set_preset_mode(PRESET_ECO)
|
||||
assert device.values.mode.data == "eco"
|
||||
|
||||
|
||||
def test_operation_value_set_unknown(device_unknown):
|
||||
"""Test values changed for climate device. Unknown."""
|
||||
device = device_unknown
|
||||
assert device.values.mode.data == "Heat"
|
||||
device.set_preset_mode("Abcdefg")
|
||||
assert device.values.mode.data == "Abcdefg"
|
||||
device.set_preset_mode(PRESET_NONE)
|
||||
assert device.values.mode.data == HVAC_MODE_HEAT_COOL
|
||||
|
||||
|
||||
def test_operation_value_set_heat_cool(device_heat_cool):
|
||||
"""Test values changed for climate device. Heat/Cool only."""
|
||||
device = device_heat_cool
|
||||
assert device.values.mode.data == HVAC_MODE_HEAT
|
||||
device.set_preset_mode("Heat Eco")
|
||||
assert device.values.mode.data == "Heat Eco"
|
||||
device.set_preset_mode(PRESET_NONE)
|
||||
assert device.values.mode.data == HVAC_MODE_HEAT
|
||||
device.set_preset_mode("Cool Eco")
|
||||
assert device.values.mode.data == "Cool Eco"
|
||||
device.set_preset_mode(PRESET_NONE)
|
||||
assert device.values.mode.data == HVAC_MODE_COOL
|
||||
|
||||
|
||||
def test_fan_mode_value_set(device):
|
||||
@ -143,6 +306,9 @@ def test_fan_mode_value_set(device):
|
||||
assert device.values.fan_mode.data == "test2"
|
||||
device.set_fan_mode("test_fan_set")
|
||||
assert device.values.fan_mode.data == "test_fan_set"
|
||||
device.values.fan_mode = None
|
||||
device.set_fan_mode("test_fan_set_failes")
|
||||
assert device.values.fan_mode is None
|
||||
|
||||
|
||||
def test_target_value_changed(device):
|
||||
@ -163,25 +329,85 @@ def test_temperature_value_changed(device):
|
||||
|
||||
def test_operation_value_changed(device):
|
||||
"""Test values changed for climate device."""
|
||||
assert device.hvac_mode == "test1"
|
||||
device.values.mode.data = "test_updated"
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode.data = HVAC_MODE_COOL
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == "test_updated"
|
||||
assert device.hvac_mode == HVAC_MODE_COOL
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode.data = HVAC_MODE_OFF
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_OFF
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode = None
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT_COOL
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
|
||||
|
||||
def test_operation_value_changed_preset(device_mapping):
|
||||
"""Test preset changed for climate device."""
|
||||
device = device_mapping
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode.data = PRESET_ECO
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT_COOL
|
||||
assert device.preset_mode == PRESET_ECO
|
||||
|
||||
|
||||
def test_operation_value_changed_mapping(device_mapping):
|
||||
"""Test values changed for climate device. Mapping."""
|
||||
device = device_mapping
|
||||
assert device.hvac_mode == "off"
|
||||
device.values.mode.data = "Heat"
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT
|
||||
device.values.mode.data = "Cool"
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_COOL
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode.data = "Off"
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_OFF
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode.data = "Cool"
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_COOL
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
|
||||
|
||||
def test_operation_value_changed_mapping_preset(device_mapping):
|
||||
"""Test values changed for climate device. Mapping with presets."""
|
||||
device = device_mapping
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode.data = "Full Power"
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT_COOL
|
||||
assert device.preset_mode == PRESET_BOOST
|
||||
device.values.mode = None
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT_COOL
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
|
||||
|
||||
def test_operation_value_changed_unknown(device_unknown):
|
||||
"""Test preset changed for climate device. Unknown."""
|
||||
device = device_unknown
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode.data = "Abcdefg"
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT_COOL
|
||||
assert device.preset_mode == "Abcdefg"
|
||||
|
||||
|
||||
def test_operation_value_changed_heat_cool(device_heat_cool):
|
||||
"""Test preset changed for climate device. Heat/Cool only."""
|
||||
device = device_heat_cool
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT
|
||||
assert device.preset_mode == PRESET_NONE
|
||||
device.values.mode.data = "Cool Eco"
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_COOL
|
||||
assert device.preset_mode == "Cool Eco"
|
||||
device.values.mode.data = "Heat Eco"
|
||||
value_changed(device.values.mode)
|
||||
assert device.hvac_mode == HVAC_MODE_HEAT
|
||||
assert device.preset_mode == "Heat Eco"
|
||||
|
||||
|
||||
def test_fan_mode_value_changed(device):
|
||||
@ -190,3 +416,29 @@ def test_fan_mode_value_changed(device):
|
||||
device.values.fan_mode.data = "test_updated_fan"
|
||||
value_changed(device.values.fan_mode)
|
||||
assert device.fan_mode == "test_updated_fan"
|
||||
|
||||
|
||||
def test_hvac_action_value_changed(device):
|
||||
"""Test values changed for climate device."""
|
||||
assert device.hvac_action == CURRENT_HVAC_HEAT
|
||||
device.values.operating_state.data = CURRENT_HVAC_COOL
|
||||
value_changed(device.values.operating_state)
|
||||
assert device.hvac_action == CURRENT_HVAC_COOL
|
||||
|
||||
|
||||
def test_hvac_action_value_changed_mapping(device_mapping):
|
||||
"""Test values changed for climate device."""
|
||||
device = device_mapping
|
||||
assert device.hvac_action == CURRENT_HVAC_HEAT
|
||||
device.values.operating_state.data = "cooling"
|
||||
value_changed(device.values.operating_state)
|
||||
assert device.hvac_action == CURRENT_HVAC_COOL
|
||||
|
||||
|
||||
def test_hvac_action_value_changed_unknown(device_unknown):
|
||||
"""Test values changed for climate device."""
|
||||
device = device_unknown
|
||||
assert device.hvac_action == "test4"
|
||||
device.values.operating_state.data = "another_hvac_action"
|
||||
value_changed(device.values.operating_state)
|
||||
assert device.hvac_action == "another_hvac_action"
|
||||
|
Loading…
x
Reference in New Issue
Block a user