Skip to content
This repository has been archived by the owner on Dec 21, 2023. It is now read-only.

Commit

Permalink
Fix/160 core 300 s automation broken (#163)
Browse files Browse the repository at this point in the history
* only accept numbers for AQI sensor

* fix syntax error and update style.

* add an air quality value sensor

* add empty unit of measurement.

* fix validate
  • Loading branch information
vlebourl authored Sep 14, 2023
1 parent 9c7a779 commit b54a839
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 18 deletions.
13 changes: 4 additions & 9 deletions .github/workflows/validate.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
name: Validate
name: Validate with hassfest

on:
push:
pull_request:
schedule:
- cron: "0 0 * * *"
Expand All @@ -9,11 +10,5 @@ jobs:
validate:
runs-on: "ubuntu-latest"
steps:
- uses: "actions/[email protected]"
- name: HACS validation
uses: "hacs/[email protected]"
with:
ignore: "brands"
category: "integration"
comment: false

- uses: "actions/checkout@v3"
- uses: home-assistant/actions/hassfest@master
70 changes: 61 additions & 9 deletions custom_components/vesync/sensor.py
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,8 @@ def _setup_entities(devices, async_add_entities, coordinator):
entities.append(VeSyncHumiditySensor(dev, coordinator))
if has_feature(dev, "details", "air_quality"):
entities.append(VeSyncAirQualitySensor(dev, coordinator))
if has_feature(dev, "details", "air_quality_value"):
entities.append(VeSyncAirQualityValueSensor(dev, coordinator))
if has_feature(dev, "details", "filter_life"):
entities.append(VeSyncFilterLifeSensor(dev, coordinator))

Expand Down Expand Up @@ -185,11 +187,19 @@ class VeSyncAirQualitySensor(VeSyncHumidifierSensorEntity):
"""Representation of an air quality sensor."""

_attr_state_class = SensorStateClass.MEASUREMENT
_attr_device_class = SensorDeviceClass.AQI
_attr_native_unit_of_measurement = " "

def __init__(self, plug, coordinator):
"""Initialize the VeSync outlet device."""
super().__init__(plug, coordinator)
def __init__(self, device, coordinator):
"""Initialize the VeSync device."""
super().__init__(device, coordinator)
self._numeric_quality = None
if self.native_value is not None:
self._numeric_quality = isinstance(self.native_value, (int, float))

@property
def device_class(self):
"""Return the air quality device class."""
return SensorDeviceClass.AQI if self._numeric_quality else None

@property
def unique_id(self):
Expand All @@ -204,12 +214,54 @@ def name(self):
@property
def native_value(self):
"""Return the air quality index."""
quality = None
if has_feature(self.smarthumidifier, "details", "air_quality_value"):
quality = self.smarthumidifier.details["air_quality_value"]
elif has_feature(self.smarthumidifier, "details", "air_quality"):
if has_feature(self.smarthumidifier, "details", "air_quality"):
quality = self.smarthumidifier.details["air_quality"]
return quality.capitalize() if isinstance(quality, str) else quality
if isinstance(quality, (int, float)):
return quality
_LOGGER.warn(
"Got non numeric value for AQI sensor from 'air_quality' for %s: %s",
self.name,
quality,
)
_LOGGER.warn("No air quality index found in '%s'", self.name)
return None


class VeSyncAirQualityValueSensor(VeSyncHumidifierSensorEntity):
"""Representation of an air quality sensor."""

_attr_state_class = SensorStateClass.MEASUREMENT
_attr_device_class = SensorDeviceClass.AQI
_attr_native_unit_of_measurement = " "

def __init__(self, device, coordinator):
"""Initialize the VeSync device."""
super().__init__(device, coordinator)

@property
def unique_id(self):
"""Return unique ID for air quality sensor on device."""
return f"{super().unique_id}-air-quality-value"

@property
def name(self):
"""Return sensor name."""
return f"{super().name} air quality value"

@property
def native_value(self):
"""Return the air quality index."""
if has_feature(self.smarthumidifier, "details", "air_quality_value"):
quality_value = self.smarthumidifier.details["air_quality_value"]
if isinstance(quality_value, (int, float)):
return quality_value
_LOGGER.warn(
"Got non numeric value for AQI sensor from 'air_quality_value' for %s: %s",
self.name,
quality_value,
)
_LOGGER.warn("No air quality value found in '%s'", self.name)
return None


class VeSyncFilterLifeSensor(VeSyncHumidifierSensorEntity):
Expand Down

0 comments on commit b54a839

Please sign in to comment.