From 96c62d746d71c8f00520066f8f97a1ea0e97e9c9 Mon Sep 17 00:00:00 2001 From: andreapier Date: Mon, 11 Nov 2024 09:23:41 +0100 Subject: [PATCH] Fix alarm panel deprecations --- .../econnect_metronet/alarm_control_panel.py | 22 ++++------ .../econnect_metronet/devices.py | 24 ++++------- tests/test_devices.py | 40 ++++++++----------- 3 files changed, 31 insertions(+), 55 deletions(-) diff --git a/custom_components/econnect_metronet/alarm_control_panel.py b/custom_components/econnect_metronet/alarm_control_panel.py index fc1cf88..dc704fe 100644 --- a/custom_components/econnect_metronet/alarm_control_panel.py +++ b/custom_components/econnect_metronet/alarm_control_panel.py @@ -4,22 +4,14 @@ from homeassistant.components.alarm_control_panel import ( AlarmControlPanelEntity, + AlarmControlPanelState, CodeFormat, ) from homeassistant.components.alarm_control_panel.const import ( AlarmControlPanelEntityFeature as AlarmFeatures, ) from homeassistant.config_entries import ConfigEntry -from homeassistant.const import ( - CONF_USERNAME, - STATE_ALARM_ARMED_AWAY, - STATE_ALARM_ARMED_HOME, - STATE_ALARM_ARMED_NIGHT, - STATE_ALARM_ARMED_VACATION, - STATE_ALARM_ARMING, - STATE_ALARM_DISARMED, - STATE_ALARM_DISARMING, -) +from homeassistant.const import CONF_USERNAME from homeassistant.core import HomeAssistant from homeassistant.helpers.update_coordinator import CoordinatorEntity @@ -91,19 +83,19 @@ def supported_features(self): """Return the list of supported features.""" return AlarmFeatures.ARM_HOME | AlarmFeatures.ARM_AWAY | AlarmFeatures.ARM_NIGHT | AlarmFeatures.ARM_VACATION - @set_device_state(STATE_ALARM_DISARMED, STATE_ALARM_DISARMING) + @set_device_state(AlarmControlPanelState.DISARMED, AlarmControlPanelState.DISARMING) @retry_refresh_token async def async_alarm_disarm(self, code=None): """Send disarm command.""" await self.hass.async_add_executor_job(self._device.disarm, code) - @set_device_state(STATE_ALARM_ARMED_AWAY, STATE_ALARM_ARMING) + @set_device_state(AlarmControlPanelState.ARMED_AWAY, AlarmControlPanelState.ARMING) @retry_refresh_token async def async_alarm_arm_away(self, code=None): """Send arm away command.""" await self.hass.async_add_executor_job(self._device.arm, code, self._device._sectors_away) - @set_device_state(STATE_ALARM_ARMED_HOME, STATE_ALARM_ARMING) + @set_device_state(AlarmControlPanelState.ARMED_HOME, AlarmControlPanelState.ARMING) @retry_refresh_token async def async_alarm_arm_home(self, code=None): """Send arm home command.""" @@ -113,7 +105,7 @@ async def async_alarm_arm_home(self, code=None): await self.hass.async_add_executor_job(self._device.arm, code, self._device._sectors_home) - @set_device_state(STATE_ALARM_ARMED_NIGHT, STATE_ALARM_ARMING) + @set_device_state(AlarmControlPanelState.ARMED_NIGHT, AlarmControlPanelState.ARMING) @retry_refresh_token async def async_alarm_arm_night(self, code=None): """Send arm night command.""" @@ -123,7 +115,7 @@ async def async_alarm_arm_night(self, code=None): await self.hass.async_add_executor_job(self._device.arm, code, self._device._sectors_night) - @set_device_state(STATE_ALARM_ARMED_VACATION, STATE_ALARM_ARMING) + @set_device_state(AlarmControlPanelState.ARMED_VACATION, AlarmControlPanelState.ARMING) @retry_refresh_token async def async_alarm_arm_vacation(self, code=None): """Send arm vacation command.""" diff --git a/custom_components/econnect_metronet/devices.py b/custom_components/econnect_metronet/devices.py index a5319b0..e8a0cb1 100644 --- a/custom_components/econnect_metronet/devices.py +++ b/custom_components/econnect_metronet/devices.py @@ -10,16 +10,8 @@ LockError, ParseError, ) -from homeassistant.const import ( - STATE_ALARM_ARMED_AWAY, - STATE_ALARM_ARMED_HOME, - STATE_ALARM_ARMED_NIGHT, - STATE_ALARM_ARMED_VACATION, - STATE_ALARM_ARMING, - STATE_ALARM_DISARMED, - STATE_ALARM_DISARMING, - STATE_UNAVAILABLE, -) +from homeassistant.components.alarm_control_panel import AlarmControlPanelState +from homeassistant.const import STATE_UNAVAILABLE from requests.exceptions import HTTPError from .const import ( @@ -225,12 +217,12 @@ def get_state(self): """ # If the system is arming or disarming, return the current state # to prevent the state from being updated while the system is in transition. - if self.state in [STATE_ALARM_ARMING, STATE_ALARM_DISARMING]: + if self.state in [AlarmControlPanelState.ARMING, AlarmControlPanelState.DISARMING]: return self.state sectors_armed = dict(self.items(q.SECTORS, status=True)) if not sectors_armed: - return STATE_ALARM_DISARMED + return AlarmControlPanelState.DISARMED # Note: `element` is the sector ID you use to arm/disarm the sector. sectors = [sectors["element"] for sectors in sectors_armed.values()] @@ -238,15 +230,15 @@ def get_state(self): # regardless of whether the input lists were pre-sorted or not. sectors_armed_sorted = sorted(sectors) if sectors_armed_sorted == sorted(self._sectors_home): - return STATE_ALARM_ARMED_HOME + return AlarmControlPanelState.ARMED_HOME if sectors_armed_sorted == sorted(self._sectors_night): - return STATE_ALARM_ARMED_NIGHT + return AlarmControlPanelState.ARMED_NIGHT if sectors_armed_sorted == sorted(self._sectors_vacation): - return STATE_ALARM_ARMED_VACATION + return AlarmControlPanelState.ARMED_VACATION - return STATE_ALARM_ARMED_AWAY + return AlarmControlPanelState.ARMED_AWAY def get_status(self, query: int, id: int) -> Union[bool, int]: """Get the status of an item in the device inventory specified by query and id. diff --git a/tests/test_devices.py b/tests/test_devices.py index f634122..3292a90 100644 --- a/tests/test_devices.py +++ b/tests/test_devices.py @@ -2,16 +2,8 @@ import responses from elmo import query as q from elmo.api.exceptions import CodeError, CredentialError, LockError, ParseError -from homeassistant.const import ( - STATE_ALARM_ARMED_AWAY, - STATE_ALARM_ARMED_HOME, - STATE_ALARM_ARMED_NIGHT, - STATE_ALARM_ARMED_VACATION, - STATE_ALARM_ARMING, - STATE_ALARM_DISARMED, - STATE_ALARM_DISARMING, - STATE_UNAVAILABLE, -) +from homeassistant.components.alarm_control_panel import AlarmControlPanelState +from homeassistant.const import STATE_UNAVAILABLE from requests.exceptions import HTTPError from requests.models import Response @@ -1468,7 +1460,7 @@ def test_get_state_no_sectors_armed(alarm_device): alarm_device._sectors_night = [] alarm_device._inventory = {9: {}} # Test - assert alarm_device.get_state() == STATE_ALARM_DISARMED + assert alarm_device.get_state() == AlarmControlPanelState.DISARMED def test_get_state_armed_home(alarm_device): @@ -1482,7 +1474,7 @@ def test_get_state_armed_home(alarm_device): } } # Test - assert alarm_device.get_state() == STATE_ALARM_ARMED_HOME + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_HOME def test_get_state_armed_home_out_of_order(alarm_device): @@ -1496,7 +1488,7 @@ def test_get_state_armed_home_out_of_order(alarm_device): } } # Test - assert alarm_device.get_state() == STATE_ALARM_ARMED_HOME + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_HOME def test_get_state_armed_night(alarm_device): @@ -1510,7 +1502,7 @@ def test_get_state_armed_night(alarm_device): } } # Test (out of order keys to test sorting) - assert alarm_device.get_state() == STATE_ALARM_ARMED_NIGHT + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_NIGHT def test_get_state_armed_night_out_of_order(alarm_device): @@ -1524,7 +1516,7 @@ def test_get_state_armed_night_out_of_order(alarm_device): } } # Test - assert alarm_device.get_state() == STATE_ALARM_ARMED_NIGHT + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_NIGHT def test_get_state_armed_vacation(alarm_device): @@ -1538,7 +1530,7 @@ def test_get_state_armed_vacation(alarm_device): } } # Test (out of order keys to test sorting) - assert alarm_device.get_state() == STATE_ALARM_ARMED_VACATION + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_VACATION def test_get_state_armed_vacation_out_of_order(alarm_device): @@ -1552,7 +1544,7 @@ def test_get_state_armed_vacation_out_of_order(alarm_device): } } # Test - assert alarm_device.get_state() == STATE_ALARM_ARMED_VACATION + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_VACATION def test_get_state_armed_away(alarm_device): @@ -1569,7 +1561,7 @@ def test_get_state_armed_away(alarm_device): } } # Test - assert alarm_device.get_state() == STATE_ALARM_ARMED_AWAY + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_AWAY def test_get_state_armed_mixed(alarm_device): @@ -1586,7 +1578,7 @@ def test_get_state_armed_mixed(alarm_device): } } # Test - assert alarm_device.get_state() == STATE_ALARM_ARMED_AWAY + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_AWAY def test_get_state_armed_away_with_config(alarm_device): @@ -1603,7 +1595,7 @@ def test_get_state_armed_away_with_config(alarm_device): } } # Test - assert alarm_device.get_state() == STATE_ALARM_ARMED_AWAY + assert alarm_device.get_state() == AlarmControlPanelState.ARMED_AWAY def test_get_state_while_disarming(alarm_device): @@ -1612,9 +1604,9 @@ def test_get_state_while_disarming(alarm_device): alarm_device._sectors_home = [] alarm_device._sectors_night = [] alarm_device._inventory = {9: {}} - alarm_device.state = STATE_ALARM_DISARMING + alarm_device.state = AlarmControlPanelState.DISARMING # Test - assert alarm_device.get_state() == STATE_ALARM_DISARMING + assert alarm_device.get_state() == AlarmControlPanelState.DISARMING def test_get_state_while_arming(alarm_device): @@ -1623,9 +1615,9 @@ def test_get_state_while_arming(alarm_device): alarm_device._sectors_home = [] alarm_device._sectors_night = [] alarm_device._inventory = {9: {}} - alarm_device.state = STATE_ALARM_ARMING + alarm_device.state = AlarmControlPanelState.ARMING # Test - assert alarm_device.get_state() == STATE_ALARM_ARMING + assert alarm_device.get_state() == AlarmControlPanelState.ARMING class TestTurnOff: