Fix HVAC modes for Airzone slave zones (#68851)

pull/68898/head
Álvaro Fernández Rojas 2022-03-30 13:32:15 +02:00 committed by GitHub
parent 3953b6abe2
commit 0cb8ff9bc6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 79 additions and 32 deletions

View File

@ -144,10 +144,14 @@ class AirzoneClimate(AirzoneEntity, ClimateEntity):
if hvac_mode == HVAC_MODE_OFF: if hvac_mode == HVAC_MODE_OFF:
params[API_ON] = 0 params[API_ON] = 0
else: else:
if self.get_zone_value(AZD_MASTER): mode = HVAC_MODE_HASS_TO_LIB[hvac_mode]
mode = HVAC_MODE_HASS_TO_LIB[hvac_mode] if mode != self.get_zone_value(AZD_MODE):
if mode != self.get_zone_value(AZD_MODE): if self.get_zone_value(AZD_MASTER):
params[API_MODE] = mode params[API_MODE] = mode
else:
raise HomeAssistantError(
f"Mode can't be changed on slave zone {self.name}"
)
params[API_ON] = 1 params[API_ON] = 1
_LOGGER.debug("Set hvac_mode=%s params=%s", hvac_mode, params) _LOGGER.debug("Set hvac_mode=%s params=%s", hvac_mode, params)
await self._async_update_hvac_params(params) await self._async_update_hvac_params(params)

View File

@ -3,7 +3,7 @@
"name": "Airzone", "name": "Airzone",
"config_flow": true, "config_flow": true,
"documentation": "https://www.home-assistant.io/integrations/airzone", "documentation": "https://www.home-assistant.io/integrations/airzone",
"requirements": ["aioairzone==0.2.1"], "requirements": ["aioairzone==0.2.3"],
"codeowners": ["@Noltari"], "codeowners": ["@Noltari"],
"iot_class": "local_polling", "iot_class": "local_polling",
"loggers": ["aioairzone"] "loggers": ["aioairzone"]

View File

@ -110,7 +110,7 @@ aio_geojson_nsw_rfs_incidents==0.4
aio_georss_gdacs==0.5 aio_georss_gdacs==0.5
# homeassistant.components.airzone # homeassistant.components.airzone
aioairzone==0.2.1 aioairzone==0.2.3
# homeassistant.components.ambient_station # homeassistant.components.ambient_station
aioambient==2021.11.0 aioambient==2021.11.0

View File

@ -91,7 +91,7 @@ aio_geojson_nsw_rfs_incidents==0.4
aio_georss_gdacs==0.5 aio_georss_gdacs==0.5
# homeassistant.components.airzone # homeassistant.components.airzone
aioairzone==0.2.1 aioairzone==0.2.3
# homeassistant.components.ambient_station # homeassistant.components.ambient_station
aioambient==2021.11.0 aioambient==2021.11.0

View File

@ -12,6 +12,7 @@ from aioairzone.const import (
API_ZONE_ID, API_ZONE_ID,
) )
from aioairzone.exceptions import AirzoneError from aioairzone.exceptions import AirzoneError
import pytest
from homeassistant.components.airzone.const import API_TEMPERATURE_STEP from homeassistant.components.airzone.const import API_TEMPERATURE_STEP
from homeassistant.components.climate.const import ( from homeassistant.components.climate.const import (
@ -52,8 +53,11 @@ async def test_airzone_create_climates(hass):
assert state.attributes.get(ATTR_CURRENT_TEMPERATURE) == 21.2 assert state.attributes.get(ATTR_CURRENT_TEMPERATURE) == 21.2
assert state.attributes.get(ATTR_HVAC_ACTION) == CURRENT_HVAC_OFF assert state.attributes.get(ATTR_HVAC_ACTION) == CURRENT_HVAC_OFF
assert state.attributes.get(ATTR_HVAC_MODES) == [ assert state.attributes.get(ATTR_HVAC_MODES) == [
HVAC_MODE_HEAT,
HVAC_MODE_OFF, HVAC_MODE_OFF,
HVAC_MODE_FAN_ONLY,
HVAC_MODE_COOL,
HVAC_MODE_HEAT,
HVAC_MODE_DRY,
] ]
assert state.attributes.get(ATTR_MAX_TEMP) == 30 assert state.attributes.get(ATTR_MAX_TEMP) == 30
assert state.attributes.get(ATTR_MIN_TEMP) == 15 assert state.attributes.get(ATTR_MIN_TEMP) == 15
@ -66,8 +70,11 @@ async def test_airzone_create_climates(hass):
assert state.attributes.get(ATTR_CURRENT_TEMPERATURE) == 20.8 assert state.attributes.get(ATTR_CURRENT_TEMPERATURE) == 20.8
assert state.attributes.get(ATTR_HVAC_ACTION) == CURRENT_HVAC_IDLE assert state.attributes.get(ATTR_HVAC_ACTION) == CURRENT_HVAC_IDLE
assert state.attributes.get(ATTR_HVAC_MODES) == [ assert state.attributes.get(ATTR_HVAC_MODES) == [
HVAC_MODE_HEAT,
HVAC_MODE_OFF, HVAC_MODE_OFF,
HVAC_MODE_FAN_ONLY,
HVAC_MODE_COOL,
HVAC_MODE_HEAT,
HVAC_MODE_DRY,
] ]
assert state.attributes.get(ATTR_MAX_TEMP) == 30 assert state.attributes.get(ATTR_MAX_TEMP) == 30
assert state.attributes.get(ATTR_MIN_TEMP) == 15 assert state.attributes.get(ATTR_MIN_TEMP) == 15
@ -80,8 +87,11 @@ async def test_airzone_create_climates(hass):
assert state.attributes.get(ATTR_CURRENT_TEMPERATURE) == 20.5 assert state.attributes.get(ATTR_CURRENT_TEMPERATURE) == 20.5
assert state.attributes.get(ATTR_HVAC_ACTION) == CURRENT_HVAC_OFF assert state.attributes.get(ATTR_HVAC_ACTION) == CURRENT_HVAC_OFF
assert state.attributes.get(ATTR_HVAC_MODES) == [ assert state.attributes.get(ATTR_HVAC_MODES) == [
HVAC_MODE_HEAT,
HVAC_MODE_OFF, HVAC_MODE_OFF,
HVAC_MODE_FAN_ONLY,
HVAC_MODE_COOL,
HVAC_MODE_HEAT,
HVAC_MODE_DRY,
] ]
assert state.attributes.get(ATTR_MAX_TEMP) == 30 assert state.attributes.get(ATTR_MAX_TEMP) == 30
assert state.attributes.get(ATTR_MIN_TEMP) == 15 assert state.attributes.get(ATTR_MIN_TEMP) == 15
@ -94,8 +104,11 @@ async def test_airzone_create_climates(hass):
assert state.attributes.get(ATTR_CURRENT_TEMPERATURE) == 21.1 assert state.attributes.get(ATTR_CURRENT_TEMPERATURE) == 21.1
assert state.attributes.get(ATTR_HVAC_ACTION) == CURRENT_HVAC_HEAT assert state.attributes.get(ATTR_HVAC_ACTION) == CURRENT_HVAC_HEAT
assert state.attributes.get(ATTR_HVAC_MODES) == [ assert state.attributes.get(ATTR_HVAC_MODES) == [
HVAC_MODE_HEAT,
HVAC_MODE_OFF, HVAC_MODE_OFF,
HVAC_MODE_FAN_ONLY,
HVAC_MODE_COOL,
HVAC_MODE_HEAT,
HVAC_MODE_DRY,
] ]
assert state.attributes.get(ATTR_MAX_TEMP) == 30 assert state.attributes.get(ATTR_MAX_TEMP) == 30
assert state.attributes.get(ATTR_MIN_TEMP) == 15 assert state.attributes.get(ATTR_MIN_TEMP) == 15
@ -121,7 +134,7 @@ async def test_airzone_create_climates(hass):
async def test_airzone_climate_set_hvac_mode(hass): async def test_airzone_climate_set_hvac_mode(hass):
"""Test setting the target temperature.""" """Test setting the HVAC mode."""
await async_init_integration(hass) await async_init_integration(hass)
@ -149,8 +162,8 @@ async def test_airzone_climate_set_hvac_mode(hass):
blocking=True, blocking=True,
) )
state = hass.states.get("climate.salon") state = hass.states.get("climate.salon")
assert state.state == HVAC_MODE_COOL assert state.state == HVAC_MODE_COOL
HVAC_MOCK_2 = { HVAC_MOCK_2 = {
API_DATA: [ API_DATA: [
@ -175,8 +188,41 @@ async def test_airzone_climate_set_hvac_mode(hass):
blocking=True, blocking=True,
) )
state = hass.states.get("climate.salon") state = hass.states.get("climate.salon")
assert state.state == HVAC_MODE_OFF assert state.state == HVAC_MODE_OFF
async def test_airzone_climate_set_hvac_slave_error(hass):
"""Test setting the HVAC mode for a slave zone."""
HVAC_MOCK = {
API_DATA: [
{
API_SYSTEM_ID: 1,
API_ZONE_ID: 5,
API_ON: 1,
}
]
}
await async_init_integration(hass)
with patch(
"homeassistant.components.airzone.AirzoneLocalApi.http_request",
return_value=HVAC_MOCK,
), pytest.raises(HomeAssistantError):
await hass.services.async_call(
CLIMATE_DOMAIN,
SERVICE_SET_HVAC_MODE,
{
ATTR_ENTITY_ID: "climate.dorm_2",
ATTR_HVAC_MODE: HVAC_MODE_COOL,
},
blocking=True,
)
state = hass.states.get("climate.dorm_2")
assert state.state == HVAC_MODE_OFF
async def test_airzone_climate_set_temp(hass): async def test_airzone_climate_set_temp(hass):
@ -208,8 +254,8 @@ async def test_airzone_climate_set_temp(hass):
blocking=True, blocking=True,
) )
state = hass.states.get("climate.dorm_2") state = hass.states.get("climate.dorm_2")
assert state.attributes.get(ATTR_TEMPERATURE) == 20.5 assert state.attributes.get(ATTR_TEMPERATURE) == 20.5
async def test_airzone_climate_set_temp_error(hass): async def test_airzone_climate_set_temp_error(hass):
@ -220,19 +266,16 @@ async def test_airzone_climate_set_temp_error(hass):
with patch( with patch(
"homeassistant.components.airzone.AirzoneLocalApi.put_hvac", "homeassistant.components.airzone.AirzoneLocalApi.put_hvac",
side_effect=AirzoneError, side_effect=AirzoneError,
): ), pytest.raises(HomeAssistantError):
try: await hass.services.async_call(
await hass.services.async_call( CLIMATE_DOMAIN,
CLIMATE_DOMAIN, SERVICE_SET_TEMPERATURE,
SERVICE_SET_TEMPERATURE, {
{ ATTR_ENTITY_ID: "climate.dorm_2",
ATTR_ENTITY_ID: "climate.dorm_2", ATTR_TEMPERATURE: 20.5,
ATTR_TEMPERATURE: 20.5, },
}, blocking=True,
blocking=True, )
)
except HomeAssistantError:
pass
state = hass.states.get("climate.dorm_2") state = hass.states.get("climate.dorm_2")
assert state.attributes.get(ATTR_TEMPERATURE) == 19.5 assert state.attributes.get(ATTR_TEMPERATURE) == 19.5