2019-11-06 22:55:39 +00:00
|
|
|
"""Tests for the WLED light platform."""
|
2020-06-03 15:18:50 +00:00
|
|
|
import json
|
2021-01-01 21:31:56 +00:00
|
|
|
from unittest.mock import patch
|
2020-06-03 15:18:50 +00:00
|
|
|
|
|
|
|
from wled import Device as WLEDDevice, WLEDConnectionError
|
2019-11-06 22:55:39 +00:00
|
|
|
|
|
|
|
from homeassistant.components.light import (
|
|
|
|
ATTR_BRIGHTNESS,
|
|
|
|
ATTR_EFFECT,
|
|
|
|
ATTR_HS_COLOR,
|
|
|
|
ATTR_RGB_COLOR,
|
2021-06-09 11:31:31 +00:00
|
|
|
ATTR_RGBW_COLOR,
|
2019-11-06 22:55:39 +00:00
|
|
|
ATTR_TRANSITION,
|
|
|
|
DOMAIN as LIGHT_DOMAIN,
|
|
|
|
)
|
|
|
|
from homeassistant.components.wled.const import (
|
|
|
|
ATTR_INTENSITY,
|
|
|
|
ATTR_PALETTE,
|
|
|
|
ATTR_PLAYLIST,
|
|
|
|
ATTR_PRESET,
|
2020-03-23 20:21:35 +00:00
|
|
|
ATTR_REVERSE,
|
2019-11-06 22:55:39 +00:00
|
|
|
ATTR_SPEED,
|
2020-03-23 20:21:35 +00:00
|
|
|
DOMAIN,
|
2021-06-09 18:15:46 +00:00
|
|
|
SCAN_INTERVAL,
|
2020-03-23 20:21:35 +00:00
|
|
|
SERVICE_EFFECT,
|
2020-10-25 11:44:26 +00:00
|
|
|
SERVICE_PRESET,
|
2019-11-06 22:55:39 +00:00
|
|
|
)
|
|
|
|
from homeassistant.const import (
|
|
|
|
ATTR_ENTITY_ID,
|
|
|
|
ATTR_ICON,
|
|
|
|
SERVICE_TURN_OFF,
|
|
|
|
SERVICE_TURN_ON,
|
2020-06-07 21:37:58 +00:00
|
|
|
STATE_OFF,
|
2019-11-06 22:55:39 +00:00
|
|
|
STATE_ON,
|
|
|
|
STATE_UNAVAILABLE,
|
|
|
|
)
|
|
|
|
from homeassistant.core import HomeAssistant
|
2021-03-09 13:25:03 +00:00
|
|
|
from homeassistant.helpers import entity_registry as er
|
2020-06-03 15:18:50 +00:00
|
|
|
import homeassistant.util.dt as dt_util
|
2019-11-06 22:55:39 +00:00
|
|
|
|
2020-06-03 15:18:50 +00:00
|
|
|
from tests.common import async_fire_time_changed, load_fixture
|
2019-11-06 22:55:39 +00:00
|
|
|
from tests.components.wled import init_integration
|
|
|
|
from tests.test_util.aiohttp import AiohttpClientMocker
|
|
|
|
|
|
|
|
|
|
|
|
async def test_rgb_light_state(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
|
|
|
) -> None:
|
|
|
|
"""Test the creation and values of the WLED lights."""
|
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
2021-03-09 13:25:03 +00:00
|
|
|
entity_registry = er.async_get(hass)
|
2019-11-06 22:55:39 +00:00
|
|
|
|
|
|
|
# First segment of the strip
|
2020-06-07 21:37:58 +00:00
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_0")
|
2019-11-06 22:55:39 +00:00
|
|
|
assert state
|
|
|
|
assert state.attributes.get(ATTR_BRIGHTNESS) == 127
|
|
|
|
assert state.attributes.get(ATTR_EFFECT) == "Solid"
|
|
|
|
assert state.attributes.get(ATTR_HS_COLOR) == (37.412, 100.0)
|
|
|
|
assert state.attributes.get(ATTR_ICON) == "mdi:led-strip-variant"
|
|
|
|
assert state.attributes.get(ATTR_INTENSITY) == 128
|
|
|
|
assert state.attributes.get(ATTR_PALETTE) == "Default"
|
|
|
|
assert state.attributes.get(ATTR_PLAYLIST) is None
|
|
|
|
assert state.attributes.get(ATTR_PRESET) is None
|
2020-03-23 20:21:35 +00:00
|
|
|
assert state.attributes.get(ATTR_REVERSE) is False
|
2019-11-06 22:55:39 +00:00
|
|
|
assert state.attributes.get(ATTR_SPEED) == 32
|
|
|
|
assert state.state == STATE_ON
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
entry = entity_registry.async_get("light.wled_rgb_light_segment_0")
|
2019-11-06 22:55:39 +00:00
|
|
|
assert entry
|
|
|
|
assert entry.unique_id == "aabbccddeeff_0"
|
|
|
|
|
|
|
|
# Second segment of the strip
|
2020-06-07 21:37:58 +00:00
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_1")
|
2019-11-06 22:55:39 +00:00
|
|
|
assert state
|
|
|
|
assert state.attributes.get(ATTR_BRIGHTNESS) == 127
|
|
|
|
assert state.attributes.get(ATTR_EFFECT) == "Blink"
|
|
|
|
assert state.attributes.get(ATTR_HS_COLOR) == (148.941, 100.0)
|
|
|
|
assert state.attributes.get(ATTR_ICON) == "mdi:led-strip-variant"
|
|
|
|
assert state.attributes.get(ATTR_INTENSITY) == 64
|
|
|
|
assert state.attributes.get(ATTR_PALETTE) == "Random Cycle"
|
|
|
|
assert state.attributes.get(ATTR_PLAYLIST) is None
|
|
|
|
assert state.attributes.get(ATTR_PRESET) is None
|
2020-03-23 20:21:35 +00:00
|
|
|
assert state.attributes.get(ATTR_REVERSE) is False
|
2019-11-06 22:55:39 +00:00
|
|
|
assert state.attributes.get(ATTR_SPEED) == 16
|
|
|
|
assert state.state == STATE_ON
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
entry = entity_registry.async_get("light.wled_rgb_light_segment_1")
|
2019-11-06 22:55:39 +00:00
|
|
|
assert entry
|
|
|
|
assert entry.unique_id == "aabbccddeeff_1"
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
# Test master control of the lightstrip
|
|
|
|
state = hass.states.get("light.wled_rgb_light_master")
|
|
|
|
assert state
|
|
|
|
assert state.attributes.get(ATTR_BRIGHTNESS) == 127
|
|
|
|
assert state.state == STATE_ON
|
2019-11-06 22:55:39 +00:00
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
entry = entity_registry.async_get("light.wled_rgb_light_master")
|
|
|
|
assert entry
|
|
|
|
assert entry.unique_id == "aabbccddeeff"
|
|
|
|
|
|
|
|
|
|
|
|
async def test_segment_change_state(
|
2020-03-13 12:19:05 +00:00
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker, caplog
|
2019-11-06 22:55:39 +00:00
|
|
|
) -> None:
|
2020-06-07 21:37:58 +00:00
|
|
|
"""Test the change of state of the WLED segments."""
|
2019-11-06 22:55:39 +00:00
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-13 12:19:05 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_OFF,
|
2020-06-07 21:37:58 +00:00
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0", ATTR_TRANSITION: 5},
|
2020-03-13 12:19:05 +00:00
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
on=False,
|
|
|
|
segment_id=0,
|
|
|
|
transition=50,
|
2020-03-13 12:19:05 +00:00
|
|
|
)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-13 12:19:05 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_ON,
|
|
|
|
{
|
|
|
|
ATTR_BRIGHTNESS: 42,
|
|
|
|
ATTR_EFFECT: "Chase",
|
2020-06-07 21:37:58 +00:00
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0",
|
2020-03-13 12:19:05 +00:00
|
|
|
ATTR_RGB_COLOR: [255, 0, 0],
|
|
|
|
ATTR_TRANSITION: 5,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
|
|
|
brightness=42,
|
|
|
|
color_primary=(255, 0, 0),
|
|
|
|
effect="Chase",
|
|
|
|
on=True,
|
|
|
|
segment_id=0,
|
|
|
|
transition=50,
|
|
|
|
)
|
|
|
|
|
2019-11-06 22:55:39 +00:00
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
async def test_master_change_state(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker, caplog
|
|
|
|
) -> None:
|
|
|
|
"""Test the change of state of the WLED master light control."""
|
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
|
|
|
with patch("wled.WLED.master") as light_mock:
|
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_OFF,
|
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_master", ATTR_TRANSITION: 5},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
on=False,
|
|
|
|
transition=50,
|
2020-06-07 21:37:58 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
with patch("wled.WLED.master") as light_mock:
|
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_ON,
|
|
|
|
{
|
|
|
|
ATTR_BRIGHTNESS: 42,
|
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_master",
|
|
|
|
ATTR_TRANSITION: 5,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
brightness=42,
|
|
|
|
on=True,
|
|
|
|
transition=50,
|
2020-06-07 21:37:58 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
with patch("wled.WLED.master") as light_mock:
|
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_OFF,
|
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_master", ATTR_TRANSITION: 5},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
on=False,
|
|
|
|
transition=50,
|
2020-06-07 21:37:58 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
with patch("wled.WLED.master") as light_mock:
|
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_ON,
|
|
|
|
{
|
|
|
|
ATTR_BRIGHTNESS: 42,
|
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_master",
|
|
|
|
ATTR_TRANSITION: 5,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
brightness=42,
|
|
|
|
on=True,
|
|
|
|
transition=50,
|
2020-06-07 21:37:58 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
2020-06-03 15:18:50 +00:00
|
|
|
async def test_dynamically_handle_segments(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
|
|
|
) -> None:
|
|
|
|
"""Test if a new/deleted segment is dynamically added/removed."""
|
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
assert hass.states.get("light.wled_rgb_light_master")
|
|
|
|
assert hass.states.get("light.wled_rgb_light_segment_0")
|
|
|
|
assert hass.states.get("light.wled_rgb_light_segment_1")
|
2020-06-03 15:18:50 +00:00
|
|
|
|
|
|
|
data = json.loads(load_fixture("wled/rgb_single_segment.json"))
|
|
|
|
device = WLEDDevice(data)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
# Test removal if segment went missing, including the master entity
|
2020-06-03 15:18:50 +00:00
|
|
|
with patch(
|
2021-06-09 18:15:46 +00:00
|
|
|
"homeassistant.components.wled.coordinator.WLED.update",
|
2020-08-27 11:56:20 +00:00
|
|
|
return_value=device,
|
2020-06-03 15:18:50 +00:00
|
|
|
):
|
|
|
|
async_fire_time_changed(hass, dt_util.utcnow() + SCAN_INTERVAL)
|
|
|
|
await hass.async_block_till_done()
|
2020-06-07 21:37:58 +00:00
|
|
|
assert hass.states.get("light.wled_rgb_light_segment_0")
|
|
|
|
assert not hass.states.get("light.wled_rgb_light_segment_1")
|
|
|
|
assert not hass.states.get("light.wled_rgb_light_master")
|
2020-06-03 15:18:50 +00:00
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
# Test adding if segment shows up again, including the master entity
|
2020-06-03 15:18:50 +00:00
|
|
|
async_fire_time_changed(hass, dt_util.utcnow() + SCAN_INTERVAL)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
assert hass.states.get("light.wled_rgb_light_master")
|
|
|
|
assert hass.states.get("light.wled_rgb_light_segment_0")
|
|
|
|
assert hass.states.get("light.wled_rgb_light_segment_1")
|
|
|
|
|
|
|
|
|
|
|
|
async def test_single_segment_behavior(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker, caplog
|
|
|
|
) -> None:
|
|
|
|
"""Test the behavior of the integration with a single segment."""
|
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
|
|
|
data = json.loads(load_fixture("wled/rgb_single_segment.json"))
|
|
|
|
device = WLEDDevice(data)
|
|
|
|
|
|
|
|
# Test absent master
|
|
|
|
with patch(
|
2021-06-09 18:15:46 +00:00
|
|
|
"homeassistant.components.wled.coordinator.WLED.update",
|
2020-08-27 11:56:20 +00:00
|
|
|
return_value=device,
|
2020-06-07 21:37:58 +00:00
|
|
|
):
|
|
|
|
async_fire_time_changed(hass, dt_util.utcnow() + SCAN_INTERVAL)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert not hass.states.get("light.wled_rgb_light_master")
|
|
|
|
|
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_0")
|
|
|
|
assert state
|
|
|
|
assert state.state == STATE_ON
|
|
|
|
|
|
|
|
# Test segment brightness takes master into account
|
|
|
|
device.state.brightness = 100
|
|
|
|
device.state.segments[0].brightness = 255
|
|
|
|
with patch(
|
2021-06-09 18:15:46 +00:00
|
|
|
"homeassistant.components.wled.coordinator.WLED.update",
|
2020-08-27 11:56:20 +00:00
|
|
|
return_value=device,
|
2020-06-07 21:37:58 +00:00
|
|
|
):
|
|
|
|
async_fire_time_changed(hass, dt_util.utcnow() + SCAN_INTERVAL)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_0")
|
|
|
|
assert state
|
|
|
|
assert state.attributes.get(ATTR_BRIGHTNESS) == 100
|
|
|
|
|
|
|
|
# Test segment is off when master is off
|
|
|
|
device.state.on = False
|
|
|
|
with patch(
|
2021-06-09 18:15:46 +00:00
|
|
|
"homeassistant.components.wled.coordinator.WLED.update",
|
2020-08-27 11:56:20 +00:00
|
|
|
return_value=device,
|
2020-06-07 21:37:58 +00:00
|
|
|
):
|
|
|
|
async_fire_time_changed(hass, dt_util.utcnow() + SCAN_INTERVAL)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_0")
|
|
|
|
assert state
|
|
|
|
assert state.state == STATE_OFF
|
|
|
|
|
|
|
|
# Test master is turned off when turning off a single segment
|
|
|
|
with patch("wled.WLED.master") as master_mock:
|
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_OFF,
|
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0", ATTR_TRANSITION: 5},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
master_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
on=False,
|
|
|
|
transition=50,
|
2020-06-07 21:37:58 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
# Test master is turned on when turning on a single segment, and segment
|
|
|
|
# brightness is set to 255.
|
|
|
|
with patch("wled.WLED.master") as master_mock, patch(
|
|
|
|
"wled.WLED.segment"
|
|
|
|
) as segment_mock:
|
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_ON,
|
|
|
|
{
|
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0",
|
|
|
|
ATTR_TRANSITION: 5,
|
|
|
|
ATTR_BRIGHTNESS: 42,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
master_mock.assert_called_once_with(on=True, transition=50, brightness=42)
|
|
|
|
segment_mock.assert_called_once_with(on=True, segment_id=0, brightness=255)
|
2020-06-03 15:18:50 +00:00
|
|
|
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
async def test_light_error(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker, caplog
|
|
|
|
) -> None:
|
|
|
|
"""Test error handling of the WLED lights."""
|
2020-04-04 05:41:08 +00:00
|
|
|
aioclient_mock.post("http://192.168.1.123:80/json/state", text="", status=400)
|
2020-03-13 12:19:05 +00:00
|
|
|
await init_integration(hass, aioclient_mock)
|
2019-11-06 22:55:39 +00:00
|
|
|
|
2021-06-09 18:15:46 +00:00
|
|
|
with patch("homeassistant.components.wled.coordinator.WLED.update"):
|
2020-03-13 12:19:05 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_OFF,
|
2020-06-07 21:37:58 +00:00
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0"},
|
2020-03-13 12:19:05 +00:00
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2019-11-06 22:55:39 +00:00
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_0")
|
2020-03-13 12:19:05 +00:00
|
|
|
assert state.state == STATE_ON
|
|
|
|
assert "Invalid response from API" in caplog.text
|
2019-11-06 22:55:39 +00:00
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
|
|
|
|
async def test_light_connection_error(
|
2019-11-06 22:55:39 +00:00
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
|
|
|
) -> None:
|
|
|
|
"""Test error handling of the WLED switches."""
|
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
2021-06-09 18:15:46 +00:00
|
|
|
with patch("homeassistant.components.wled.coordinator.WLED.update"), patch(
|
|
|
|
"homeassistant.components.wled.coordinator.WLED.segment",
|
|
|
|
side_effect=WLEDConnectionError,
|
2020-06-03 00:29:49 +00:00
|
|
|
):
|
2020-03-13 12:19:05 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_OFF,
|
2020-06-07 21:37:58 +00:00
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0"},
|
2020-03-13 12:19:05 +00:00
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_0")
|
2020-03-13 12:19:05 +00:00
|
|
|
assert state.state == STATE_UNAVAILABLE
|
2019-11-06 22:55:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_rgbw_light(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
|
|
|
) -> None:
|
|
|
|
"""Test RGBW support for WLED."""
|
|
|
|
await init_integration(hass, aioclient_mock, rgbw=True)
|
|
|
|
|
|
|
|
state = hass.states.get("light.wled_rgbw_light")
|
|
|
|
assert state.state == STATE_ON
|
2021-06-09 11:31:31 +00:00
|
|
|
assert state.attributes.get(ATTR_RGBW_COLOR) == (255, 0, 0, 139)
|
2020-03-13 12:19:05 +00:00
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-13 12:19:05 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
LIGHT_DOMAIN,
|
|
|
|
SERVICE_TURN_ON,
|
|
|
|
{
|
|
|
|
ATTR_ENTITY_ID: "light.wled_rgbw_light",
|
2021-06-09 11:31:31 +00:00
|
|
|
ATTR_RGBW_COLOR: (255, 255, 255, 255),
|
2020-03-13 12:19:05 +00:00
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2021-06-09 11:31:31 +00:00
|
|
|
color_primary=(255, 255, 255, 255),
|
2020-08-27 11:56:20 +00:00
|
|
|
on=True,
|
|
|
|
segment_id=0,
|
2020-03-13 12:19:05 +00:00
|
|
|
)
|
2020-03-23 20:21:35 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_effect_service(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
|
|
|
) -> None:
|
|
|
|
"""Test the effect service of a WLED light."""
|
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-23 20:21:35 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_EFFECT,
|
|
|
|
{
|
|
|
|
ATTR_EFFECT: "Rainbow",
|
2020-06-07 21:37:58 +00:00
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0",
|
2020-03-23 20:21:35 +00:00
|
|
|
ATTR_INTENSITY: 200,
|
2020-10-13 12:12:01 +00:00
|
|
|
ATTR_PALETTE: "Tiamat",
|
2020-03-23 20:21:35 +00:00
|
|
|
ATTR_REVERSE: True,
|
|
|
|
ATTR_SPEED: 100,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
effect="Rainbow",
|
|
|
|
intensity=200,
|
2020-10-13 12:12:01 +00:00
|
|
|
palette="Tiamat",
|
2020-08-27 11:56:20 +00:00
|
|
|
reverse=True,
|
|
|
|
segment_id=0,
|
|
|
|
speed=100,
|
2020-03-23 20:21:35 +00:00
|
|
|
)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-23 20:21:35 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_EFFECT,
|
2020-06-07 21:37:58 +00:00
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0", ATTR_EFFECT: 9},
|
2020-03-23 20:21:35 +00:00
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
segment_id=0,
|
|
|
|
effect=9,
|
2020-03-23 20:21:35 +00:00
|
|
|
)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-23 20:21:35 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_EFFECT,
|
|
|
|
{
|
2020-06-07 21:37:58 +00:00
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0",
|
2020-03-23 20:21:35 +00:00
|
|
|
ATTR_INTENSITY: 200,
|
|
|
|
ATTR_REVERSE: True,
|
|
|
|
ATTR_SPEED: 100,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
intensity=200,
|
|
|
|
reverse=True,
|
|
|
|
segment_id=0,
|
|
|
|
speed=100,
|
2020-03-23 20:21:35 +00:00
|
|
|
)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-23 20:21:35 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_EFFECT,
|
|
|
|
{
|
|
|
|
ATTR_EFFECT: "Rainbow",
|
2020-06-07 21:37:58 +00:00
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0",
|
2020-10-13 12:12:01 +00:00
|
|
|
ATTR_PALETTE: "Tiamat",
|
2020-03-23 20:21:35 +00:00
|
|
|
ATTR_REVERSE: True,
|
|
|
|
ATTR_SPEED: 100,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
effect="Rainbow",
|
2020-10-13 12:12:01 +00:00
|
|
|
palette="Tiamat",
|
2020-08-27 11:56:20 +00:00
|
|
|
reverse=True,
|
|
|
|
segment_id=0,
|
|
|
|
speed=100,
|
2020-03-23 20:21:35 +00:00
|
|
|
)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-23 20:21:35 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_EFFECT,
|
|
|
|
{
|
|
|
|
ATTR_EFFECT: "Rainbow",
|
2020-06-07 21:37:58 +00:00
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0",
|
2020-03-23 20:21:35 +00:00
|
|
|
ATTR_INTENSITY: 200,
|
|
|
|
ATTR_SPEED: 100,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
effect="Rainbow",
|
|
|
|
intensity=200,
|
|
|
|
segment_id=0,
|
|
|
|
speed=100,
|
2020-03-23 20:21:35 +00:00
|
|
|
)
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
with patch("wled.WLED.segment") as light_mock:
|
2020-03-23 20:21:35 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_EFFECT,
|
|
|
|
{
|
|
|
|
ATTR_EFFECT: "Rainbow",
|
2020-06-07 21:37:58 +00:00
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0",
|
2020-03-23 20:21:35 +00:00
|
|
|
ATTR_INTENSITY: 200,
|
|
|
|
ATTR_REVERSE: True,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
2020-08-27 11:56:20 +00:00
|
|
|
effect="Rainbow",
|
|
|
|
intensity=200,
|
|
|
|
reverse=True,
|
|
|
|
segment_id=0,
|
2020-03-23 20:21:35 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
async def test_effect_service_error(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker, caplog
|
|
|
|
) -> None:
|
|
|
|
"""Test error handling of the WLED effect service."""
|
2020-04-04 05:41:08 +00:00
|
|
|
aioclient_mock.post("http://192.168.1.123:80/json/state", text="", status=400)
|
2020-03-23 20:21:35 +00:00
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
2021-06-09 18:15:46 +00:00
|
|
|
with patch("homeassistant.components.wled.coordinator.WLED.update"):
|
2020-03-23 20:21:35 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_EFFECT,
|
2020-06-07 21:37:58 +00:00
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0", ATTR_EFFECT: 9},
|
2020-03-23 20:21:35 +00:00
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
2020-06-07 21:37:58 +00:00
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_0")
|
2020-03-23 20:21:35 +00:00
|
|
|
assert state.state == STATE_ON
|
|
|
|
assert "Invalid response from API" in caplog.text
|
2020-10-25 11:44:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_preset_service(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker
|
|
|
|
) -> None:
|
|
|
|
"""Test the preset service of a WLED light."""
|
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
|
|
|
with patch("wled.WLED.preset") as light_mock:
|
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_PRESET,
|
|
|
|
{
|
|
|
|
ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0",
|
|
|
|
ATTR_PRESET: 1,
|
|
|
|
},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
light_mock.assert_called_once_with(
|
|
|
|
preset=1,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
async def test_preset_service_error(
|
|
|
|
hass: HomeAssistant, aioclient_mock: AiohttpClientMocker, caplog
|
|
|
|
) -> None:
|
|
|
|
"""Test error handling of the WLED preset service."""
|
|
|
|
aioclient_mock.post("http://192.168.1.123:80/json/state", text="", status=400)
|
|
|
|
await init_integration(hass, aioclient_mock)
|
|
|
|
|
2021-06-09 18:15:46 +00:00
|
|
|
with patch("homeassistant.components.wled.coordinator.WLED.update"):
|
2020-10-25 11:44:26 +00:00
|
|
|
await hass.services.async_call(
|
|
|
|
DOMAIN,
|
|
|
|
SERVICE_PRESET,
|
|
|
|
{ATTR_ENTITY_ID: "light.wled_rgb_light_segment_0", ATTR_PRESET: 1},
|
|
|
|
blocking=True,
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
state = hass.states.get("light.wled_rgb_light_segment_0")
|
|
|
|
assert state.state == STATE_ON
|
|
|
|
assert "Invalid response from API" in caplog.text
|