|
|
|
@@ -3,27 +3,18 @@
|
|
|
|
|
from datetime import timedelta
|
|
|
|
|
from unittest.mock import AsyncMock, Mock, patch
|
|
|
|
|
|
|
|
|
|
from freezegun.api import FrozenDateTimeFactory
|
|
|
|
|
from nettigo_air_monitor import ApiError
|
|
|
|
|
from syrupy import SnapshotAssertion
|
|
|
|
|
|
|
|
|
|
from homeassistant.components.nam.const import DOMAIN
|
|
|
|
|
from homeassistant.components.sensor import (
|
|
|
|
|
ATTR_OPTIONS,
|
|
|
|
|
ATTR_STATE_CLASS,
|
|
|
|
|
DOMAIN as SENSOR_DOMAIN,
|
|
|
|
|
SensorDeviceClass,
|
|
|
|
|
SensorStateClass,
|
|
|
|
|
)
|
|
|
|
|
from homeassistant.components.sensor import DOMAIN as SENSOR_DOMAIN, SensorDeviceClass
|
|
|
|
|
from homeassistant.const import (
|
|
|
|
|
ATTR_DEVICE_CLASS,
|
|
|
|
|
ATTR_ENTITY_ID,
|
|
|
|
|
ATTR_ICON,
|
|
|
|
|
ATTR_UNIT_OF_MEASUREMENT,
|
|
|
|
|
CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
|
|
|
|
CONCENTRATION_PARTS_PER_MILLION,
|
|
|
|
|
PERCENTAGE,
|
|
|
|
|
SIGNAL_STRENGTH_DECIBELS_MILLIWATT,
|
|
|
|
|
STATE_UNAVAILABLE,
|
|
|
|
|
UnitOfPressure,
|
|
|
|
|
Platform,
|
|
|
|
|
UnitOfTemperature,
|
|
|
|
|
)
|
|
|
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
@@ -31,447 +22,32 @@ from homeassistant.helpers import entity_registry as er
|
|
|
|
|
from homeassistant.setup import async_setup_component
|
|
|
|
|
from homeassistant.util.dt import utcnow
|
|
|
|
|
|
|
|
|
|
from . import INCOMPLETE_NAM_DATA, init_integration, nam_data
|
|
|
|
|
from . import INCOMPLETE_NAM_DATA, init_integration
|
|
|
|
|
|
|
|
|
|
from tests.common import async_fire_time_changed
|
|
|
|
|
from tests.common import async_fire_time_changed, load_json_object_fixture
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async def test_sensor(hass: HomeAssistant, entity_registry: er.EntityRegistry) -> None:
|
|
|
|
|
async def test_sensor(
|
|
|
|
|
hass: HomeAssistant,
|
|
|
|
|
entity_registry_enabled_by_default: None,
|
|
|
|
|
entity_registry: er.EntityRegistry,
|
|
|
|
|
snapshot: SnapshotAssertion,
|
|
|
|
|
freezer: FrozenDateTimeFactory,
|
|
|
|
|
) -> None:
|
|
|
|
|
"""Test states of the air_quality."""
|
|
|
|
|
entity_registry.async_get_or_create(
|
|
|
|
|
SENSOR_DOMAIN,
|
|
|
|
|
DOMAIN,
|
|
|
|
|
"aa:bb:cc:dd:ee:ff-signal",
|
|
|
|
|
suggested_object_id="nettigo_air_monitor_signal_strength",
|
|
|
|
|
disabled_by=None,
|
|
|
|
|
)
|
|
|
|
|
hass.config.set_time_zone("UTC")
|
|
|
|
|
freezer.move_to("2024-04-20 12:00:00+00:00")
|
|
|
|
|
|
|
|
|
|
entity_registry.async_get_or_create(
|
|
|
|
|
SENSOR_DOMAIN,
|
|
|
|
|
DOMAIN,
|
|
|
|
|
"aa:bb:cc:dd:ee:ff-uptime",
|
|
|
|
|
suggested_object_id="nettigo_air_monitor_uptime",
|
|
|
|
|
disabled_by=None,
|
|
|
|
|
)
|
|
|
|
|
with patch("homeassistant.components.nam.PLATFORMS", [Platform.SENSOR]):
|
|
|
|
|
entry = await init_integration(hass)
|
|
|
|
|
|
|
|
|
|
# Patch return value from utcnow, with offset to make sure the patch is correct
|
|
|
|
|
now = utcnow() - timedelta(hours=1)
|
|
|
|
|
with patch("homeassistant.components.nam.sensor.utcnow", return_value=now):
|
|
|
|
|
await init_integration(hass)
|
|
|
|
|
entity_entries = er.async_entries_for_config_entry(entity_registry, entry.entry_id)
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_bme280_humidity")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "45.7"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.HUMIDITY
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == PERCENTAGE
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_bme280_humidity")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-bme280_humidity"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_bme280_temperature")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "7.6"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.TEMPERATURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfTemperature.CELSIUS
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_bme280_temperature")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-bme280_temperature"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_bme280_pressure")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "1011.012"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PRESSURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfPressure.HPA
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_bme280_pressure")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-bme280_pressure"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_bmp180_temperature")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "7.6"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.TEMPERATURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfTemperature.CELSIUS
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_bmp180_temperature")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-bmp180_temperature"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_bmp180_pressure")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "1032.012"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PRESSURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfPressure.HPA
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_bmp180_pressure")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-bmp180_pressure"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_bmp280_temperature")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "5.6"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.TEMPERATURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfTemperature.CELSIUS
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_bmp280_temperature")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-bmp280_temperature"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_bmp280_pressure")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "1022.012"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PRESSURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfPressure.HPA
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_bmp280_pressure")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-bmp280_pressure"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sht3x_humidity")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "34.7"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.HUMIDITY
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == PERCENTAGE
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_sht3x_humidity")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sht3x_humidity"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sht3x_temperature")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "6.3"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.TEMPERATURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfTemperature.CELSIUS
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_sht3x_temperature")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sht3x_temperature"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_dht22_humidity")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "46.2"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.HUMIDITY
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == PERCENTAGE
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_dht22_humidity")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-dht22_humidity"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_dht22_temperature")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "6.3"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.TEMPERATURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfTemperature.CELSIUS
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_dht22_temperature")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-dht22_temperature"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_heca_humidity")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "50.0"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.HUMIDITY
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == PERCENTAGE
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_heca_humidity")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-heca_humidity"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_heca_temperature")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "8.0"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.TEMPERATURE
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert state.attributes.get(ATTR_UNIT_OF_MEASUREMENT) == UnitOfTemperature.CELSIUS
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_heca_temperature")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-heca_temperature"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_signal_strength")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "-72.0"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.SIGNAL_STRENGTH
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== SIGNAL_STRENGTH_DECIBELS_MILLIWATT
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_signal_strength")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-signal"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_uptime")
|
|
|
|
|
assert state
|
|
|
|
|
assert (
|
|
|
|
|
state.state
|
|
|
|
|
== (now - timedelta(seconds=456987)).replace(microsecond=0).isoformat()
|
|
|
|
|
)
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.TIMESTAMP
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is None
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_uptime")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-uptime"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get(
|
|
|
|
|
"sensor.nettigo_air_monitor_pmsx003_common_air_quality_index_level"
|
|
|
|
|
)
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "very_low"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.ENUM
|
|
|
|
|
assert state.attributes.get(ATTR_OPTIONS) == [
|
|
|
|
|
"very_low",
|
|
|
|
|
"low",
|
|
|
|
|
"medium",
|
|
|
|
|
"high",
|
|
|
|
|
"very_high",
|
|
|
|
|
]
|
|
|
|
|
assert state.attributes.get(ATTR_ICON) is None
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get(
|
|
|
|
|
"sensor.nettigo_air_monitor_pmsx003_common_air_quality_index_level"
|
|
|
|
|
)
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-pms_caqi_level"
|
|
|
|
|
assert entry.translation_key == "pmsx003_caqi_level"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get(
|
|
|
|
|
"sensor.nettigo_air_monitor_pmsx003_common_air_quality_index"
|
|
|
|
|
)
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "19"
|
|
|
|
|
assert state.attributes.get(ATTR_ICON) is None
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get(
|
|
|
|
|
"sensor.nettigo_air_monitor_pmsx003_common_air_quality_index"
|
|
|
|
|
)
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-pms_caqi"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_pmsx003_pm10")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "10.0"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PM10
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_pmsx003_pm10")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-pms_p1"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_pmsx003_pm2_5")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "11.0"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PM25
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_pmsx003_pm2_5")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-pms_p2"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_pmsx003_pm1")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "6.0"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PM1
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_pmsx003_pm1")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-pms_p0"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sds011_pm10")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "18.6"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PM10
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_sds011_pm10")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sds011_p1"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get(
|
|
|
|
|
"sensor.nettigo_air_monitor_sds011_common_air_quality_index"
|
|
|
|
|
)
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "19"
|
|
|
|
|
assert state.attributes.get(ATTR_ICON) is None
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get(
|
|
|
|
|
"sensor.nettigo_air_monitor_sds011_common_air_quality_index"
|
|
|
|
|
)
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sds011_caqi"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get(
|
|
|
|
|
"sensor.nettigo_air_monitor_sds011_common_air_quality_index_level"
|
|
|
|
|
)
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "very_low"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.ENUM
|
|
|
|
|
assert state.attributes.get(ATTR_OPTIONS) == [
|
|
|
|
|
"very_low",
|
|
|
|
|
"low",
|
|
|
|
|
"medium",
|
|
|
|
|
"high",
|
|
|
|
|
"very_high",
|
|
|
|
|
]
|
|
|
|
|
assert state.attributes.get(ATTR_ICON) is None
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get(
|
|
|
|
|
"sensor.nettigo_air_monitor_sds011_common_air_quality_index_level"
|
|
|
|
|
)
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sds011_caqi_level"
|
|
|
|
|
assert entry.translation_key == "sds011_caqi_level"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sds011_pm2_5")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "11.0"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PM25
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_sds011_pm2_5")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sds011_p2"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sps30_common_air_quality_index")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "54"
|
|
|
|
|
assert state.attributes.get(ATTR_ICON) is None
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get(
|
|
|
|
|
"sensor.nettigo_air_monitor_sps30_common_air_quality_index"
|
|
|
|
|
)
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sps30_caqi"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get(
|
|
|
|
|
"sensor.nettigo_air_monitor_sps30_common_air_quality_index_level"
|
|
|
|
|
)
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "medium"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.ENUM
|
|
|
|
|
assert state.attributes.get(ATTR_OPTIONS) == [
|
|
|
|
|
"very_low",
|
|
|
|
|
"low",
|
|
|
|
|
"medium",
|
|
|
|
|
"high",
|
|
|
|
|
"very_high",
|
|
|
|
|
]
|
|
|
|
|
assert state.attributes.get(ATTR_ICON) is None
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get(
|
|
|
|
|
"sensor.nettigo_air_monitor_sps30_common_air_quality_index_level"
|
|
|
|
|
)
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sps30_caqi_level"
|
|
|
|
|
assert entry.translation_key == "sps30_caqi_level"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sps30_pm1")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "31.2"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PM1
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_sps30_pm1")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sps30_p0"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sps30_pm10")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "21.2"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PM10
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_sps30_pm10")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sps30_p1"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sps30_pm2_5")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "34.3"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.PM25
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_sps30_pm2_5")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sps30_p2"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_sps30_pm4")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "24.7"
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_MICROGRAMS_PER_CUBIC_METER
|
|
|
|
|
)
|
|
|
|
|
assert state.attributes.get(ATTR_ICON) is None
|
|
|
|
|
|
|
|
|
|
entry = entity_registry.async_get("sensor.nettigo_air_monitor_sps30_pm4")
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-sps30_p4"
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_mh_z14a_carbon_dioxide")
|
|
|
|
|
assert state
|
|
|
|
|
assert state.state == "865.0"
|
|
|
|
|
assert state.attributes.get(ATTR_DEVICE_CLASS) == SensorDeviceClass.CO2
|
|
|
|
|
assert state.attributes.get(ATTR_STATE_CLASS) is SensorStateClass.MEASUREMENT
|
|
|
|
|
assert (
|
|
|
|
|
state.attributes.get(ATTR_UNIT_OF_MEASUREMENT)
|
|
|
|
|
== CONCENTRATION_PARTS_PER_MILLION
|
|
|
|
|
)
|
|
|
|
|
entry = entity_registry.async_get(
|
|
|
|
|
"sensor.nettigo_air_monitor_mh_z14a_carbon_dioxide"
|
|
|
|
|
)
|
|
|
|
|
assert entry
|
|
|
|
|
assert entry.unique_id == "aa:bb:cc:dd:ee:ff-mhz14a_carbon_dioxide"
|
|
|
|
|
assert entity_entries
|
|
|
|
|
for entity_entry in entity_entries:
|
|
|
|
|
assert entity_entry == snapshot(name=f"{entity_entry.entity_id}-entry")
|
|
|
|
|
assert (state := hass.states.get(entity_entry.entity_id))
|
|
|
|
|
assert state == snapshot(name=f"{entity_entry.entity_id}-state")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async def test_sensor_disabled(
|
|
|
|
@@ -524,6 +100,8 @@ async def test_incompleta_data_after_device_restart(hass: HomeAssistant) -> None
|
|
|
|
|
|
|
|
|
|
async def test_availability(hass: HomeAssistant) -> None:
|
|
|
|
|
"""Ensure that we mark the entities unavailable correctly when device causes an error."""
|
|
|
|
|
nam_data = load_json_object_fixture("nam/nam_data.json")
|
|
|
|
|
|
|
|
|
|
await init_integration(hass)
|
|
|
|
|
|
|
|
|
|
state = hass.states.get("sensor.nettigo_air_monitor_bme280_temperature")
|
|
|
|
@@ -566,6 +144,8 @@ async def test_availability(hass: HomeAssistant) -> None:
|
|
|
|
|
|
|
|
|
|
async def test_manual_update_entity(hass: HomeAssistant) -> None:
|
|
|
|
|
"""Test manual update entity via service homeasasistant/update_entity."""
|
|
|
|
|
nam_data = load_json_object_fixture("nam/nam_data.json")
|
|
|
|
|
|
|
|
|
|
await init_integration(hass)
|
|
|
|
|
|
|
|
|
|
await async_setup_component(hass, "homeassistant", {})
|
|
|
|
|