1
0
mirror of https://github.com/home-assistant/core.git synced 2025-12-26 22:18:40 +00:00

Add Demo valves with position support (#154657)

This commit is contained in:
Shay Levy
2025-10-19 00:54:02 +03:00
committed by GitHub
parent f1e72c1616
commit 6de2016aa3
2 changed files with 126 additions and 10 deletions

View File

@@ -1,24 +1,30 @@
"""The tests for the Demo valve platform."""
from datetime import timedelta
from unittest.mock import patch
import pytest
from homeassistant.components.demo import DOMAIN, valve as demo_valve
from homeassistant.components.valve import (
ATTR_CURRENT_POSITION,
ATTR_POSITION,
DOMAIN as VALVE_DOMAIN,
SERVICE_CLOSE_VALVE,
SERVICE_OPEN_VALVE,
SERVICE_SET_VALVE_POSITION,
ValveState,
)
from homeassistant.const import ATTR_ENTITY_ID, EVENT_STATE_CHANGED, Platform
from homeassistant.core import HomeAssistant
from homeassistant.setup import async_setup_component
from homeassistant.util import dt as dt_util
from tests.common import async_capture_events
from tests.common import async_capture_events, async_fire_time_changed
FRONT_GARDEN = "valve.front_garden"
ORCHARD = "valve.orchard"
BACK_GARDEN = "valve.back_garden"
@pytest.fixture
@@ -81,3 +87,59 @@ async def test_opening(hass: HomeAssistant) -> None:
assert state_changes[1].data["entity_id"] == ORCHARD
assert state_changes[1].data["new_state"].state == ValveState.OPEN
async def test_set_valve_position(hass: HomeAssistant) -> None:
"""Test moving the valve to a specific position."""
state = hass.states.get(BACK_GARDEN)
assert state.attributes[ATTR_CURRENT_POSITION] == 70
# close to 10%
await hass.services.async_call(
VALVE_DOMAIN,
SERVICE_SET_VALVE_POSITION,
{ATTR_ENTITY_ID: BACK_GARDEN, ATTR_POSITION: 10},
blocking=True,
)
state = hass.states.get(BACK_GARDEN)
assert state.state == ValveState.CLOSING
for _ in range(6):
future = dt_util.utcnow() + timedelta(seconds=1)
async_fire_time_changed(hass, future)
await hass.async_block_till_done()
state = hass.states.get(BACK_GARDEN)
assert state.attributes[ATTR_CURRENT_POSITION] == 10
assert state.state == ValveState.OPEN
# open to 80%
await hass.services.async_call(
VALVE_DOMAIN,
SERVICE_SET_VALVE_POSITION,
{ATTR_ENTITY_ID: BACK_GARDEN, ATTR_POSITION: 80},
blocking=True,
)
state = hass.states.get(BACK_GARDEN)
assert state.state == ValveState.OPENING
for _ in range(7):
future = dt_util.utcnow() + timedelta(seconds=1)
async_fire_time_changed(hass, future)
await hass.async_block_till_done()
state = hass.states.get(BACK_GARDEN)
assert state.attributes[ATTR_CURRENT_POSITION] == 80
assert state.state == ValveState.OPEN
# test valve is at requested position
state_changes = async_capture_events(hass, EVENT_STATE_CHANGED)
await hass.services.async_call(
VALVE_DOMAIN,
SERVICE_SET_VALVE_POSITION,
{ATTR_ENTITY_ID: BACK_GARDEN, ATTR_POSITION: 80},
blocking=True,
)
await hass.async_block_till_done()
assert len(state_changes) == 0