2020-04-05 23:09:20 +00:00
|
|
|
"""The tests for the Modbus sensor component."""
|
|
|
|
from datetime import timedelta
|
|
|
|
import logging
|
|
|
|
from unittest import mock
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
from homeassistant.components.modbus.const import (
|
2020-09-28 01:00:44 +00:00
|
|
|
CALL_TYPE_COIL,
|
|
|
|
CALL_TYPE_DISCRETE,
|
2020-04-05 23:09:20 +00:00
|
|
|
CALL_TYPE_REGISTER_INPUT,
|
|
|
|
DEFAULT_HUB,
|
2020-04-09 20:15:20 +00:00
|
|
|
MODBUS_DOMAIN as DOMAIN,
|
2020-04-05 23:09:20 +00:00
|
|
|
)
|
2020-09-28 01:00:44 +00:00
|
|
|
from homeassistant.const import CONF_PLATFORM, CONF_SCAN_INTERVAL
|
2020-04-05 23:09:20 +00:00
|
|
|
from homeassistant.setup import async_setup_component
|
|
|
|
import homeassistant.util.dt as dt_util
|
|
|
|
|
|
|
|
from tests.common import MockModule, async_fire_time_changed, mock_integration
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture()
|
|
|
|
def mock_hub(hass):
|
|
|
|
"""Mock hub."""
|
2020-04-09 20:15:20 +00:00
|
|
|
mock_integration(hass, MockModule(DOMAIN))
|
2020-04-05 23:09:20 +00:00
|
|
|
hub = mock.MagicMock()
|
|
|
|
hub.name = "hub"
|
2020-04-09 20:15:20 +00:00
|
|
|
hass.data[DOMAIN] = {DEFAULT_HUB: hub}
|
2020-04-05 23:09:20 +00:00
|
|
|
return hub
|
|
|
|
|
|
|
|
|
|
|
|
class ReadResult:
|
|
|
|
"""Storage class for register read results."""
|
|
|
|
|
|
|
|
def __init__(self, register_words):
|
|
|
|
"""Init."""
|
|
|
|
self.registers = register_words
|
2020-09-28 01:00:44 +00:00
|
|
|
self.bits = register_words
|
|
|
|
|
|
|
|
|
|
|
|
async def run_base_test(
|
|
|
|
sensor_name,
|
|
|
|
hass,
|
|
|
|
use_mock_hub,
|
|
|
|
data_array,
|
|
|
|
register_type,
|
|
|
|
entity_domain,
|
|
|
|
register_words,
|
|
|
|
expected,
|
2020-04-05 23:09:20 +00:00
|
|
|
):
|
2020-09-28 01:00:44 +00:00
|
|
|
"""Run test for given config."""
|
2020-04-05 23:09:20 +00:00
|
|
|
|
|
|
|
# Full sensor configuration
|
|
|
|
scan_interval = 5
|
|
|
|
config = {
|
|
|
|
entity_domain: {
|
|
|
|
CONF_PLATFORM: "modbus",
|
|
|
|
CONF_SCAN_INTERVAL: scan_interval,
|
2020-09-28 01:00:44 +00:00
|
|
|
**data_array,
|
2020-04-05 23:09:20 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Setup inputs for the sensor
|
|
|
|
read_result = ReadResult(register_words)
|
2020-09-28 01:00:44 +00:00
|
|
|
if register_type == CALL_TYPE_COIL:
|
|
|
|
use_mock_hub.read_coils.return_value = read_result
|
|
|
|
elif register_type == CALL_TYPE_DISCRETE:
|
|
|
|
use_mock_hub.read_discrete_inputs.return_value = read_result
|
|
|
|
elif register_type == CALL_TYPE_REGISTER_INPUT:
|
2020-04-17 07:55:57 +00:00
|
|
|
use_mock_hub.read_input_registers.return_value = read_result
|
2020-09-28 01:00:44 +00:00
|
|
|
else: # CALL_TYPE_REGISTER_HOLDING
|
2020-04-17 07:55:57 +00:00
|
|
|
use_mock_hub.read_holding_registers.return_value = read_result
|
2020-04-05 23:09:20 +00:00
|
|
|
|
|
|
|
# Initialize sensor
|
|
|
|
now = dt_util.utcnow()
|
|
|
|
with mock.patch("homeassistant.helpers.event.dt_util.utcnow", return_value=now):
|
|
|
|
assert await async_setup_component(hass, entity_domain, config)
|
2020-06-01 05:18:30 +00:00
|
|
|
await hass.async_block_till_done()
|
2020-04-05 23:09:20 +00:00
|
|
|
|
|
|
|
# Trigger update call with time_changed event
|
|
|
|
now += timedelta(seconds=scan_interval + 1)
|
|
|
|
with mock.patch("homeassistant.helpers.event.dt_util.utcnow", return_value=now):
|
|
|
|
async_fire_time_changed(hass, now)
|
|
|
|
await hass.async_block_till_done()
|