1
0
mirror of https://github.com/home-assistant/core.git synced 2025-12-21 11:30:03 +00:00
Files
core/tests/components/knx/test_datetime.py

141 lines
4.3 KiB
Python

"""Test KNX date."""
from homeassistant.components.datetime import (
ATTR_DATETIME,
DOMAIN as DATETIME_DOMAIN,
SERVICE_SET_VALUE,
)
from homeassistant.components.knx.const import CONF_RESPOND_TO_READ, KNX_ADDRESS
from homeassistant.components.knx.schema import DateTimeSchema
from homeassistant.const import CONF_NAME, Platform
from homeassistant.core import HomeAssistant, State
from . import KnxEntityGenerator
from .conftest import KNXTestKit
from tests.common import mock_restore_cache
# KNX DPT 19.001 doesn't provide timezone information so we send local time
async def test_datetime(hass: HomeAssistant, knx: KNXTestKit) -> None:
"""Test KNX datetime."""
# default timezone in tests is US/Pacific
test_address = "1/1/1"
await knx.setup_integration(
{
DateTimeSchema.PLATFORM: {
CONF_NAME: "test",
KNX_ADDRESS: test_address,
}
}
)
# set value
await hass.services.async_call(
DATETIME_DOMAIN,
SERVICE_SET_VALUE,
{"entity_id": "datetime.test", ATTR_DATETIME: "2020-01-02T03:04:05+00:00"},
blocking=True,
)
await knx.assert_write(
test_address,
# service call in UTC, telegram in local time
(0x78, 0x01, 0x01, 0x13, 0x04, 0x05, 0x24, 0x00),
)
state = hass.states.get("datetime.test")
assert state.state == "2020-01-02T03:04:05+00:00"
# update from KNX
await knx.receive_write(
test_address,
(0x7B, 0x07, 0x19, 0x49, 0x28, 0x08, 0x00, 0x00),
)
state = hass.states.get("datetime.test")
assert state.state == "2023-07-25T16:40:08+00:00"
async def test_date_restore_and_respond(hass: HomeAssistant, knx: KNXTestKit) -> None:
"""Test KNX datetime with passive_address, restoring state and respond_to_read."""
await hass.config.async_set_time_zone("Europe/Vienna")
test_address = "1/1/1"
test_passive_address = "3/3/3"
fake_state = State("datetime.test", "2022-03-03T03:04:05+00:00")
mock_restore_cache(hass, (fake_state,))
await knx.setup_integration(
{
DateTimeSchema.PLATFORM: {
CONF_NAME: "test",
KNX_ADDRESS: [test_address, test_passive_address],
CONF_RESPOND_TO_READ: True,
}
}
)
# restored state - doesn't send telegram
state = hass.states.get("datetime.test")
assert state.state == "2022-03-03T03:04:05+00:00"
await knx.assert_telegram_count(0)
# respond with restored state
await knx.receive_read(test_address)
await knx.assert_response(
test_address,
(0x7A, 0x03, 0x03, 0x04, 0x04, 0x05, 0x24, 0x00),
)
# don't respond to passive address
await knx.receive_read(test_passive_address)
await knx.assert_no_telegram()
# update from KNX passive address
await knx.receive_write(
test_passive_address,
(0x78, 0x01, 0x01, 0x73, 0x04, 0x05, 0x20, 0x80),
)
state = hass.states.get("datetime.test")
assert state.state == "2020-01-01T18:04:05+00:00"
async def test_datetime_ui_create(
hass: HomeAssistant,
knx: KNXTestKit,
create_ui_entity: KnxEntityGenerator,
) -> None:
"""Test creating a datetime entity."""
await knx.setup_integration()
await create_ui_entity(
platform=Platform.DATETIME,
entity_data={"name": "test"},
knx_data={
"ga_datetime": {"write": "0/0/1", "state": "0/0/2"},
"respond_to_read": True,
"sync_state": True,
},
)
# created entity sends a read-request to the read address
await knx.assert_read(
"0/0/2", response=(0x7B, 0x07, 0x19, 0x49, 0x28, 0x08, 0x00, 0x00)
)
knx.assert_state("datetime.test", "2023-07-25T16:40:08+00:00")
async def test_datetime_ui_load(knx: KNXTestKit) -> None:
"""Test loading datetime entities from storage."""
await knx.setup_integration(config_store_fixture="config_store_datetime.json")
# datetime_with_state_address
await knx.assert_read(
"0/0/2",
response=(0x7B, 0x07, 0x19, 0x49, 0x28, 0x08, 0x00, 0x00),
ignore_order=True,
)
knx.assert_state(
"datetime.datetime_with_state_address",
"2023-07-25T16:40:08+00:00",
)
knx.assert_state(
"datetime.datetime_without_state_address",
"unknown",
)