mirror of
https://github.com/esphome/esphome.git
synced 2025-10-30 14:43:51 +00:00
Merge branch 'sensor_memory' into integration
This commit is contained in:
@@ -4,6 +4,31 @@ binary_sensor:
|
||||
id: some_binary_sensor
|
||||
name: "Random binary"
|
||||
lambda: return (random_uint32() & 1) == 0;
|
||||
filters:
|
||||
- invert:
|
||||
- delayed_on: 100ms
|
||||
- delayed_off: 100ms
|
||||
# Templated, delays for 1s (1000ms) only if a reed switch is active
|
||||
- delayed_on_off: !lambda "return 1000;"
|
||||
- delayed_on_off:
|
||||
time_on: 10s
|
||||
time_off: !lambda "return 1000;"
|
||||
- autorepeat:
|
||||
- delay: 1s
|
||||
time_off: 100ms
|
||||
time_on: 900ms
|
||||
- delay: 5s
|
||||
time_off: 100ms
|
||||
time_on: 400ms
|
||||
- lambda: |-
|
||||
if (id(some_binary_sensor).state) {
|
||||
return x;
|
||||
} else {
|
||||
return {};
|
||||
}
|
||||
- settle: 100ms
|
||||
- timeout: 10s
|
||||
|
||||
on_state_change:
|
||||
then:
|
||||
- logger.log:
|
||||
|
||||
@@ -8,5 +8,8 @@ sensor:
|
||||
name: Test Sensor
|
||||
id: test_sensor
|
||||
unit_of_measurement: °C
|
||||
accuracy_decimals: 2
|
||||
state_class: measurement
|
||||
force_update: true
|
||||
lambda: return 42.0;
|
||||
update_interval: 0.1s
|
||||
|
||||
@@ -4,6 +4,7 @@ from __future__ import annotations
|
||||
|
||||
import asyncio
|
||||
|
||||
import aioesphomeapi
|
||||
from aioesphomeapi import EntityState
|
||||
import pytest
|
||||
|
||||
@@ -47,3 +48,23 @@ async def test_host_mode_with_sensor(
|
||||
# Verify the sensor state
|
||||
assert test_sensor_state.state == 42.0
|
||||
assert len(states) > 0, "No states received"
|
||||
|
||||
# Verify the optimized fields are working correctly
|
||||
# Get entity info to check accuracy_decimals, state_class, etc.
|
||||
entities, _ = await client.list_entities_services()
|
||||
sensor_info: aioesphomeapi.SensorInfo | None = None
|
||||
for entity in entities:
|
||||
if isinstance(entity, aioesphomeapi.SensorInfo):
|
||||
sensor_info = entity
|
||||
break
|
||||
|
||||
assert sensor_info is not None, "Sensor entity info not found"
|
||||
assert sensor_info.accuracy_decimals == 2, (
|
||||
f"Expected accuracy_decimals=2, got {sensor_info.accuracy_decimals}"
|
||||
)
|
||||
assert sensor_info.state_class == aioesphomeapi.StateClass.MEASUREMENT, (
|
||||
f"Expected state_class=StateClass.MEASUREMENT, got {sensor_info.state_class}"
|
||||
)
|
||||
assert sensor_info.force_update is True, (
|
||||
f"Expected force_update=True, got {sensor_info.force_update}"
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user