2019-10-12 19:45:11 +00:00
|
|
|
"""Tests for HomematicIP Cloud climate."""
|
|
|
|
import datetime
|
|
|
|
|
|
|
|
from homematicip.base.enums import AbsenceType
|
|
|
|
from homematicip.functionalHomes import IndoorClimateHome
|
|
|
|
|
2019-10-15 10:12:58 +00:00
|
|
|
from homeassistant.components.climate import DOMAIN as CLIMATE_DOMAIN
|
2019-10-12 19:45:11 +00:00
|
|
|
from homeassistant.components.climate.const import (
|
|
|
|
ATTR_CURRENT_TEMPERATURE,
|
2019-11-26 18:02:30 +00:00
|
|
|
ATTR_HVAC_ACTION,
|
2019-10-12 19:45:11 +00:00
|
|
|
ATTR_PRESET_MODE,
|
|
|
|
ATTR_PRESET_MODES,
|
2019-11-26 18:02:30 +00:00
|
|
|
CURRENT_HVAC_HEAT,
|
|
|
|
CURRENT_HVAC_IDLE,
|
2019-10-12 19:45:11 +00:00
|
|
|
HVAC_MODE_AUTO,
|
2019-11-07 15:41:33 +00:00
|
|
|
HVAC_MODE_COOL,
|
2019-10-12 19:45:11 +00:00
|
|
|
HVAC_MODE_HEAT,
|
2019-11-07 15:41:33 +00:00
|
|
|
HVAC_MODE_OFF,
|
2019-10-12 19:45:11 +00:00
|
|
|
PRESET_AWAY,
|
|
|
|
PRESET_BOOST,
|
|
|
|
PRESET_ECO,
|
2020-02-16 09:09:26 +00:00
|
|
|
PRESET_NONE,
|
2019-10-12 19:45:11 +00:00
|
|
|
)
|
2019-10-15 10:12:58 +00:00
|
|
|
from homeassistant.components.homematicip_cloud import DOMAIN as HMIPC_DOMAIN
|
2019-11-07 15:41:33 +00:00
|
|
|
from homeassistant.components.homematicip_cloud.climate import (
|
|
|
|
ATTR_PRESET_END_TIME,
|
|
|
|
PERMANENT_END_TIME,
|
|
|
|
)
|
2019-10-15 10:12:58 +00:00
|
|
|
from homeassistant.setup import async_setup_component
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
from .helper import HAPID, async_manipulate_test_data, get_and_check_entity_basics
|
|
|
|
|
|
|
|
|
2019-10-15 10:12:58 +00:00
|
|
|
async def test_manually_configured_platform(hass):
|
|
|
|
"""Test that we do not set up an access point."""
|
2020-02-16 09:09:26 +00:00
|
|
|
assert await async_setup_component(
|
|
|
|
hass, CLIMATE_DOMAIN, {CLIMATE_DOMAIN: {"platform": HMIPC_DOMAIN}}
|
2019-10-15 10:12:58 +00:00
|
|
|
)
|
|
|
|
assert not hass.data.get(HMIPC_DOMAIN)
|
|
|
|
|
|
|
|
|
2020-02-14 06:56:17 +00:00
|
|
|
async def test_hmip_heating_group_heat(hass, default_mock_hap_factory):
|
2019-10-12 19:45:11 +00:00
|
|
|
"""Test HomematicipHeatingGroup."""
|
|
|
|
entity_id = "climate.badezimmer"
|
|
|
|
entity_name = "Badezimmer"
|
|
|
|
device_model = None
|
2020-02-14 06:56:17 +00:00
|
|
|
mock_hap = await default_mock_hap_factory.async_get_mock_hap(
|
2020-02-16 09:09:26 +00:00
|
|
|
test_devices=["Wandthermostat", "Heizkörperthermostat3"],
|
2020-02-14 06:56:17 +00:00
|
|
|
test_groups=[entity_name],
|
|
|
|
)
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
ha_state, hmip_device = get_and_check_entity_basics(
|
2020-02-14 06:56:17 +00:00
|
|
|
hass, mock_hap, entity_id, entity_name, device_model
|
2019-10-12 19:45:11 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
assert ha_state.attributes["current_temperature"] == 23.8
|
|
|
|
assert ha_state.attributes["min_temp"] == 5.0
|
|
|
|
assert ha_state.attributes["max_temp"] == 30.0
|
|
|
|
assert ha_state.attributes["temperature"] == 5.0
|
|
|
|
assert ha_state.attributes["current_humidity"] == 47
|
2019-10-19 15:44:40 +00:00
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == "STD"
|
2019-11-07 15:41:33 +00:00
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODES] == [PRESET_BOOST, "STD", "Winter"]
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
service_call_counter = len(hmip_device.mock_calls)
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_temperature",
|
|
|
|
{"entity_id": entity_id, "temperature": 22.5},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 1
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_point_temperature"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == (22.5,)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "actualTemperature", 22.5)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.attributes[ATTR_CURRENT_TEMPERATURE] == 22.5
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_hvac_mode",
|
|
|
|
{"entity_id": entity_id, "hvac_mode": HVAC_MODE_HEAT},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 3
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_control_mode"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == ("MANUAL",)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "MANUAL")
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.state == HVAC_MODE_HEAT
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_hvac_mode",
|
|
|
|
{"entity_id": entity_id, "hvac_mode": HVAC_MODE_AUTO},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 5
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_control_mode"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == ("AUTOMATIC",)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "AUTO")
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_preset_mode",
|
|
|
|
{"entity_id": entity_id, "preset_mode": PRESET_BOOST},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 7
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_boost"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == ()
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "boostMode", True)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == PRESET_BOOST
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_preset_mode",
|
2019-11-07 15:41:33 +00:00
|
|
|
{"entity_id": entity_id, "preset_mode": "STD"},
|
2019-10-12 19:45:11 +00:00
|
|
|
blocking=True,
|
|
|
|
)
|
2019-11-07 15:41:33 +00:00
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 11
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_active_profile"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == (0,)
|
2019-10-12 19:45:11 +00:00
|
|
|
await async_manipulate_test_data(hass, hmip_device, "boostMode", False)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
2019-10-19 15:44:40 +00:00
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == "STD"
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
# Not required for hmip, but a posiblity to send no temperature.
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_temperature",
|
|
|
|
{"entity_id": entity_id, "target_temp_low": 10, "target_temp_high": 10},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
# No new service call should be in mock_calls.
|
2019-11-07 15:41:33 +00:00
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 12
|
2019-10-12 19:45:11 +00:00
|
|
|
# Only fire event from last async_manipulate_test_data available.
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "fire_update_event"
|
|
|
|
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "ECO")
|
|
|
|
await async_manipulate_test_data(
|
|
|
|
hass,
|
2020-02-14 06:56:17 +00:00
|
|
|
mock_hap.home.get_functionalHome(IndoorClimateHome),
|
2019-10-12 19:45:11 +00:00
|
|
|
"absenceType",
|
|
|
|
AbsenceType.VACATION,
|
|
|
|
fire_device=hmip_device,
|
|
|
|
)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == PRESET_AWAY
|
|
|
|
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "ECO")
|
|
|
|
await async_manipulate_test_data(
|
|
|
|
hass,
|
2020-02-14 06:56:17 +00:00
|
|
|
mock_hap.home.get_functionalHome(IndoorClimateHome),
|
2019-10-12 19:45:11 +00:00
|
|
|
"absenceType",
|
|
|
|
AbsenceType.PERIOD,
|
|
|
|
fire_device=hmip_device,
|
|
|
|
)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == PRESET_ECO
|
|
|
|
|
2019-10-19 15:44:40 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_preset_mode",
|
|
|
|
{"entity_id": entity_id, "preset_mode": "Winter"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
|
2019-11-07 15:41:33 +00:00
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 18
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_active_profile"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == (1,)
|
|
|
|
|
2020-02-14 06:56:17 +00:00
|
|
|
mock_hap.home.get_functionalHome(
|
2019-11-07 15:41:33 +00:00
|
|
|
IndoorClimateHome
|
|
|
|
).absenceType = AbsenceType.PERMANENT
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "ECO")
|
|
|
|
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_END_TIME] == PERMANENT_END_TIME
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_hvac_mode",
|
|
|
|
{"entity_id": entity_id, "hvac_mode": HVAC_MODE_HEAT},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 20
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_control_mode"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == ("MANUAL",)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "MANUAL")
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.state == HVAC_MODE_HEAT
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_preset_mode",
|
|
|
|
{"entity_id": entity_id, "preset_mode": "Winter"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 23
|
2019-10-19 15:44:40 +00:00
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_active_profile"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == (1,)
|
2019-11-07 15:41:33 +00:00
|
|
|
hmip_device.activeProfile = hmip_device.profiles[0]
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "AUTOMATIC")
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_hvac_mode",
|
|
|
|
{"entity_id": entity_id, "hvac_mode": "dry"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 24
|
|
|
|
# Only fire event from last async_manipulate_test_data available.
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "fire_update_event"
|
|
|
|
|
2019-11-26 18:02:30 +00:00
|
|
|
await async_manipulate_test_data(hass, hmip_device, "floorHeatingMode", "RADIATOR")
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "valvePosition", 0.1)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
assert ha_state.attributes[ATTR_HVAC_ACTION] == CURRENT_HVAC_HEAT
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "floorHeatingMode", "RADIATOR")
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "valvePosition", 0.0)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
assert ha_state.attributes[ATTR_HVAC_ACTION] == CURRENT_HVAC_IDLE
|
|
|
|
|
2019-11-07 15:41:33 +00:00
|
|
|
|
2020-02-14 06:56:17 +00:00
|
|
|
async def test_hmip_heating_group_cool(hass, default_mock_hap_factory):
|
2019-11-07 15:41:33 +00:00
|
|
|
"""Test HomematicipHeatingGroup."""
|
|
|
|
entity_id = "climate.badezimmer"
|
|
|
|
entity_name = "Badezimmer"
|
|
|
|
device_model = None
|
2020-02-14 06:56:17 +00:00
|
|
|
mock_hap = await default_mock_hap_factory.async_get_mock_hap(
|
|
|
|
test_groups=[entity_name]
|
|
|
|
)
|
2019-11-07 15:41:33 +00:00
|
|
|
|
|
|
|
ha_state, hmip_device = get_and_check_entity_basics(
|
2020-02-14 06:56:17 +00:00
|
|
|
hass, mock_hap, entity_id, entity_name, device_model
|
2019-11-07 15:41:33 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
hmip_device.activeProfile = hmip_device.profiles[3]
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "cooling", True)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "coolingAllowed", True)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "coolingIgnored", False)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
assert ha_state.attributes["current_temperature"] == 23.8
|
|
|
|
assert ha_state.attributes["min_temp"] == 5.0
|
|
|
|
assert ha_state.attributes["max_temp"] == 30.0
|
|
|
|
assert ha_state.attributes["temperature"] == 5.0
|
|
|
|
assert ha_state.attributes["current_humidity"] == 47
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == "Cool1"
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODES] == ["Cool1", "Cool2"]
|
|
|
|
|
|
|
|
service_call_counter = len(hmip_device.mock_calls)
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_hvac_mode",
|
|
|
|
{"entity_id": entity_id, "hvac_mode": HVAC_MODE_COOL},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 1
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_control_mode"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == ("MANUAL",)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "MANUAL")
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.state == HVAC_MODE_COOL
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_hvac_mode",
|
|
|
|
{"entity_id": entity_id, "hvac_mode": HVAC_MODE_AUTO},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 3
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_control_mode"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == ("AUTOMATIC",)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "controlMode", "AUTO")
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_preset_mode",
|
|
|
|
{"entity_id": entity_id, "preset_mode": "Cool2"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 6
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_active_profile"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == (4,)
|
|
|
|
|
|
|
|
hmip_device.activeProfile = hmip_device.profiles[4]
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "cooling", True)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "coolingAllowed", False)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "coolingIgnored", False)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
|
|
|
|
assert ha_state.state == HVAC_MODE_OFF
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == "none"
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODES] == []
|
|
|
|
|
|
|
|
hmip_device.activeProfile = hmip_device.profiles[4]
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "cooling", True)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "coolingAllowed", True)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "coolingIgnored", True)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
|
|
|
|
assert ha_state.state == HVAC_MODE_OFF
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == "none"
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODES] == []
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_preset_mode",
|
|
|
|
{"entity_id": entity_id, "preset_mode": "Cool2"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 12
|
|
|
|
# fire_update_event shows that set_active_profile has not been called.
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "fire_update_event"
|
|
|
|
|
|
|
|
hmip_device.activeProfile = hmip_device.profiles[4]
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "cooling", True)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "coolingAllowed", True)
|
|
|
|
await async_manipulate_test_data(hass, hmip_device, "coolingIgnored", False)
|
|
|
|
ha_state = hass.states.get(entity_id)
|
|
|
|
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == "Cool2"
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODES] == ["Cool1", "Cool2"]
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"climate",
|
|
|
|
"set_preset_mode",
|
|
|
|
{"entity_id": entity_id, "preset_mode": "Cool2"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
assert len(hmip_device.mock_calls) == service_call_counter + 17
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_active_profile"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == (4,)
|
2019-10-19 15:44:40 +00:00
|
|
|
|
2019-10-12 19:45:11 +00:00
|
|
|
|
2020-02-14 06:56:17 +00:00
|
|
|
async def test_hmip_heating_group_heat_with_switch(hass, default_mock_hap_factory):
|
2019-11-12 10:32:32 +00:00
|
|
|
"""Test HomematicipHeatingGroup."""
|
|
|
|
entity_id = "climate.schlafzimmer"
|
|
|
|
entity_name = "Schlafzimmer"
|
|
|
|
device_model = None
|
2020-02-14 06:56:17 +00:00
|
|
|
mock_hap = await default_mock_hap_factory.async_get_mock_hap(
|
|
|
|
test_devices=["Wandthermostat", "Heizkörperthermostat", "Pc"],
|
|
|
|
test_groups=[entity_name],
|
|
|
|
)
|
2019-11-12 10:32:32 +00:00
|
|
|
ha_state, hmip_device = get_and_check_entity_basics(
|
2020-02-14 06:56:17 +00:00
|
|
|
hass, mock_hap, entity_id, entity_name, device_model
|
2019-11-12 10:32:32 +00:00
|
|
|
)
|
|
|
|
|
2019-11-15 08:55:40 +00:00
|
|
|
assert hmip_device
|
2019-11-12 10:32:32 +00:00
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
assert ha_state.attributes["current_temperature"] == 24.7
|
|
|
|
assert ha_state.attributes["min_temp"] == 5.0
|
|
|
|
assert ha_state.attributes["max_temp"] == 30.0
|
|
|
|
assert ha_state.attributes["temperature"] == 5.0
|
|
|
|
assert ha_state.attributes["current_humidity"] == 43
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] == "STD"
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODES] == [PRESET_BOOST, "STD", "P2"]
|
|
|
|
|
|
|
|
|
2020-02-16 09:09:26 +00:00
|
|
|
async def test_hmip_heating_group_heat_with_radiator(hass, default_mock_hap_factory):
|
|
|
|
"""Test HomematicipHeatingGroup."""
|
|
|
|
entity_id = "climate.vorzimmer"
|
|
|
|
entity_name = "Vorzimmer"
|
|
|
|
device_model = None
|
|
|
|
mock_hap = await default_mock_hap_factory.async_get_mock_hap(
|
2020-08-27 11:56:20 +00:00
|
|
|
test_devices=["Heizkörperthermostat2"],
|
|
|
|
test_groups=[entity_name],
|
2020-02-16 09:09:26 +00:00
|
|
|
)
|
|
|
|
ha_state, hmip_device = get_and_check_entity_basics(
|
|
|
|
hass, mock_hap, entity_id, entity_name, device_model
|
|
|
|
)
|
|
|
|
|
|
|
|
assert hmip_device
|
|
|
|
assert ha_state.state == HVAC_MODE_AUTO
|
|
|
|
assert ha_state.attributes["current_temperature"] == 20
|
|
|
|
assert ha_state.attributes["min_temp"] == 5.0
|
|
|
|
assert ha_state.attributes["max_temp"] == 30.0
|
|
|
|
assert ha_state.attributes["temperature"] == 5.0
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODE] is None
|
|
|
|
assert ha_state.attributes[ATTR_PRESET_MODES] == [PRESET_NONE, PRESET_BOOST]
|
|
|
|
|
|
|
|
|
2019-10-12 19:45:11 +00:00
|
|
|
async def test_hmip_climate_services(hass, mock_hap_with_service):
|
|
|
|
"""Test HomematicipHeatingGroup."""
|
|
|
|
|
|
|
|
home = mock_hap_with_service.home
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"activate_eco_mode_with_duration",
|
|
|
|
{"duration": 60, "accesspoint_id": HAPID},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "activate_absence_with_duration"
|
|
|
|
assert home.mock_calls[-1][1] == (60,)
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 1 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"activate_eco_mode_with_duration",
|
|
|
|
{"duration": 60},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "activate_absence_with_duration"
|
|
|
|
assert home.mock_calls[-1][1] == (60,)
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 2 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"activate_eco_mode_with_period",
|
|
|
|
{"endtime": "2019-02-17 14:00", "accesspoint_id": HAPID},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "activate_absence_with_period"
|
|
|
|
assert home.mock_calls[-1][1] == (datetime.datetime(2019, 2, 17, 14, 0),)
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 3 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"activate_eco_mode_with_period",
|
|
|
|
{"endtime": "2019-02-17 14:00"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "activate_absence_with_period"
|
|
|
|
assert home.mock_calls[-1][1] == (datetime.datetime(2019, 2, 17, 14, 0),)
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 4 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"activate_vacation",
|
|
|
|
{"endtime": "2019-02-17 14:00", "temperature": 18.5, "accesspoint_id": HAPID},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "activate_vacation"
|
|
|
|
assert home.mock_calls[-1][1] == (datetime.datetime(2019, 2, 17, 14, 0), 18.5)
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 5 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"activate_vacation",
|
|
|
|
{"endtime": "2019-02-17 14:00", "temperature": 18.5},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "activate_vacation"
|
|
|
|
assert home.mock_calls[-1][1] == (datetime.datetime(2019, 2, 17, 14, 0), 18.5)
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 6 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"deactivate_eco_mode",
|
|
|
|
{"accesspoint_id": HAPID},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "deactivate_absence"
|
|
|
|
assert home.mock_calls[-1][1] == ()
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 7 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud", "deactivate_eco_mode", blocking=True
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "deactivate_absence"
|
|
|
|
assert home.mock_calls[-1][1] == ()
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 8 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"deactivate_vacation",
|
|
|
|
{"accesspoint_id": HAPID},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "deactivate_vacation"
|
|
|
|
assert home.mock_calls[-1][1] == ()
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 9 # pylint: disable=protected-access
|
2019-10-12 19:45:11 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud", "deactivate_vacation", blocking=True
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "deactivate_vacation"
|
|
|
|
assert home.mock_calls[-1][1] == ()
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 10 # pylint: disable=protected-access
|
2019-10-15 10:12:58 +00:00
|
|
|
|
|
|
|
not_existing_hap_id = "5555F7110000000000000001"
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"deactivate_vacation",
|
|
|
|
{"accesspoint_id": not_existing_hap_id},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert home.mock_calls[-1][0] == "deactivate_vacation"
|
|
|
|
assert home.mock_calls[-1][1] == ()
|
|
|
|
# There is no further call on connection.
|
2019-11-26 06:40:08 +00:00
|
|
|
assert len(home._connection.mock_calls) == 10 # pylint: disable=protected-access
|
2019-10-19 15:44:40 +00:00
|
|
|
|
|
|
|
|
2020-02-14 06:56:17 +00:00
|
|
|
async def test_hmip_heating_group_services(hass, default_mock_hap_factory):
|
2019-10-19 15:44:40 +00:00
|
|
|
"""Test HomematicipHeatingGroup services."""
|
|
|
|
entity_id = "climate.badezimmer"
|
|
|
|
entity_name = "Badezimmer"
|
|
|
|
device_model = None
|
2020-02-14 06:56:17 +00:00
|
|
|
mock_hap = await default_mock_hap_factory.async_get_mock_hap(
|
|
|
|
test_groups=[entity_name]
|
|
|
|
)
|
2019-10-19 15:44:40 +00:00
|
|
|
|
|
|
|
ha_state, hmip_device = get_and_check_entity_basics(
|
2020-02-14 06:56:17 +00:00
|
|
|
hass, mock_hap, entity_id, entity_name, device_model
|
2019-10-19 15:44:40 +00:00
|
|
|
)
|
|
|
|
assert ha_state
|
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"set_active_climate_profile",
|
|
|
|
{"climate_profile_index": 2, "entity_id": "climate.badezimmer"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_active_profile"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == (1,)
|
2019-11-26 06:40:08 +00:00
|
|
|
assert (
|
|
|
|
len(hmip_device._connection.mock_calls) == 2 # pylint: disable=protected-access
|
|
|
|
)
|
2019-10-19 15:44:40 +00:00
|
|
|
|
|
|
|
await hass.services.async_call(
|
|
|
|
"homematicip_cloud",
|
|
|
|
"set_active_climate_profile",
|
|
|
|
{"climate_profile_index": 2, "entity_id": "all"},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
assert hmip_device.mock_calls[-1][0] == "set_active_profile"
|
|
|
|
assert hmip_device.mock_calls[-1][1] == (1,)
|
2019-11-26 06:40:08 +00:00
|
|
|
assert (
|
2020-02-14 06:56:17 +00:00
|
|
|
len(hmip_device._connection.mock_calls) == 4 # pylint: disable=protected-access
|
2019-11-26 06:40:08 +00:00
|
|
|
)
|