2020-10-01 16:00:26 +00:00
|
|
|
"""The tests for the Modbus switch component."""
|
2021-05-24 10:59:55 +00:00
|
|
|
from datetime import timedelta
|
|
|
|
from unittest import mock
|
|
|
|
|
2021-05-19 13:05:29 +00:00
|
|
|
from pymodbus.exceptions import ModbusException
|
2020-10-08 13:47:59 +00:00
|
|
|
import pytest
|
|
|
|
|
2020-11-08 16:42:45 +00:00
|
|
|
from homeassistant.components.modbus.const import (
|
|
|
|
CALL_TYPE_COIL,
|
2021-05-17 09:20:12 +00:00
|
|
|
CALL_TYPE_DISCRETE,
|
2021-03-27 21:48:06 +00:00
|
|
|
CALL_TYPE_REGISTER_HOLDING,
|
|
|
|
CALL_TYPE_REGISTER_INPUT,
|
|
|
|
CONF_INPUT_TYPE,
|
2021-08-21 13:49:50 +00:00
|
|
|
CONF_LAZY_ERROR,
|
2021-03-27 21:48:06 +00:00
|
|
|
CONF_STATE_OFF,
|
|
|
|
CONF_STATE_ON,
|
2021-04-30 14:47:18 +00:00
|
|
|
CONF_VERIFY,
|
|
|
|
CONF_WRITE_TYPE,
|
2021-05-19 13:05:29 +00:00
|
|
|
MODBUS_DOMAIN,
|
2021-08-18 10:56:54 +00:00
|
|
|
TCP,
|
2020-11-08 16:42:45 +00:00
|
|
|
)
|
2020-10-01 16:00:26 +00:00
|
|
|
from homeassistant.components.switch import DOMAIN as SWITCH_DOMAIN
|
2020-11-08 16:42:45 +00:00
|
|
|
from homeassistant.const import (
|
2021-03-27 21:48:06 +00:00
|
|
|
CONF_ADDRESS,
|
2020-11-08 16:42:45 +00:00
|
|
|
CONF_COMMAND_OFF,
|
|
|
|
CONF_COMMAND_ON,
|
2021-05-24 10:59:55 +00:00
|
|
|
CONF_DELAY,
|
2021-03-27 21:48:06 +00:00
|
|
|
CONF_DEVICE_CLASS,
|
2021-05-19 13:05:29 +00:00
|
|
|
CONF_HOST,
|
2020-11-08 16:42:45 +00:00
|
|
|
CONF_NAME,
|
2021-05-19 13:05:29 +00:00
|
|
|
CONF_PORT,
|
2021-05-24 10:59:55 +00:00
|
|
|
CONF_SCAN_INTERVAL,
|
2020-11-08 16:42:45 +00:00
|
|
|
CONF_SLAVE,
|
2021-04-04 12:02:47 +00:00
|
|
|
CONF_SWITCHES,
|
2021-05-19 13:05:29 +00:00
|
|
|
CONF_TYPE,
|
2020-11-08 16:42:45 +00:00
|
|
|
STATE_OFF,
|
|
|
|
STATE_ON,
|
2021-05-19 13:05:29 +00:00
|
|
|
STATE_UNAVAILABLE,
|
2020-11-08 16:42:45 +00:00
|
|
|
)
|
2021-05-19 13:05:29 +00:00
|
|
|
from homeassistant.core import State
|
|
|
|
from homeassistant.setup import async_setup_component
|
2021-05-24 10:59:55 +00:00
|
|
|
import homeassistant.util.dt as dt_util
|
2020-10-01 16:00:26 +00:00
|
|
|
|
2021-10-13 18:51:51 +00:00
|
|
|
from .conftest import (
|
|
|
|
TEST_ENTITY_NAME,
|
|
|
|
TEST_MODBUS_HOST,
|
|
|
|
TEST_PORT_TCP,
|
|
|
|
ReadResult,
|
|
|
|
do_next_cycle,
|
|
|
|
)
|
2021-02-14 16:40:30 +00:00
|
|
|
|
2021-06-29 05:21:04 +00:00
|
|
|
from tests.common import async_fire_time_changed
|
|
|
|
|
2021-08-17 18:43:27 +00:00
|
|
|
ENTITY_ID = f"{SWITCH_DOMAIN}.{TEST_ENTITY_NAME}"
|
2021-10-20 11:38:55 +00:00
|
|
|
ENTITY_ID2 = f"{ENTITY_ID}2"
|
2021-05-19 13:05:29 +00:00
|
|
|
|
2021-02-14 16:40:30 +00:00
|
|
|
|
2021-03-27 21:48:06 +00:00
|
|
|
@pytest.mark.parametrize(
|
2021-04-30 14:47:18 +00:00
|
|
|
"do_config",
|
2021-03-31 09:20:14 +00:00
|
|
|
[
|
2021-04-30 14:47:18 +00:00
|
|
|
{
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
}
|
|
|
|
]
|
2021-04-30 14:47:18 +00:00
|
|
|
},
|
|
|
|
{
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_WRITE_TYPE: CALL_TYPE_COIL,
|
2021-08-21 13:49:50 +00:00
|
|
|
CONF_LAZY_ERROR: 10,
|
2021-06-17 10:27:05 +00:00
|
|
|
}
|
|
|
|
]
|
2021-04-30 14:47:18 +00:00
|
|
|
},
|
|
|
|
{
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_SLAVE: 1,
|
|
|
|
CONF_COMMAND_OFF: 0x00,
|
|
|
|
CONF_COMMAND_ON: 0x01,
|
|
|
|
CONF_DEVICE_CLASS: "switch",
|
|
|
|
CONF_VERIFY: {
|
|
|
|
CONF_INPUT_TYPE: CALL_TYPE_REGISTER_HOLDING,
|
|
|
|
CONF_ADDRESS: 1235,
|
|
|
|
CONF_STATE_OFF: 0,
|
|
|
|
CONF_STATE_ON: 1,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
]
|
2021-04-30 14:47:18 +00:00
|
|
|
},
|
|
|
|
{
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_SLAVE: 1,
|
|
|
|
CONF_COMMAND_OFF: 0x00,
|
|
|
|
CONF_COMMAND_ON: 0x01,
|
|
|
|
CONF_DEVICE_CLASS: "switch",
|
|
|
|
CONF_VERIFY: {
|
|
|
|
CONF_INPUT_TYPE: CALL_TYPE_REGISTER_INPUT,
|
|
|
|
CONF_ADDRESS: 1235,
|
|
|
|
CONF_STATE_OFF: 0,
|
|
|
|
CONF_STATE_ON: 1,
|
|
|
|
CONF_DELAY: 10,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
]
|
2021-04-30 14:47:18 +00:00
|
|
|
},
|
2021-05-19 13:05:29 +00:00
|
|
|
{
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_SLAVE: 1,
|
|
|
|
CONF_COMMAND_OFF: 0x00,
|
|
|
|
CONF_COMMAND_ON: 0x01,
|
|
|
|
CONF_DEVICE_CLASS: "switch",
|
|
|
|
CONF_VERIFY: {
|
|
|
|
CONF_INPUT_TYPE: CALL_TYPE_DISCRETE,
|
|
|
|
CONF_ADDRESS: 1235,
|
|
|
|
CONF_STATE_OFF: 0,
|
|
|
|
CONF_STATE_ON: 1,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
]
|
2021-05-19 13:05:29 +00:00
|
|
|
},
|
|
|
|
{
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-06-17 10:27:05 +00:00
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_SLAVE: 1,
|
|
|
|
CONF_COMMAND_OFF: 0x00,
|
|
|
|
CONF_COMMAND_ON: 0x01,
|
|
|
|
CONF_DEVICE_CLASS: "switch",
|
|
|
|
CONF_SCAN_INTERVAL: 0,
|
|
|
|
CONF_VERIFY: None,
|
|
|
|
}
|
|
|
|
]
|
2021-05-19 13:05:29 +00:00
|
|
|
},
|
2021-03-31 09:20:14 +00:00
|
|
|
],
|
2021-03-27 21:48:06 +00:00
|
|
|
)
|
2021-06-17 10:27:05 +00:00
|
|
|
async def test_config_switch(hass, mock_modbus):
|
|
|
|
"""Run configurationtest for switch."""
|
|
|
|
assert SWITCH_DOMAIN in hass.config.components
|
2020-10-01 16:00:26 +00:00
|
|
|
|
|
|
|
|
2020-10-08 13:47:59 +00:00
|
|
|
@pytest.mark.parametrize(
|
2021-08-22 17:59:38 +00:00
|
|
|
"do_config",
|
|
|
|
[
|
|
|
|
{
|
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_SLAVE: 1,
|
|
|
|
CONF_WRITE_TYPE: CALL_TYPE_COIL,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_SLAVE: 1,
|
|
|
|
CONF_WRITE_TYPE: CALL_TYPE_REGISTER_HOLDING,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
)
|
|
|
|
@pytest.mark.parametrize(
|
2021-08-23 21:55:57 +00:00
|
|
|
"register_words,do_exception,config_addon,expected",
|
2020-10-08 13:47:59 +00:00
|
|
|
[
|
|
|
|
(
|
|
|
|
[0x00],
|
2021-08-23 21:55:57 +00:00
|
|
|
False,
|
2021-05-19 13:05:29 +00:00
|
|
|
{CONF_VERIFY: {}},
|
2020-10-08 13:47:59 +00:00
|
|
|
STATE_OFF,
|
|
|
|
),
|
|
|
|
(
|
|
|
|
[0x01],
|
2021-08-23 21:55:57 +00:00
|
|
|
False,
|
2021-05-19 13:05:29 +00:00
|
|
|
{CONF_VERIFY: {}},
|
2020-10-08 13:47:59 +00:00
|
|
|
STATE_ON,
|
|
|
|
),
|
2020-11-08 16:42:45 +00:00
|
|
|
(
|
|
|
|
[0xFE],
|
2021-08-23 21:55:57 +00:00
|
|
|
False,
|
2021-05-19 13:05:29 +00:00
|
|
|
{CONF_VERIFY: {}},
|
2020-11-08 16:42:45 +00:00
|
|
|
STATE_OFF,
|
|
|
|
),
|
|
|
|
(
|
2021-08-23 21:55:57 +00:00
|
|
|
[0x00],
|
|
|
|
True,
|
2021-05-19 13:05:29 +00:00
|
|
|
{CONF_VERIFY: {}},
|
|
|
|
STATE_UNAVAILABLE,
|
2020-11-08 16:42:45 +00:00
|
|
|
),
|
|
|
|
(
|
2021-08-23 21:55:57 +00:00
|
|
|
[0x00],
|
|
|
|
True,
|
2021-08-22 17:59:38 +00:00
|
|
|
None,
|
2021-05-19 13:05:29 +00:00
|
|
|
STATE_OFF,
|
2020-11-08 16:42:45 +00:00
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|
2021-08-23 21:55:57 +00:00
|
|
|
async def test_all_switch(hass, mock_do_cycle, expected):
|
2020-11-08 16:42:45 +00:00
|
|
|
"""Run test for given config."""
|
2021-08-22 17:59:38 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == expected
|
2020-11-08 16:42:45 +00:00
|
|
|
|
|
|
|
|
2021-10-13 18:51:51 +00:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"do_config",
|
|
|
|
[
|
|
|
|
{
|
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_SLAVE: 1,
|
|
|
|
CONF_WRITE_TYPE: CALL_TYPE_REGISTER_HOLDING,
|
|
|
|
CONF_SCAN_INTERVAL: 10,
|
|
|
|
CONF_LAZY_ERROR: 2,
|
|
|
|
CONF_VERIFY: {},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
)
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"register_words,do_exception,start_expect,end_expect",
|
|
|
|
[
|
|
|
|
(
|
|
|
|
[0x00],
|
|
|
|
True,
|
|
|
|
STATE_OFF,
|
|
|
|
STATE_UNAVAILABLE,
|
|
|
|
),
|
|
|
|
],
|
|
|
|
)
|
|
|
|
async def test_lazy_error_switch(hass, start_expect, end_expect, mock_do_cycle):
|
|
|
|
"""Run test for given config."""
|
|
|
|
now = mock_do_cycle
|
|
|
|
assert hass.states.get(ENTITY_ID).state == start_expect
|
|
|
|
now = await do_next_cycle(hass, now, 11)
|
|
|
|
assert hass.states.get(ENTITY_ID).state == start_expect
|
|
|
|
now = await do_next_cycle(hass, now, 11)
|
|
|
|
assert hass.states.get(ENTITY_ID).state == end_expect
|
|
|
|
|
|
|
|
|
2021-06-29 05:21:04 +00:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"mock_test_state",
|
2021-06-30 12:34:33 +00:00
|
|
|
[(State(ENTITY_ID, STATE_ON),)],
|
2021-06-29 05:21:04 +00:00
|
|
|
indirect=True,
|
|
|
|
)
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"do_config",
|
|
|
|
[
|
|
|
|
{
|
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-06-29 05:21:04 +00:00
|
|
|
CONF_ADDRESS: 1234,
|
2021-07-21 05:48:02 +00:00
|
|
|
CONF_SCAN_INTERVAL: 0,
|
2021-06-29 05:21:04 +00:00
|
|
|
}
|
|
|
|
]
|
|
|
|
},
|
|
|
|
],
|
|
|
|
)
|
|
|
|
async def test_restore_state_switch(hass, mock_test_state, mock_modbus):
|
2021-05-19 13:05:29 +00:00
|
|
|
"""Run test for sensor restore state."""
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == mock_test_state[0].state
|
2021-05-19 13:05:29 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_switch_service_turn(hass, caplog, mock_pymodbus):
|
|
|
|
"""Run test for service turn_on/turn_off."""
|
|
|
|
|
|
|
|
config = {
|
|
|
|
MODBUS_DOMAIN: {
|
2021-08-18 10:56:54 +00:00
|
|
|
CONF_TYPE: TCP,
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_HOST: TEST_MODBUS_HOST,
|
|
|
|
CONF_PORT: TEST_PORT_TCP,
|
2021-05-19 13:05:29 +00:00
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-05-19 13:05:29 +00:00
|
|
|
CONF_ADDRESS: 17,
|
|
|
|
CONF_WRITE_TYPE: CALL_TYPE_REGISTER_HOLDING,
|
2021-07-21 05:48:02 +00:00
|
|
|
CONF_SCAN_INTERVAL: 0,
|
2021-05-19 13:05:29 +00:00
|
|
|
},
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: f"{TEST_ENTITY_NAME}2",
|
2021-08-19 07:37:31 +00:00
|
|
|
CONF_ADDRESS: 18,
|
2021-05-19 13:05:29 +00:00
|
|
|
CONF_WRITE_TYPE: CALL_TYPE_REGISTER_HOLDING,
|
2021-07-21 05:48:02 +00:00
|
|
|
CONF_SCAN_INTERVAL: 0,
|
2021-05-19 13:05:29 +00:00
|
|
|
CONF_VERIFY: {},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
}
|
|
|
|
assert await async_setup_component(hass, MODBUS_DOMAIN, config) is True
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert MODBUS_DOMAIN in hass.config.components
|
|
|
|
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == STATE_OFF
|
2021-05-19 13:05:29 +00:00
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"switch", "turn_on", service_data={"entity_id": ENTITY_ID}
|
2021-05-19 13:05:29 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == STATE_ON
|
2021-05-19 13:05:29 +00:00
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"switch", "turn_off", service_data={"entity_id": ENTITY_ID}
|
2021-05-19 13:05:29 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == STATE_OFF
|
2021-05-19 13:05:29 +00:00
|
|
|
|
|
|
|
mock_pymodbus.read_holding_registers.return_value = ReadResult([0x01])
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID2).state == STATE_OFF
|
2021-05-19 13:05:29 +00:00
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"switch", "turn_on", service_data={"entity_id": ENTITY_ID2}
|
2021-05-19 13:05:29 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID2).state == STATE_ON
|
2021-05-19 13:05:29 +00:00
|
|
|
mock_pymodbus.read_holding_registers.return_value = ReadResult([0x00])
|
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"switch", "turn_off", service_data={"entity_id": ENTITY_ID2}
|
2021-05-19 13:05:29 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID2).state == STATE_OFF
|
2021-05-19 13:05:29 +00:00
|
|
|
|
|
|
|
mock_pymodbus.write_register.side_effect = ModbusException("fail write_")
|
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"switch", "turn_on", service_data={"entity_id": ENTITY_ID2}
|
2021-05-19 13:05:29 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID2).state == STATE_UNAVAILABLE
|
2021-05-19 13:05:29 +00:00
|
|
|
mock_pymodbus.write_coil.side_effect = ModbusException("fail write_")
|
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"switch", "turn_off", service_data={"entity_id": ENTITY_ID}
|
2021-05-19 13:05:29 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == STATE_UNAVAILABLE
|
2021-05-02 08:41:36 +00:00
|
|
|
|
|
|
|
|
2021-08-11 10:42:28 +00:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"do_config",
|
|
|
|
[
|
|
|
|
{
|
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-08-11 10:42:28 +00:00
|
|
|
CONF_ADDRESS: 1234,
|
|
|
|
CONF_WRITE_TYPE: CALL_TYPE_COIL,
|
|
|
|
CONF_VERIFY: {},
|
|
|
|
}
|
|
|
|
]
|
|
|
|
},
|
|
|
|
],
|
|
|
|
)
|
|
|
|
async def test_service_switch_update(hass, mock_modbus, mock_ha):
|
2021-05-02 08:41:36 +00:00
|
|
|
"""Run test for service homeassistant.update_entity."""
|
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"homeassistant", "update_entity", {"entity_id": ENTITY_ID}, blocking=True
|
2021-05-02 08:41:36 +00:00
|
|
|
)
|
2021-08-11 10:42:28 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == STATE_OFF
|
|
|
|
mock_modbus.read_coils.return_value = ReadResult([0x01])
|
2021-05-02 08:41:36 +00:00
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"homeassistant", "update_entity", {"entity_id": ENTITY_ID}, blocking=True
|
2021-05-02 08:41:36 +00:00
|
|
|
)
|
2021-08-11 10:42:28 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == STATE_ON
|
2021-05-24 10:59:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_delay_switch(hass, mock_pymodbus):
|
|
|
|
"""Run test for switch verify delay."""
|
|
|
|
config = {
|
|
|
|
MODBUS_DOMAIN: [
|
|
|
|
{
|
2021-08-18 10:56:54 +00:00
|
|
|
CONF_TYPE: TCP,
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_HOST: TEST_MODBUS_HOST,
|
|
|
|
CONF_PORT: TEST_PORT_TCP,
|
2021-05-24 10:59:55 +00:00
|
|
|
CONF_SWITCHES: [
|
|
|
|
{
|
2021-08-17 18:43:27 +00:00
|
|
|
CONF_NAME: TEST_ENTITY_NAME,
|
2021-05-24 10:59:55 +00:00
|
|
|
CONF_ADDRESS: 51,
|
|
|
|
CONF_SCAN_INTERVAL: 0,
|
|
|
|
CONF_VERIFY: {
|
|
|
|
CONF_DELAY: 1,
|
|
|
|
CONF_INPUT_TYPE: CALL_TYPE_REGISTER_HOLDING,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
mock_pymodbus.read_holding_registers.return_value = ReadResult([0x01])
|
|
|
|
now = dt_util.utcnow()
|
|
|
|
with mock.patch("homeassistant.helpers.event.dt_util.utcnow", return_value=now):
|
|
|
|
assert await async_setup_component(hass, MODBUS_DOMAIN, config) is True
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
await hass.services.async_call(
|
2021-06-30 12:34:33 +00:00
|
|
|
"switch", "turn_on", service_data={"entity_id": ENTITY_ID}
|
2021-05-24 10:59:55 +00:00
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == STATE_OFF
|
2021-05-24 10:59:55 +00:00
|
|
|
now = now + timedelta(seconds=2)
|
|
|
|
with mock.patch("homeassistant.helpers.event.dt_util.utcnow", return_value=now):
|
|
|
|
async_fire_time_changed(hass, now)
|
|
|
|
await hass.async_block_till_done()
|
2021-06-30 12:34:33 +00:00
|
|
|
assert hass.states.get(ENTITY_ID).state == STATE_ON
|