Add aircleaner and humidify service to nexia climate (#33078)
* Add aircleaner and humidify service to nexia climate * These were removed from the original merge to reduce review scope * Additional tests for binary_sensor, sensor, and climate states * Switch to signals for services Get rid of everywhere we call device and change to zone or thermostat as it was too confusing Renames to make it clear that zone and thermostat are tightly coupled * Make scene activation responsive * no need to use update for only one key/value * stray comma * use async_call_later * its async, need ()s * cleaner * merge entity platform services testing branch
This commit is contained in:
parent
0e3dc7976c
commit
b8fdebd05c
13 changed files with 575 additions and 291 deletions
|
@ -43,3 +43,38 @@ async def test_climate_zones(hass):
|
|||
assert all(
|
||||
state.attributes[key] == expected_attributes[key] for key in expected_attributes
|
||||
)
|
||||
|
||||
state = hass.states.get("climate.kitchen")
|
||||
assert state.state == HVAC_MODE_HEAT_COOL
|
||||
|
||||
expected_attributes = {
|
||||
"attribution": "Data provided by mynexia.com",
|
||||
"current_humidity": 36.0,
|
||||
"current_temperature": 25.0,
|
||||
"dehumidify_setpoint": 50.0,
|
||||
"dehumidify_supported": True,
|
||||
"fan_mode": "auto",
|
||||
"fan_modes": ["auto", "on", "circulate"],
|
||||
"friendly_name": "Kitchen",
|
||||
"humidify_supported": False,
|
||||
"humidity": 50.0,
|
||||
"hvac_action": "idle",
|
||||
"hvac_modes": ["off", "auto", "heat_cool", "heat", "cool"],
|
||||
"max_humidity": 65.0,
|
||||
"max_temp": 37.2,
|
||||
"min_humidity": 35.0,
|
||||
"min_temp": 12.8,
|
||||
"preset_mode": "None",
|
||||
"preset_modes": ["None", "Home", "Away", "Sleep"],
|
||||
"supported_features": 31,
|
||||
"target_temp_high": 26.1,
|
||||
"target_temp_low": 17.2,
|
||||
"target_temp_step": 1.0,
|
||||
"temperature": None,
|
||||
"zone_status": "",
|
||||
}
|
||||
# Only test for a subset of attributes in case
|
||||
# HA changes the implementation and a new one appears
|
||||
assert all(
|
||||
state.attributes[key] == expected_attributes[key] for key in expected_attributes
|
||||
)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue