mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 21:27:38 +00:00
Add SmartThings climate support for Air Conditioners (#21840)
* Add support for Samsung Air Conditioners to Climate * Changes per review feedback. * Fix py3.5 compat list sorting in test
This commit is contained in:
parent
2d2abc7831
commit
c927cd9c14
@ -7,9 +7,10 @@ from homeassistant.components.climate import (
|
|||||||
DOMAIN as CLIMATE_DOMAIN, ClimateDevice)
|
DOMAIN as CLIMATE_DOMAIN, ClimateDevice)
|
||||||
from homeassistant.components.climate.const import (
|
from homeassistant.components.climate.const import (
|
||||||
ATTR_OPERATION_MODE, ATTR_TARGET_TEMP_HIGH, ATTR_TARGET_TEMP_LOW,
|
ATTR_OPERATION_MODE, ATTR_TARGET_TEMP_HIGH, ATTR_TARGET_TEMP_LOW,
|
||||||
STATE_AUTO, STATE_COOL, STATE_ECO, STATE_HEAT, SUPPORT_FAN_MODE,
|
STATE_AUTO, STATE_COOL, STATE_DRY, STATE_ECO, STATE_FAN_ONLY, STATE_HEAT,
|
||||||
SUPPORT_OPERATION_MODE, SUPPORT_TARGET_TEMPERATURE,
|
SUPPORT_FAN_MODE, SUPPORT_ON_OFF, SUPPORT_OPERATION_MODE,
|
||||||
SUPPORT_TARGET_TEMPERATURE_HIGH, SUPPORT_TARGET_TEMPERATURE_LOW)
|
SUPPORT_TARGET_TEMPERATURE, SUPPORT_TARGET_TEMPERATURE_HIGH,
|
||||||
|
SUPPORT_TARGET_TEMPERATURE_LOW)
|
||||||
from homeassistant.const import (
|
from homeassistant.const import (
|
||||||
ATTR_TEMPERATURE, STATE_OFF, TEMP_CELSIUS, TEMP_FAHRENHEIT)
|
ATTR_TEMPERATURE, STATE_OFF, TEMP_CELSIUS, TEMP_FAHRENHEIT)
|
||||||
|
|
||||||
@ -35,6 +36,25 @@ STATE_TO_MODE = {
|
|||||||
STATE_HEAT: 'heat',
|
STATE_HEAT: 'heat',
|
||||||
STATE_OFF: 'off'
|
STATE_OFF: 'off'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AC_MODE_TO_STATE = {
|
||||||
|
'auto': STATE_AUTO,
|
||||||
|
'cool': STATE_COOL,
|
||||||
|
'dry': STATE_DRY,
|
||||||
|
'heat': STATE_HEAT,
|
||||||
|
'fanOnly': STATE_FAN_ONLY
|
||||||
|
}
|
||||||
|
STATE_TO_AC_MODE = {v: k for k, v in AC_MODE_TO_STATE.items()}
|
||||||
|
|
||||||
|
SPEED_TO_FAN_MODE = {
|
||||||
|
0: 'auto',
|
||||||
|
1: 'low',
|
||||||
|
2: 'medium',
|
||||||
|
3: 'high',
|
||||||
|
4: 'turbo'
|
||||||
|
}
|
||||||
|
FAN_MODE_TO_SPEED = {v: k for k, v in SPEED_TO_FAN_MODE.items()}
|
||||||
|
|
||||||
UNIT_MAP = {
|
UNIT_MAP = {
|
||||||
'C': TEMP_CELSIUS,
|
'C': TEMP_CELSIUS,
|
||||||
'F': TEMP_FAHRENHEIT
|
'F': TEMP_FAHRENHEIT
|
||||||
@ -51,10 +71,26 @@ async def async_setup_platform(
|
|||||||
|
|
||||||
async def async_setup_entry(hass, config_entry, async_add_entities):
|
async def async_setup_entry(hass, config_entry, async_add_entities):
|
||||||
"""Add climate entities for a config entry."""
|
"""Add climate entities for a config entry."""
|
||||||
|
from pysmartthings import Capability
|
||||||
|
|
||||||
|
ac_capabilities = [
|
||||||
|
Capability.air_conditioner_mode,
|
||||||
|
Capability.fan_speed,
|
||||||
|
Capability.switch,
|
||||||
|
Capability.temperature_measurement,
|
||||||
|
Capability.thermostat_cooling_setpoint]
|
||||||
|
|
||||||
broker = hass.data[DOMAIN][DATA_BROKERS][config_entry.entry_id]
|
broker = hass.data[DOMAIN][DATA_BROKERS][config_entry.entry_id]
|
||||||
async_add_entities(
|
entities = []
|
||||||
[SmartThingsThermostat(device) for device in broker.devices.values()
|
for device in broker.devices.values():
|
||||||
if broker.any_assigned(device.device_id, CLIMATE_DOMAIN)], True)
|
if not broker.any_assigned(device.device_id, CLIMATE_DOMAIN):
|
||||||
|
continue
|
||||||
|
if all(capability in device.capabilities
|
||||||
|
for capability in ac_capabilities):
|
||||||
|
entities.append(SmartThingsAirConditioner(device))
|
||||||
|
else:
|
||||||
|
entities.append(SmartThingsThermostat(device))
|
||||||
|
async_add_entities(entities, True)
|
||||||
|
|
||||||
|
|
||||||
def get_capabilities(capabilities: Sequence[str]) -> Optional[Sequence[str]]:
|
def get_capabilities(capabilities: Sequence[str]) -> Optional[Sequence[str]]:
|
||||||
@ -62,28 +98,41 @@ def get_capabilities(capabilities: Sequence[str]) -> Optional[Sequence[str]]:
|
|||||||
from pysmartthings import Capability
|
from pysmartthings import Capability
|
||||||
|
|
||||||
supported = [
|
supported = [
|
||||||
Capability.thermostat,
|
Capability.air_conditioner_mode,
|
||||||
|
Capability.demand_response_load_control,
|
||||||
|
Capability.fan_speed,
|
||||||
|
Capability.power_consumption_report,
|
||||||
|
Capability.relative_humidity_measurement,
|
||||||
|
Capability.switch,
|
||||||
Capability.temperature_measurement,
|
Capability.temperature_measurement,
|
||||||
|
Capability.thermostat,
|
||||||
Capability.thermostat_cooling_setpoint,
|
Capability.thermostat_cooling_setpoint,
|
||||||
|
Capability.thermostat_fan_mode,
|
||||||
Capability.thermostat_heating_setpoint,
|
Capability.thermostat_heating_setpoint,
|
||||||
Capability.thermostat_mode,
|
Capability.thermostat_mode,
|
||||||
Capability.relative_humidity_measurement,
|
Capability.thermostat_operating_state]
|
||||||
Capability.thermostat_operating_state,
|
|
||||||
Capability.thermostat_fan_mode
|
|
||||||
]
|
|
||||||
# Can have this legacy/deprecated capability
|
# Can have this legacy/deprecated capability
|
||||||
if Capability.thermostat in capabilities:
|
if Capability.thermostat in capabilities:
|
||||||
return supported
|
return supported
|
||||||
# Or must have all of these
|
# Or must have all of these thermostat capabilities
|
||||||
climate_capabilities = [
|
thermostat_capabilities = [
|
||||||
Capability.temperature_measurement,
|
Capability.temperature_measurement,
|
||||||
Capability.thermostat_cooling_setpoint,
|
Capability.thermostat_cooling_setpoint,
|
||||||
Capability.thermostat_heating_setpoint,
|
Capability.thermostat_heating_setpoint,
|
||||||
Capability.thermostat_mode]
|
Capability.thermostat_mode]
|
||||||
if all(capability in capabilities
|
if all(capability in capabilities
|
||||||
for capability in climate_capabilities):
|
for capability in thermostat_capabilities):
|
||||||
|
return supported
|
||||||
|
# Or must have all of these A/C capabilities
|
||||||
|
ac_capabilities = [
|
||||||
|
Capability.air_conditioner_mode,
|
||||||
|
Capability.fan_speed,
|
||||||
|
Capability.switch,
|
||||||
|
Capability.temperature_measurement,
|
||||||
|
Capability.thermostat_cooling_setpoint]
|
||||||
|
if all(capability in capabilities
|
||||||
|
for capability in ac_capabilities):
|
||||||
return supported
|
return supported
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
@ -254,5 +303,128 @@ class SmartThingsThermostat(SmartThingsEntity, ClimateDevice):
|
|||||||
@property
|
@property
|
||||||
def temperature_unit(self):
|
def temperature_unit(self):
|
||||||
"""Return the unit of measurement."""
|
"""Return the unit of measurement."""
|
||||||
|
from pysmartthings import Attribute
|
||||||
return UNIT_MAP.get(
|
return UNIT_MAP.get(
|
||||||
self._device.status.attributes['temperature'].unit)
|
self._device.status.attributes[Attribute.temperature].unit)
|
||||||
|
|
||||||
|
|
||||||
|
class SmartThingsAirConditioner(SmartThingsEntity, ClimateDevice):
|
||||||
|
"""Define a SmartThings Air Conditioner."""
|
||||||
|
|
||||||
|
async def async_set_fan_mode(self, fan_mode):
|
||||||
|
"""Set new target fan mode."""
|
||||||
|
await self._device.set_fan_speed(
|
||||||
|
FAN_MODE_TO_SPEED[fan_mode], set_status=True)
|
||||||
|
# State is set optimistically in the command above, therefore update
|
||||||
|
# the entity state ahead of receiving the confirming push updates
|
||||||
|
self.async_schedule_update_ha_state()
|
||||||
|
|
||||||
|
async def async_set_operation_mode(self, operation_mode):
|
||||||
|
"""Set new target operation mode."""
|
||||||
|
await self._device.set_air_conditioner_mode(
|
||||||
|
STATE_TO_AC_MODE[operation_mode], set_status=True)
|
||||||
|
# State is set optimistically in the command above, therefore update
|
||||||
|
# the entity state ahead of receiving the confirming push updates
|
||||||
|
self.async_schedule_update_ha_state()
|
||||||
|
|
||||||
|
async def async_set_temperature(self, **kwargs):
|
||||||
|
"""Set new target temperature."""
|
||||||
|
tasks = []
|
||||||
|
# operation mode
|
||||||
|
operation_mode = kwargs.get(ATTR_OPERATION_MODE)
|
||||||
|
if operation_mode:
|
||||||
|
tasks.append(self.async_set_operation_mode(operation_mode))
|
||||||
|
# temperature
|
||||||
|
tasks.append(self._device.set_cooling_setpoint(
|
||||||
|
kwargs[ATTR_TEMPERATURE], set_status=True))
|
||||||
|
await asyncio.gather(*tasks)
|
||||||
|
# State is set optimistically in the command above, therefore update
|
||||||
|
# the entity state ahead of receiving the confirming push updates
|
||||||
|
self.async_schedule_update_ha_state()
|
||||||
|
|
||||||
|
async def async_turn_on(self):
|
||||||
|
"""Turn device on."""
|
||||||
|
await self._device.switch_on(set_status=True)
|
||||||
|
# State is set optimistically in the command above, therefore update
|
||||||
|
# the entity state ahead of receiving the confirming push updates
|
||||||
|
self.async_schedule_update_ha_state()
|
||||||
|
|
||||||
|
async def async_turn_off(self):
|
||||||
|
"""Turn device off."""
|
||||||
|
await self._device.switch_off(set_status=True)
|
||||||
|
# State is set optimistically in the command above, therefore update
|
||||||
|
# the entity state ahead of receiving the confirming push updates
|
||||||
|
self.async_schedule_update_ha_state()
|
||||||
|
|
||||||
|
@property
|
||||||
|
def current_fan_mode(self):
|
||||||
|
"""Return the fan setting."""
|
||||||
|
return SPEED_TO_FAN_MODE.get(self._device.status.fan_speed)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def current_operation(self):
|
||||||
|
"""Return current operation ie. heat, cool, idle."""
|
||||||
|
return AC_MODE_TO_STATE.get(self._device.status.air_conditioner_mode)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def current_temperature(self):
|
||||||
|
"""Return the current temperature."""
|
||||||
|
return self._device.status.temperature
|
||||||
|
|
||||||
|
@property
|
||||||
|
def device_state_attributes(self):
|
||||||
|
"""
|
||||||
|
Return device specific state attributes.
|
||||||
|
|
||||||
|
Include attributes from the Demand Response Load Control (drlc)
|
||||||
|
and Power Consumption capabilities.
|
||||||
|
"""
|
||||||
|
attributes = [
|
||||||
|
'drlc_status_duration',
|
||||||
|
'drlc_status_level',
|
||||||
|
'drlc_status_start',
|
||||||
|
'drlc_status_override',
|
||||||
|
'power_consumption_start',
|
||||||
|
'power_consumption_power',
|
||||||
|
'power_consumption_energy',
|
||||||
|
'power_consumption_end'
|
||||||
|
]
|
||||||
|
state_attributes = {}
|
||||||
|
for attribute in attributes:
|
||||||
|
value = getattr(self._device.status, attribute)
|
||||||
|
if value is not None:
|
||||||
|
state_attributes[attribute] = value
|
||||||
|
return state_attributes
|
||||||
|
|
||||||
|
@property
|
||||||
|
def fan_list(self):
|
||||||
|
"""Return the list of available fan modes."""
|
||||||
|
return list(FAN_MODE_TO_SPEED)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def is_on(self):
|
||||||
|
"""Return true if on."""
|
||||||
|
return self._device.status.switch
|
||||||
|
|
||||||
|
@property
|
||||||
|
def operation_list(self):
|
||||||
|
"""Return the list of available operation modes."""
|
||||||
|
return list(STATE_TO_AC_MODE)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def supported_features(self):
|
||||||
|
"""Return the supported features."""
|
||||||
|
return SUPPORT_OPERATION_MODE | SUPPORT_TARGET_TEMPERATURE \
|
||||||
|
| SUPPORT_FAN_MODE | SUPPORT_ON_OFF
|
||||||
|
|
||||||
|
@property
|
||||||
|
def target_temperature(self):
|
||||||
|
"""Return the temperature we try to reach."""
|
||||||
|
return self._device.status.cooling_setpoint
|
||||||
|
|
||||||
|
@property
|
||||||
|
def temperature_unit(self):
|
||||||
|
"""Return the unit of measurement."""
|
||||||
|
from pysmartthings import Attribute
|
||||||
|
return UNIT_MAP.get(
|
||||||
|
self._device.status.attributes[Attribute.temperature].unit)
|
||||||
|
@ -13,14 +13,15 @@ from homeassistant.components.climate.const import (
|
|||||||
ATTR_FAN_MODE, ATTR_OPERATION_LIST, ATTR_OPERATION_MODE,
|
ATTR_FAN_MODE, ATTR_OPERATION_LIST, ATTR_OPERATION_MODE,
|
||||||
ATTR_TARGET_TEMP_HIGH, ATTR_TARGET_TEMP_LOW, DOMAIN as CLIMATE_DOMAIN,
|
ATTR_TARGET_TEMP_HIGH, ATTR_TARGET_TEMP_LOW, DOMAIN as CLIMATE_DOMAIN,
|
||||||
SERVICE_SET_FAN_MODE, SERVICE_SET_OPERATION_MODE, SERVICE_SET_TEMPERATURE,
|
SERVICE_SET_FAN_MODE, SERVICE_SET_OPERATION_MODE, SERVICE_SET_TEMPERATURE,
|
||||||
STATE_AUTO, STATE_COOL, STATE_ECO, STATE_HEAT, SUPPORT_FAN_MODE,
|
STATE_AUTO, STATE_COOL, STATE_DRY, STATE_ECO, STATE_FAN_ONLY, STATE_HEAT,
|
||||||
SUPPORT_OPERATION_MODE, SUPPORT_TARGET_TEMPERATURE,
|
SUPPORT_FAN_MODE, SUPPORT_ON_OFF, SUPPORT_OPERATION_MODE,
|
||||||
SUPPORT_TARGET_TEMPERATURE_HIGH, SUPPORT_TARGET_TEMPERATURE_LOW)
|
SUPPORT_TARGET_TEMPERATURE, SUPPORT_TARGET_TEMPERATURE_HIGH,
|
||||||
|
SUPPORT_TARGET_TEMPERATURE_LOW)
|
||||||
from homeassistant.components.smartthings import climate
|
from homeassistant.components.smartthings import climate
|
||||||
from homeassistant.components.smartthings.const import DOMAIN
|
from homeassistant.components.smartthings.const import DOMAIN
|
||||||
from homeassistant.const import (
|
from homeassistant.const import (
|
||||||
ATTR_ENTITY_ID, ATTR_SUPPORTED_FEATURES, ATTR_TEMPERATURE, STATE_OFF,
|
ATTR_ENTITY_ID, ATTR_SUPPORTED_FEATURES, ATTR_TEMPERATURE,
|
||||||
STATE_UNKNOWN)
|
SERVICE_TURN_OFF, SERVICE_TURN_ON, STATE_OFF, STATE_UNKNOWN)
|
||||||
|
|
||||||
from .conftest import setup_platform
|
from .conftest import setup_platform
|
||||||
|
|
||||||
@ -115,6 +116,41 @@ def buggy_thermostat_fixture(device_factory):
|
|||||||
return device
|
return device
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(name="air_conditioner")
|
||||||
|
def air_conditioner_fixture(device_factory):
|
||||||
|
"""Fixture returns a air conditioner."""
|
||||||
|
device = device_factory(
|
||||||
|
"Air Conditioner",
|
||||||
|
capabilities=[
|
||||||
|
Capability.air_conditioner_mode,
|
||||||
|
Capability.demand_response_load_control,
|
||||||
|
Capability.fan_speed,
|
||||||
|
Capability.power_consumption_report,
|
||||||
|
Capability.switch,
|
||||||
|
Capability.temperature_measurement,
|
||||||
|
Capability.thermostat_cooling_setpoint],
|
||||||
|
status={
|
||||||
|
Attribute.air_conditioner_mode: 'auto',
|
||||||
|
Attribute.drlc_status: {
|
||||||
|
"duration": 0,
|
||||||
|
"drlcLevel": -1,
|
||||||
|
"start": "1970-01-01T00:00:00Z",
|
||||||
|
"override": False
|
||||||
|
},
|
||||||
|
Attribute.fan_speed: 2,
|
||||||
|
Attribute.power_consumption: {
|
||||||
|
"start": "2019-02-24T21:03:04Z",
|
||||||
|
"power": 0,
|
||||||
|
"energy": 500,
|
||||||
|
"end": "2019-02-26T02:05:55Z"
|
||||||
|
},
|
||||||
|
Attribute.switch: 'on',
|
||||||
|
Attribute.cooling_setpoint: 23}
|
||||||
|
)
|
||||||
|
device.status.attributes[Attribute.temperature] = Status(24, 'C', None)
|
||||||
|
return device
|
||||||
|
|
||||||
|
|
||||||
async def test_async_setup_platform():
|
async def test_async_setup_platform():
|
||||||
"""Test setup platform does nothing (it uses config entries)."""
|
"""Test setup platform does nothing (it uses config entries)."""
|
||||||
await climate.async_setup_platform(None, None, None)
|
await climate.async_setup_platform(None, None, None)
|
||||||
@ -195,28 +231,61 @@ async def test_buggy_thermostat_invalid_mode(hass, buggy_thermostat):
|
|||||||
assert state.attributes[ATTR_OPERATION_LIST] == {'heat'}
|
assert state.attributes[ATTR_OPERATION_LIST] == {'heat'}
|
||||||
|
|
||||||
|
|
||||||
async def test_set_fan_mode(hass, thermostat):
|
async def test_air_conditioner_entity_state(hass, air_conditioner):
|
||||||
|
"""Tests when an invalid operation mode is included."""
|
||||||
|
await setup_platform(hass, CLIMATE_DOMAIN, devices=[air_conditioner])
|
||||||
|
state = hass.states.get('climate.air_conditioner')
|
||||||
|
assert state.state == STATE_AUTO
|
||||||
|
assert state.attributes[ATTR_SUPPORTED_FEATURES] == \
|
||||||
|
SUPPORT_OPERATION_MODE | SUPPORT_FAN_MODE | \
|
||||||
|
SUPPORT_TARGET_TEMPERATURE | SUPPORT_ON_OFF
|
||||||
|
assert sorted(state.attributes[ATTR_OPERATION_LIST]) == [
|
||||||
|
STATE_AUTO, STATE_COOL, STATE_DRY, STATE_FAN_ONLY, STATE_HEAT]
|
||||||
|
assert state.attributes[ATTR_FAN_MODE] == 'medium'
|
||||||
|
assert sorted(state.attributes[ATTR_FAN_LIST]) == \
|
||||||
|
['auto', 'high', 'low', 'medium', 'turbo']
|
||||||
|
assert state.attributes[ATTR_TEMPERATURE] == 23
|
||||||
|
assert state.attributes[ATTR_CURRENT_TEMPERATURE] == 24
|
||||||
|
assert state.attributes['drlc_status_duration'] == 0
|
||||||
|
assert state.attributes['drlc_status_level'] == -1
|
||||||
|
assert state.attributes['drlc_status_start'] == '1970-01-01T00:00:00Z'
|
||||||
|
assert state.attributes['drlc_status_override'] is False
|
||||||
|
assert state.attributes['power_consumption_start'] == \
|
||||||
|
'2019-02-24T21:03:04Z'
|
||||||
|
assert state.attributes['power_consumption_power'] == 0
|
||||||
|
assert state.attributes['power_consumption_energy'] == 500
|
||||||
|
assert state.attributes['power_consumption_end'] == '2019-02-26T02:05:55Z'
|
||||||
|
|
||||||
|
|
||||||
|
async def test_set_fan_mode(hass, thermostat, air_conditioner):
|
||||||
"""Test the fan mode is set successfully."""
|
"""Test the fan mode is set successfully."""
|
||||||
await setup_platform(hass, CLIMATE_DOMAIN, devices=[thermostat])
|
await setup_platform(hass, CLIMATE_DOMAIN,
|
||||||
|
devices=[thermostat, air_conditioner])
|
||||||
|
entity_ids = ['climate.thermostat', 'climate.air_conditioner']
|
||||||
await hass.services.async_call(
|
await hass.services.async_call(
|
||||||
CLIMATE_DOMAIN, SERVICE_SET_FAN_MODE, {
|
CLIMATE_DOMAIN, SERVICE_SET_FAN_MODE, {
|
||||||
ATTR_ENTITY_ID: 'climate.thermostat',
|
ATTR_ENTITY_ID: entity_ids,
|
||||||
ATTR_FAN_MODE: 'auto'},
|
ATTR_FAN_MODE: 'auto'},
|
||||||
blocking=True)
|
blocking=True)
|
||||||
state = hass.states.get('climate.thermostat')
|
for entity_id in entity_ids:
|
||||||
assert state.attributes[ATTR_FAN_MODE] == 'auto'
|
state = hass.states.get(entity_id)
|
||||||
|
assert state.attributes[ATTR_FAN_MODE] == 'auto', entity_id
|
||||||
|
|
||||||
|
|
||||||
async def test_set_operation_mode(hass, thermostat):
|
async def test_set_operation_mode(hass, thermostat, air_conditioner):
|
||||||
"""Test the operation mode is set successfully."""
|
"""Test the operation mode is set successfully."""
|
||||||
await setup_platform(hass, CLIMATE_DOMAIN, devices=[thermostat])
|
await setup_platform(hass, CLIMATE_DOMAIN,
|
||||||
|
devices=[thermostat, air_conditioner])
|
||||||
|
entity_ids = ['climate.thermostat', 'climate.air_conditioner']
|
||||||
await hass.services.async_call(
|
await hass.services.async_call(
|
||||||
CLIMATE_DOMAIN, SERVICE_SET_OPERATION_MODE, {
|
CLIMATE_DOMAIN, SERVICE_SET_OPERATION_MODE, {
|
||||||
ATTR_ENTITY_ID: 'climate.thermostat',
|
ATTR_ENTITY_ID: entity_ids,
|
||||||
ATTR_OPERATION_MODE: STATE_ECO},
|
ATTR_OPERATION_MODE: STATE_COOL},
|
||||||
blocking=True)
|
blocking=True)
|
||||||
state = hass.states.get('climate.thermostat')
|
|
||||||
assert state.state == STATE_ECO
|
for entity_id in entity_ids:
|
||||||
|
state = hass.states.get(entity_id)
|
||||||
|
assert state.state == STATE_COOL, entity_id
|
||||||
|
|
||||||
|
|
||||||
async def test_set_temperature_heat_mode(hass, thermostat):
|
async def test_set_temperature_heat_mode(hass, thermostat):
|
||||||
@ -262,6 +331,32 @@ async def test_set_temperature(hass, thermostat):
|
|||||||
assert state.attributes[ATTR_TARGET_TEMP_LOW] == 22.2
|
assert state.attributes[ATTR_TARGET_TEMP_LOW] == 22.2
|
||||||
|
|
||||||
|
|
||||||
|
async def test_set_temperature_ac(hass, air_conditioner):
|
||||||
|
"""Test the temperature is set successfully."""
|
||||||
|
await setup_platform(hass, CLIMATE_DOMAIN, devices=[air_conditioner])
|
||||||
|
await hass.services.async_call(
|
||||||
|
CLIMATE_DOMAIN, SERVICE_SET_TEMPERATURE, {
|
||||||
|
ATTR_ENTITY_ID: 'climate.air_conditioner',
|
||||||
|
ATTR_TEMPERATURE: 27},
|
||||||
|
blocking=True)
|
||||||
|
state = hass.states.get('climate.air_conditioner')
|
||||||
|
assert state.attributes[ATTR_TEMPERATURE] == 27
|
||||||
|
|
||||||
|
|
||||||
|
async def test_set_temperature_ac_with_mode(hass, air_conditioner):
|
||||||
|
"""Test the temperature is set successfully."""
|
||||||
|
await setup_platform(hass, CLIMATE_DOMAIN, devices=[air_conditioner])
|
||||||
|
await hass.services.async_call(
|
||||||
|
CLIMATE_DOMAIN, SERVICE_SET_TEMPERATURE, {
|
||||||
|
ATTR_ENTITY_ID: 'climate.air_conditioner',
|
||||||
|
ATTR_TEMPERATURE: 27,
|
||||||
|
ATTR_OPERATION_MODE: STATE_COOL},
|
||||||
|
blocking=True)
|
||||||
|
state = hass.states.get('climate.air_conditioner')
|
||||||
|
assert state.attributes[ATTR_TEMPERATURE] == 27
|
||||||
|
assert state.state == STATE_COOL
|
||||||
|
|
||||||
|
|
||||||
async def test_set_temperature_with_mode(hass, thermostat):
|
async def test_set_temperature_with_mode(hass, thermostat):
|
||||||
"""Test the temperature and mode is set successfully."""
|
"""Test the temperature and mode is set successfully."""
|
||||||
await setup_platform(hass, CLIMATE_DOMAIN, devices=[thermostat])
|
await setup_platform(hass, CLIMATE_DOMAIN, devices=[thermostat])
|
||||||
@ -278,6 +373,31 @@ async def test_set_temperature_with_mode(hass, thermostat):
|
|||||||
assert state.state == STATE_AUTO
|
assert state.state == STATE_AUTO
|
||||||
|
|
||||||
|
|
||||||
|
async def test_set_turn_off(hass, air_conditioner):
|
||||||
|
"""Test the a/c is turned off successfully."""
|
||||||
|
await setup_platform(hass, CLIMATE_DOMAIN, devices=[air_conditioner])
|
||||||
|
state = hass.states.get('climate.air_conditioner')
|
||||||
|
assert state.state == STATE_AUTO
|
||||||
|
await hass.services.async_call(
|
||||||
|
CLIMATE_DOMAIN, SERVICE_TURN_OFF,
|
||||||
|
blocking=True)
|
||||||
|
state = hass.states.get('climate.air_conditioner')
|
||||||
|
assert state.state == STATE_OFF
|
||||||
|
|
||||||
|
|
||||||
|
async def test_set_turn_on(hass, air_conditioner):
|
||||||
|
"""Test the a/c is turned on successfully."""
|
||||||
|
air_conditioner.status.update_attribute_value(Attribute.switch, 'off')
|
||||||
|
await setup_platform(hass, CLIMATE_DOMAIN, devices=[air_conditioner])
|
||||||
|
state = hass.states.get('climate.air_conditioner')
|
||||||
|
assert state.state == STATE_OFF
|
||||||
|
await hass.services.async_call(
|
||||||
|
CLIMATE_DOMAIN, SERVICE_TURN_ON,
|
||||||
|
blocking=True)
|
||||||
|
state = hass.states.get('climate.air_conditioner')
|
||||||
|
assert state.state == STATE_AUTO
|
||||||
|
|
||||||
|
|
||||||
async def test_entity_and_device_attributes(hass, thermostat):
|
async def test_entity_and_device_attributes(hass, thermostat):
|
||||||
"""Test the attributes of the entries are correct."""
|
"""Test the attributes of the entries are correct."""
|
||||||
await setup_platform(hass, CLIMATE_DOMAIN, devices=[thermostat])
|
await setup_platform(hass, CLIMATE_DOMAIN, devices=[thermostat])
|
||||||
|
Loading…
x
Reference in New Issue
Block a user