Use dataclass properties in tesla_wall_connector discovery (#60741)

Co-authored-by: epenet <epenet@users.noreply.github.com>
This commit is contained in:
epenet 2021-12-01 19:39:43 +01:00 committed by GitHub
parent 3d5f4e54ea
commit a3cccb50c7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 20 deletions

View File

@ -9,7 +9,7 @@ from tesla_wall_connector.exceptions import WallConnectorError
import voluptuous as vol
from homeassistant import config_entries
from homeassistant.components.dhcp import IP_ADDRESS
from homeassistant.components import dhcp
from homeassistant.const import CONF_HOST
from homeassistant.core import HomeAssistant
from homeassistant.data_entry_flow import FlowResult
@ -45,12 +45,12 @@ class ConfigFlow(config_entries.ConfigFlow, domain=DOMAIN):
def __init__(self) -> None:
"""Initialize config flow."""
super().__init__()
self.ip_address = None
self.ip_address: str | None = None
self.serial_number = None
async def async_step_dhcp(self, discovery_info) -> FlowResult:
async def async_step_dhcp(self, discovery_info: dhcp.DhcpServiceInfo) -> FlowResult:
"""Handle dhcp discovery."""
self.ip_address = discovery_info[IP_ADDRESS]
self.ip_address = discovery_info.ip
_LOGGER.debug("Discovered Tesla Wall Connector at [%s]", self.ip_address)
self._async_abort_entries_match({CONF_HOST: self.ip_address})

View File

@ -4,7 +4,7 @@ from unittest.mock import patch
from tesla_wall_connector.exceptions import WallConnectorConnectionError
from homeassistant import config_entries
from homeassistant.components.dhcp import HOSTNAME, IP_ADDRESS, MAC_ADDRESS
from homeassistant.components import dhcp
from homeassistant.components.tesla_wall_connector.const import DOMAIN
from homeassistant.const import CONF_HOST
from homeassistant.core import HomeAssistant
@ -112,11 +112,11 @@ async def test_dhcp_can_finish(
result = await hass.config_entries.flow.async_init(
DOMAIN,
context={"source": config_entries.SOURCE_DHCP},
data={
HOSTNAME: "teslawallconnector_abc",
IP_ADDRESS: "1.2.3.4",
MAC_ADDRESS: "DC:44:27:12:12",
},
data=dhcp.DhcpServiceInfo(
hostname="teslawallconnector_abc",
ip="1.2.3.4",
macaddress="DC:44:27:12:12",
),
)
await hass.async_block_till_done()
assert result["type"] == "form"
@ -143,11 +143,11 @@ async def test_dhcp_already_exists(mock_wall_connector_version, hass):
result = await hass.config_entries.flow.async_init(
DOMAIN,
context={"source": config_entries.SOURCE_DHCP},
data={
HOSTNAME: "teslawallconnector_aabbcc",
IP_ADDRESS: "1.2.3.4",
MAC_ADDRESS: "aa:bb:cc:dd:ee:ff",
},
data=dhcp.DhcpServiceInfo(
hostname="teslawallconnector_aabbcc",
ip="1.2.3.4",
macaddress="aa:bb:cc:dd:ee:ff",
),
)
await hass.async_block_till_done()
@ -165,11 +165,11 @@ async def test_dhcp_error_from_wall_connector(mock_wall_connector_version, hass)
result = await hass.config_entries.flow.async_init(
DOMAIN,
context={"source": config_entries.SOURCE_DHCP},
data={
HOSTNAME: "teslawallconnector_aabbcc",
IP_ADDRESS: "1.2.3.4",
MAC_ADDRESS: "aa:bb:cc:dd:ee:ff",
},
data=dhcp.DhcpServiceInfo(
hostname="teslawallconnector_aabbcc",
ip="1.2.3.4",
macaddress="aa:bb:cc:dd:ee:ff",
),
)
await hass.async_block_till_done()