Add Airzone Cloud Aidoo HVAC indoor/outdoor sensors (#125013)
Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com>pull/125107/head
parent
f93259a2f1
commit
faefe624f6
|
@ -12,7 +12,16 @@ from aioairzone_cloud.const import (
|
||||||
AZD_AQ_PM_10,
|
AZD_AQ_PM_10,
|
||||||
AZD_CPU_USAGE,
|
AZD_CPU_USAGE,
|
||||||
AZD_HUMIDITY,
|
AZD_HUMIDITY,
|
||||||
|
AZD_INDOOR_EXCHANGER_TEMP,
|
||||||
|
AZD_INDOOR_RETURN_TEMP,
|
||||||
|
AZD_INDOOR_WORK_TEMP,
|
||||||
AZD_MEMORY_FREE,
|
AZD_MEMORY_FREE,
|
||||||
|
AZD_OUTDOOR_CONDENSER_PRESS,
|
||||||
|
AZD_OUTDOOR_DISCHARGE_TEMP,
|
||||||
|
AZD_OUTDOOR_ELECTRIC_CURRENT,
|
||||||
|
AZD_OUTDOOR_EVAPORATOR_PRESS,
|
||||||
|
AZD_OUTDOOR_EXCHANGER_TEMP,
|
||||||
|
AZD_OUTDOOR_TEMP,
|
||||||
AZD_TEMP,
|
AZD_TEMP,
|
||||||
AZD_THERMOSTAT_BATTERY,
|
AZD_THERMOSTAT_BATTERY,
|
||||||
AZD_THERMOSTAT_COVERAGE,
|
AZD_THERMOSTAT_COVERAGE,
|
||||||
|
@ -32,7 +41,9 @@ from homeassistant.const import (
|
||||||
PERCENTAGE,
|
PERCENTAGE,
|
||||||
SIGNAL_STRENGTH_DECIBELS_MILLIWATT,
|
SIGNAL_STRENGTH_DECIBELS_MILLIWATT,
|
||||||
EntityCategory,
|
EntityCategory,
|
||||||
|
UnitOfElectricCurrent,
|
||||||
UnitOfInformation,
|
UnitOfInformation,
|
||||||
|
UnitOfPressure,
|
||||||
UnitOfTemperature,
|
UnitOfTemperature,
|
||||||
)
|
)
|
||||||
from homeassistant.core import HomeAssistant, callback
|
from homeassistant.core import HomeAssistant, callback
|
||||||
|
@ -48,6 +59,78 @@ from .entity import (
|
||||||
)
|
)
|
||||||
|
|
||||||
AIDOO_SENSOR_TYPES: Final[tuple[SensorEntityDescription, ...]] = (
|
AIDOO_SENSOR_TYPES: Final[tuple[SensorEntityDescription, ...]] = (
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_INDOOR_EXCHANGER_TEMP,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="indoor_exchanger_temp",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_INDOOR_RETURN_TEMP,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="indoor_return_temp",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_INDOOR_WORK_TEMP,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="indoor_work_temp",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_OUTDOOR_CONDENSER_PRESS,
|
||||||
|
native_unit_of_measurement=UnitOfPressure.KPA,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="outdoor_condenser_press",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_OUTDOOR_DISCHARGE_TEMP,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="outdoor_discharge_temp",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_OUTDOOR_ELECTRIC_CURRENT,
|
||||||
|
native_unit_of_measurement=UnitOfElectricCurrent.AMPERE,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="outdoor_electric_current",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_OUTDOOR_EVAPORATOR_PRESS,
|
||||||
|
native_unit_of_measurement=UnitOfPressure.KPA,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="outdoor_evaporator_press",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_OUTDOOR_EXCHANGER_TEMP,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="outdoor_exchanger_temp",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
|
entity_registry_enabled_default=False,
|
||||||
|
key=AZD_OUTDOOR_TEMP,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="outdoor_temp",
|
||||||
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
key=AZD_TEMP,
|
key=AZD_TEMP,
|
||||||
|
|
|
@ -45,6 +45,33 @@
|
||||||
"free_memory": {
|
"free_memory": {
|
||||||
"name": "Free memory"
|
"name": "Free memory"
|
||||||
},
|
},
|
||||||
|
"indoor_exchanger_temp": {
|
||||||
|
"name": "Indoor exchanger temperature"
|
||||||
|
},
|
||||||
|
"indoor_return_temp": {
|
||||||
|
"name": "Indoor return temperature"
|
||||||
|
},
|
||||||
|
"indoor_work_temp": {
|
||||||
|
"name": "Indoor working temperature"
|
||||||
|
},
|
||||||
|
"outdoor_condenser_press": {
|
||||||
|
"name": "Outdoor condenser pressure"
|
||||||
|
},
|
||||||
|
"outdoor_discharge_temp": {
|
||||||
|
"name": "Outdoor discharge temperature"
|
||||||
|
},
|
||||||
|
"outdoor_electric_current": {
|
||||||
|
"name": "Outdoor electric current"
|
||||||
|
},
|
||||||
|
"outdoor_evaporator_press": {
|
||||||
|
"name": "Outdoor evaporator pressure"
|
||||||
|
},
|
||||||
|
"outdoor_exchanger_temp": {
|
||||||
|
"name": "Outdoor exchanger temperature"
|
||||||
|
},
|
||||||
|
"outdoor_temp": {
|
||||||
|
"name": "Outdoor temperature"
|
||||||
|
},
|
||||||
"thermostat_coverage": {
|
"thermostat_coverage": {
|
||||||
"name": "Signal percentage"
|
"name": "Signal percentage"
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,33 @@ async def test_airzone_create_sensors(hass: HomeAssistant) -> None:
|
||||||
state = hass.states.get("sensor.bron_pro_temperature")
|
state = hass.states.get("sensor.bron_pro_temperature")
|
||||||
assert state.state == "20.0"
|
assert state.state == "20.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_indoor_exchanger_temperature")
|
||||||
|
assert state.state == "26.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_indoor_return_temperature")
|
||||||
|
assert state.state == "26.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_indoor_working_temperature")
|
||||||
|
assert state.state == "25.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_outdoor_condenser_pressure")
|
||||||
|
assert state.state == "150.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_outdoor_discharge_temperature")
|
||||||
|
assert state.state == "121.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_outdoor_electric_current")
|
||||||
|
assert state.state == "3.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_outdoor_evaporator_pressure")
|
||||||
|
assert state.state == "20.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_outdoor_exchanger_temperature")
|
||||||
|
assert state.state == "-25.0"
|
||||||
|
|
||||||
|
state = hass.states.get("sensor.bron_pro_outdoor_temperature")
|
||||||
|
assert state.state == "29.0"
|
||||||
|
|
||||||
# WebServers
|
# WebServers
|
||||||
state = hass.states.get("sensor.webserver_11_22_33_44_55_66_cpu_usage")
|
state = hass.states.get("sensor.webserver_11_22_33_44_55_66_cpu_usage")
|
||||||
assert state.state == "32"
|
assert state.state == "32"
|
||||||
|
|
Loading…
Reference in New Issue