Fix ruckus_unleashed for python 3.11 (#94835)
Co-authored-by: Tony <29752086+ms264556@users.noreply.github.com>
This commit is contained in:
parent
739eeeccb0
commit
ef7a246f09
13 changed files with 430 additions and 299 deletions
|
@ -1,18 +1,16 @@
|
|||
"""Test the Ruckus Unleashed config flow."""
|
||||
from unittest.mock import patch
|
||||
from unittest.mock import AsyncMock
|
||||
|
||||
from pyruckus.exceptions import AuthenticationError
|
||||
from aioruckus.const import ERROR_CONNECT_TIMEOUT, ERROR_LOGIN_INCORRECT
|
||||
from aioruckus.exceptions import AuthenticationError
|
||||
|
||||
from homeassistant.components.ruckus_unleashed import (
|
||||
API_AP,
|
||||
API_DEVICE_NAME,
|
||||
API_ID,
|
||||
API_MAC,
|
||||
API_MODEL,
|
||||
API_SYSTEM_OVERVIEW,
|
||||
API_VERSION,
|
||||
DOMAIN,
|
||||
MANUFACTURER,
|
||||
from homeassistant.components.ruckus_unleashed import DOMAIN, MANUFACTURER
|
||||
from homeassistant.components.ruckus_unleashed.const import (
|
||||
API_AP_DEVNAME,
|
||||
API_AP_MAC,
|
||||
API_AP_MODEL,
|
||||
API_SYS_SYSINFO,
|
||||
API_SYS_SYSINFO_VERSION,
|
||||
)
|
||||
from homeassistant.config_entries import ConfigEntryState
|
||||
from homeassistant.core import HomeAssistant
|
||||
|
@ -22,7 +20,7 @@ from homeassistant.helpers.device_registry import CONNECTION_NETWORK_MAC
|
|||
from . import (
|
||||
DEFAULT_AP_INFO,
|
||||
DEFAULT_SYSTEM_INFO,
|
||||
DEFAULT_TITLE,
|
||||
RuckusAjaxApiPatchContext,
|
||||
init_integration,
|
||||
mock_config_entry,
|
||||
)
|
||||
|
@ -31,9 +29,8 @@ from . import (
|
|||
async def test_setup_entry_login_error(hass: HomeAssistant) -> None:
|
||||
"""Test entry setup failed due to login error."""
|
||||
entry = mock_config_entry()
|
||||
with patch(
|
||||
"homeassistant.components.ruckus_unleashed.Ruckus.connect",
|
||||
side_effect=AuthenticationError,
|
||||
with RuckusAjaxApiPatchContext(
|
||||
login_mock=AsyncMock(side_effect=AuthenticationError(ERROR_LOGIN_INCORRECT))
|
||||
):
|
||||
entry.add_to_hass(hass)
|
||||
result = await hass.config_entries.async_setup(entry.entry_id)
|
||||
|
@ -45,9 +42,8 @@ async def test_setup_entry_login_error(hass: HomeAssistant) -> None:
|
|||
async def test_setup_entry_connection_error(hass: HomeAssistant) -> None:
|
||||
"""Test entry setup failed due to connection error."""
|
||||
entry = mock_config_entry()
|
||||
with patch(
|
||||
"homeassistant.components.ruckus_unleashed.Ruckus.connect",
|
||||
side_effect=ConnectionError,
|
||||
with RuckusAjaxApiPatchContext(
|
||||
login_mock=AsyncMock(side_effect=ConnectionError(ERROR_CONNECT_TIMEOUT))
|
||||
):
|
||||
entry.add_to_hass(hass)
|
||||
await hass.config_entries.async_setup(entry.entry_id)
|
||||
|
@ -60,19 +56,22 @@ async def test_router_device_setup(hass: HomeAssistant) -> None:
|
|||
"""Test a router device is created."""
|
||||
await init_integration(hass)
|
||||
|
||||
device_info = DEFAULT_AP_INFO[API_AP][API_ID]["1"]
|
||||
device_info = DEFAULT_AP_INFO[0]
|
||||
|
||||
device_registry = dr.async_get(hass)
|
||||
device = device_registry.async_get_device(
|
||||
identifiers={(CONNECTION_NETWORK_MAC, device_info[API_MAC])},
|
||||
connections={(CONNECTION_NETWORK_MAC, device_info[API_MAC])},
|
||||
identifiers={(CONNECTION_NETWORK_MAC, device_info[API_AP_MAC])},
|
||||
connections={(CONNECTION_NETWORK_MAC, device_info[API_AP_MAC])},
|
||||
)
|
||||
|
||||
assert device
|
||||
assert device.manufacturer == MANUFACTURER
|
||||
assert device.model == device_info[API_MODEL]
|
||||
assert device.name == device_info[API_DEVICE_NAME]
|
||||
assert device.sw_version == DEFAULT_SYSTEM_INFO[API_SYSTEM_OVERVIEW][API_VERSION]
|
||||
assert device.model == device_info[API_AP_MODEL]
|
||||
assert device.name == device_info[API_AP_DEVNAME]
|
||||
assert (
|
||||
device.sw_version
|
||||
== DEFAULT_SYSTEM_INFO[API_SYS_SYSINFO][API_SYS_SYSINFO_VERSION]
|
||||
)
|
||||
assert device.via_device_id is None
|
||||
|
||||
|
||||
|
@ -83,31 +82,9 @@ async def test_unload_entry(hass: HomeAssistant) -> None:
|
|||
assert len(hass.config_entries.async_entries(DOMAIN)) == 1
|
||||
assert entry.state is ConfigEntryState.LOADED
|
||||
|
||||
assert await hass.config_entries.async_unload(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
with RuckusAjaxApiPatchContext():
|
||||
assert await hass.config_entries.async_unload(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
|
||||
assert entry.state is ConfigEntryState.NOT_LOADED
|
||||
assert not hass.data.get(DOMAIN)
|
||||
|
||||
|
||||
async def test_config_not_ready_during_setup(hass: HomeAssistant) -> None:
|
||||
"""Test we throw a ConfigNotReady if Coordinator update fails."""
|
||||
entry = mock_config_entry()
|
||||
with patch(
|
||||
"homeassistant.components.ruckus_unleashed.Ruckus.connect",
|
||||
return_value=None,
|
||||
), patch(
|
||||
"homeassistant.components.ruckus_unleashed.Ruckus.mesh_name",
|
||||
return_value=DEFAULT_TITLE,
|
||||
), patch(
|
||||
"homeassistant.components.ruckus_unleashed.Ruckus.system_info",
|
||||
return_value=DEFAULT_SYSTEM_INFO,
|
||||
), patch(
|
||||
"homeassistant.components.ruckus_unleashed.RuckusUnleashedDataUpdateCoordinator._async_update_data",
|
||||
side_effect=ConnectionError,
|
||||
):
|
||||
entry.add_to_hass(hass)
|
||||
await hass.config_entries.async_setup(entry.entry_id)
|
||||
await hass.async_block_till_done()
|
||||
|
||||
assert entry.state is ConfigEntryState.SETUP_RETRY
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue