Add Check date service for Workday (#97280)

pull/103535/head
G Johansson 2023-11-06 10:17:48 +01:00 committed by GitHub
parent 3cfb2d557f
commit b580ca6e6f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 85 additions and 3 deletions

View File

@ -2,19 +2,25 @@
from __future__ import annotations from __future__ import annotations
from datetime import date, timedelta from datetime import date, timedelta
from typing import Final
from holidays import ( from holidays import (
HolidayBase, HolidayBase,
__version__ as python_holidays_version, __version__ as python_holidays_version,
country_holidays, country_holidays,
) )
import voluptuous as vol
from homeassistant.components.binary_sensor import BinarySensorEntity from homeassistant.components.binary_sensor import BinarySensorEntity
from homeassistant.config_entries import ConfigEntry from homeassistant.config_entries import ConfigEntry
from homeassistant.const import CONF_NAME from homeassistant.const import CONF_NAME
from homeassistant.core import HomeAssistant from homeassistant.core import HomeAssistant, ServiceResponse, SupportsResponse
import homeassistant.helpers.config_validation as cv
from homeassistant.helpers.device_registry import DeviceEntryType, DeviceInfo from homeassistant.helpers.device_registry import DeviceEntryType, DeviceInfo
from homeassistant.helpers.entity_platform import AddEntitiesCallback from homeassistant.helpers.entity_platform import (
AddEntitiesCallback,
async_get_current_platform,
)
from homeassistant.util import dt as dt_util from homeassistant.util import dt as dt_util
from .const import ( from .const import (
@ -30,6 +36,9 @@ from .const import (
LOGGER, LOGGER,
) )
SERVICE_CHECK_DATE: Final = "check_date"
CHECK_DATE: Final = "check_date"
def validate_dates(holiday_list: list[str]) -> list[str]: def validate_dates(holiday_list: list[str]) -> list[str]:
"""Validate and adds to list of dates to add or remove.""" """Validate and adds to list of dates to add or remove."""
@ -109,6 +118,15 @@ async def async_setup_entry(
_holiday_string = holiday_date.strftime("%Y-%m-%d") _holiday_string = holiday_date.strftime("%Y-%m-%d")
LOGGER.debug("%s %s", _holiday_string, name) LOGGER.debug("%s %s", _holiday_string, name)
platform = async_get_current_platform()
platform.async_register_entity_service(
SERVICE_CHECK_DATE,
{vol.Required(CHECK_DATE): cv.date},
"check_date",
None,
SupportsResponse.ONLY,
)
async_add_entities( async_add_entities(
[ [
IsWorkdaySensor( IsWorkdaySensor(
@ -192,3 +210,8 @@ class IsWorkdaySensor(BinarySensorEntity):
if self.is_exclude(day_of_week, adjusted_date): if self.is_exclude(day_of_week, adjusted_date):
self._attr_is_on = False self._attr_is_on = False
async def check_date(self, check_date: date) -> ServiceResponse:
"""Check if date is workday or not."""
holiday_date = check_date in self._obj_holidays
return {"workday": not holiday_date}

View File

@ -0,0 +1,9 @@
check_date:
target:
entity:
integration: workday
fields:
check_date:
example: "2022-12-25"
selector:
date:

View File

@ -146,5 +146,17 @@
} }
} }
} }
},
"services": {
"check_date": {
"name": "Check date",
"description": "Check if date is workday.",
"fields": {
"check_date": {
"name": "Date",
"description": "Date to check if workday."
}
}
}
} }
} }

View File

@ -1,10 +1,12 @@
"""Tests the Home Assistant workday binary sensor.""" """Tests the Home Assistant workday binary sensor."""
from datetime import datetime from datetime import date, datetime
from typing import Any from typing import Any
from freezegun.api import FrozenDateTimeFactory from freezegun.api import FrozenDateTimeFactory
import pytest import pytest
from homeassistant.components.workday.binary_sensor import SERVICE_CHECK_DATE
from homeassistant.components.workday.const import DOMAIN
from homeassistant.core import HomeAssistant from homeassistant.core import HomeAssistant
from homeassistant.setup import async_setup_component from homeassistant.setup import async_setup_component
from homeassistant.util.dt import UTC from homeassistant.util.dt import UTC
@ -273,3 +275,39 @@ async def test_setup_date_range(
state = hass.states.get("binary_sensor.workday_sensor") state = hass.states.get("binary_sensor.workday_sensor")
assert state.state == "on" assert state.state == "on"
async def test_check_date_service(
hass: HomeAssistant,
freezer: FrozenDateTimeFactory,
) -> None:
"""Test check date service with response data."""
freezer.move_to(datetime(2017, 1, 6, 12, tzinfo=UTC)) # Friday
await init_integration(hass, TEST_CONFIG_WITH_PROVINCE)
hass.states.get("binary_sensor.workday_sensor")
response = await hass.services.async_call(
DOMAIN,
SERVICE_CHECK_DATE,
{
"entity_id": "binary_sensor.workday_sensor",
"check_date": date(2022, 12, 25), # Christmas Day
},
blocking=True,
return_response=True,
)
assert response == {"binary_sensor.workday_sensor": {"workday": False}}
response = await hass.services.async_call(
DOMAIN,
SERVICE_CHECK_DATE,
{
"entity_id": "binary_sensor.workday_sensor",
"check_date": date(2022, 12, 23), # Normal Friday
},
blocking=True,
return_response=True,
)
assert response == {"binary_sensor.workday_sensor": {"workday": True}}