mirror of
https://github.com/home-assistant/core.git
synced 2025-07-21 12:17:07 +00:00
Deprecate Valve binary sensor in SmartThings (#140751)
Deprecate Valve binary sensor
This commit is contained in:
parent
5351fe3f9b
commit
bbe2a95b3d
@ -6,17 +6,25 @@ from dataclasses import dataclass
|
|||||||
|
|
||||||
from pysmartthings import Attribute, Capability, SmartThings
|
from pysmartthings import Attribute, Capability, SmartThings
|
||||||
|
|
||||||
|
from homeassistant.components.automation import automations_with_entity
|
||||||
from homeassistant.components.binary_sensor import (
|
from homeassistant.components.binary_sensor import (
|
||||||
BinarySensorDeviceClass,
|
BinarySensorDeviceClass,
|
||||||
BinarySensorEntity,
|
BinarySensorEntity,
|
||||||
BinarySensorEntityDescription,
|
BinarySensorEntityDescription,
|
||||||
)
|
)
|
||||||
|
from homeassistant.components.script import scripts_with_entity
|
||||||
from homeassistant.const import EntityCategory
|
from homeassistant.const import EntityCategory
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
|
from homeassistant.helpers import entity_registry as er
|
||||||
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
||||||
|
from homeassistant.helpers.issue_registry import (
|
||||||
|
IssueSeverity,
|
||||||
|
async_create_issue,
|
||||||
|
async_delete_issue,
|
||||||
|
)
|
||||||
|
|
||||||
from . import FullDevice, SmartThingsConfigEntry
|
from . import FullDevice, SmartThingsConfigEntry
|
||||||
from .const import MAIN
|
from .const import DOMAIN, MAIN
|
||||||
from .entity import SmartThingsEntity
|
from .entity import SmartThingsEntity
|
||||||
|
|
||||||
|
|
||||||
@ -151,3 +159,55 @@ class SmartThingsBinarySensor(SmartThingsEntity, BinarySensorEntity):
|
|||||||
self.get_attribute_value(self.capability, self._attribute)
|
self.get_attribute_value(self.capability, self._attribute)
|
||||||
== self.entity_description.is_on_key
|
== self.entity_description.is_on_key
|
||||||
)
|
)
|
||||||
|
|
||||||
|
async def async_added_to_hass(self) -> None:
|
||||||
|
"""Call when entity is added to hass."""
|
||||||
|
await super().async_added_to_hass()
|
||||||
|
if self.capability is not Capability.VALVE:
|
||||||
|
return
|
||||||
|
automations = automations_with_entity(self.hass, self.entity_id)
|
||||||
|
scripts = scripts_with_entity(self.hass, self.entity_id)
|
||||||
|
items = automations + scripts
|
||||||
|
if not items:
|
||||||
|
return
|
||||||
|
|
||||||
|
entity_reg: er.EntityRegistry = er.async_get(self.hass)
|
||||||
|
entity_automations = [
|
||||||
|
automation_entity
|
||||||
|
for automation_id in automations
|
||||||
|
if (automation_entity := entity_reg.async_get(automation_id))
|
||||||
|
]
|
||||||
|
entity_scripts = [
|
||||||
|
script_entity
|
||||||
|
for script_id in scripts
|
||||||
|
if (script_entity := entity_reg.async_get(script_id))
|
||||||
|
]
|
||||||
|
|
||||||
|
items_list = [
|
||||||
|
f"- [{item.original_name}](/config/automation/edit/{item.unique_id})"
|
||||||
|
for item in entity_automations
|
||||||
|
] + [
|
||||||
|
f"- [{item.original_name}](/config/script/edit/{item.unique_id})"
|
||||||
|
for item in entity_scripts
|
||||||
|
]
|
||||||
|
|
||||||
|
async_create_issue(
|
||||||
|
self.hass,
|
||||||
|
DOMAIN,
|
||||||
|
f"deprecated_binary_valve_{self.entity_id}",
|
||||||
|
breaks_in_ha_version="2025.10.0",
|
||||||
|
is_fixable=False,
|
||||||
|
severity=IssueSeverity.WARNING,
|
||||||
|
translation_key="deprecated_binary_valve",
|
||||||
|
translation_placeholders={
|
||||||
|
"entity": self.entity_id,
|
||||||
|
"items": "\n".join(items_list),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
async def async_will_remove_from_hass(self) -> None:
|
||||||
|
"""Call when entity will be removed from hass."""
|
||||||
|
await super().async_will_remove_from_hass()
|
||||||
|
async_delete_issue(
|
||||||
|
self.hass, DOMAIN, f"deprecated_binary_valve_{self.entity_id}"
|
||||||
|
)
|
||||||
|
@ -390,5 +390,11 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"issues": {
|
||||||
|
"deprecated_binary_valve": {
|
||||||
|
"title": "Deprecated valve binary sensor detected in some automations or scripts",
|
||||||
|
"description": "The valve binary sensor `{entity}` is deprecated and is used in the following automations or scripts:\n{items}\n\nA valve entity with controls is available and should be used going forward; Please use it on the above automations or scripts to fix this issue."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6,9 +6,14 @@ from pysmartthings import Attribute, Capability
|
|||||||
import pytest
|
import pytest
|
||||||
from syrupy import SnapshotAssertion
|
from syrupy import SnapshotAssertion
|
||||||
|
|
||||||
|
from homeassistant.components import automation, script
|
||||||
|
from homeassistant.components.automation import automations_with_entity
|
||||||
|
from homeassistant.components.script import scripts_with_entity
|
||||||
|
from homeassistant.components.smartthings import DOMAIN
|
||||||
from homeassistant.const import STATE_OFF, STATE_ON, Platform
|
from homeassistant.const import STATE_OFF, STATE_ON, Platform
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
from homeassistant.helpers import entity_registry as er
|
from homeassistant.helpers import entity_registry as er, issue_registry as ir
|
||||||
|
from homeassistant.setup import async_setup_component
|
||||||
|
|
||||||
from . import setup_integration, snapshot_smartthings_entities, trigger_update
|
from . import setup_integration, snapshot_smartthings_entities, trigger_update
|
||||||
|
|
||||||
@ -51,3 +56,65 @@ async def test_state_update(
|
|||||||
)
|
)
|
||||||
|
|
||||||
assert hass.states.get("binary_sensor.refrigerator_door").state == STATE_ON
|
assert hass.states.get("binary_sensor.refrigerator_door").state == STATE_ON
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.usefixtures("entity_registry_enabled_by_default")
|
||||||
|
@pytest.mark.parametrize("device_fixture", ["virtual_valve"])
|
||||||
|
async def test_create_issue(
|
||||||
|
hass: HomeAssistant,
|
||||||
|
devices: AsyncMock,
|
||||||
|
mock_config_entry: MockConfigEntry,
|
||||||
|
issue_registry: ir.IssueRegistry,
|
||||||
|
) -> None:
|
||||||
|
"""Test we create an issue when an automation or script is using a deprecated entity."""
|
||||||
|
entity_id = "binary_sensor.volvo_valve"
|
||||||
|
issue_id = f"deprecated_binary_valve_{entity_id}"
|
||||||
|
|
||||||
|
assert await async_setup_component(
|
||||||
|
hass,
|
||||||
|
automation.DOMAIN,
|
||||||
|
{
|
||||||
|
automation.DOMAIN: {
|
||||||
|
"alias": "test",
|
||||||
|
"trigger": {"platform": "state", "entity_id": entity_id},
|
||||||
|
"action": {
|
||||||
|
"action": "automation.turn_on",
|
||||||
|
"target": {
|
||||||
|
"entity_id": "automation.test",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
)
|
||||||
|
assert await async_setup_component(
|
||||||
|
hass,
|
||||||
|
script.DOMAIN,
|
||||||
|
{
|
||||||
|
script.DOMAIN: {
|
||||||
|
"test": {
|
||||||
|
"sequence": [
|
||||||
|
{
|
||||||
|
"condition": "state",
|
||||||
|
"entity_id": entity_id,
|
||||||
|
"state": "on",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
await setup_integration(hass, mock_config_entry)
|
||||||
|
|
||||||
|
assert automations_with_entity(hass, entity_id)[0] == "automation.test"
|
||||||
|
assert scripts_with_entity(hass, entity_id)[0] == "script.test"
|
||||||
|
|
||||||
|
assert len(issue_registry.issues) == 1
|
||||||
|
assert issue_registry.async_get_issue(DOMAIN, issue_id)
|
||||||
|
|
||||||
|
await hass.config_entries.async_unload(mock_config_entry.entry_id)
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
# Assert the issue is no longer present
|
||||||
|
assert not issue_registry.async_get_issue(DOMAIN, issue_id)
|
||||||
|
assert len(issue_registry.issues) == 0
|
||||||
|
Loading…
x
Reference in New Issue
Block a user