mirror of
https://github.com/home-assistant/core.git
synced 2025-12-25 05:26:47 +00:00
Add additional coverage for ESPHome sensor and number (#95226)
This commit is contained in:
91
tests/components/esphome/test_number.py
Normal file
91
tests/components/esphome/test_number.py
Normal file
@@ -0,0 +1,91 @@
|
||||
"""Test ESPHome numbers."""
|
||||
|
||||
import math
|
||||
from unittest.mock import call
|
||||
|
||||
from aioesphomeapi import (
|
||||
APIClient,
|
||||
NumberInfo,
|
||||
NumberMode as ESPHomeNumberMode,
|
||||
NumberState,
|
||||
)
|
||||
|
||||
from homeassistant.components.number import (
|
||||
ATTR_VALUE,
|
||||
DOMAIN as NUMBER_DOMAIN,
|
||||
SERVICE_SET_VALUE,
|
||||
)
|
||||
from homeassistant.const import ATTR_ENTITY_ID, STATE_UNKNOWN
|
||||
from homeassistant.core import HomeAssistant
|
||||
|
||||
|
||||
async def test_generic_number_entity(
|
||||
hass: HomeAssistant,
|
||||
mock_client: APIClient,
|
||||
mock_generic_device_entry,
|
||||
) -> None:
|
||||
"""Test a generic number entity."""
|
||||
entity_info = [
|
||||
NumberInfo(
|
||||
object_id="mynumber",
|
||||
key=1,
|
||||
name="my number",
|
||||
unique_id="my_number",
|
||||
max_value=100,
|
||||
min_value=0,
|
||||
step=1,
|
||||
unit_of_measurement="%",
|
||||
)
|
||||
]
|
||||
states = [NumberState(key=1, state=50)]
|
||||
user_service = []
|
||||
await mock_generic_device_entry(
|
||||
mock_client=mock_client,
|
||||
entity_info=entity_info,
|
||||
user_service=user_service,
|
||||
states=states,
|
||||
)
|
||||
state = hass.states.get("number.test_my_number")
|
||||
assert state is not None
|
||||
assert state.state == "50"
|
||||
|
||||
await hass.services.async_call(
|
||||
NUMBER_DOMAIN,
|
||||
SERVICE_SET_VALUE,
|
||||
{ATTR_ENTITY_ID: "number.test_my_number", ATTR_VALUE: 50},
|
||||
blocking=True,
|
||||
)
|
||||
mock_client.number_command.assert_has_calls([call(1, 50)])
|
||||
mock_client.number_command.reset_mock()
|
||||
|
||||
|
||||
async def test_generic_number_nan(
|
||||
hass: HomeAssistant,
|
||||
mock_client: APIClient,
|
||||
mock_generic_device_entry,
|
||||
) -> None:
|
||||
"""Test a generic number entity with nan state."""
|
||||
entity_info = [
|
||||
NumberInfo(
|
||||
object_id="mynumber",
|
||||
key=1,
|
||||
name="my number",
|
||||
unique_id="my_number",
|
||||
max_value=100,
|
||||
min_value=0,
|
||||
step=1,
|
||||
unit_of_measurement="%",
|
||||
mode=ESPHomeNumberMode.SLIDER,
|
||||
)
|
||||
]
|
||||
states = [NumberState(key=1, state=math.nan)]
|
||||
user_service = []
|
||||
await mock_generic_device_entry(
|
||||
mock_client=mock_client,
|
||||
entity_info=entity_info,
|
||||
user_service=user_service,
|
||||
states=states,
|
||||
)
|
||||
state = hass.states.get("number.test_my_number")
|
||||
assert state is not None
|
||||
assert state.state == STATE_UNKNOWN
|
||||
Reference in New Issue
Block a user