mirror of
https://github.com/home-assistant/core.git
synced 2025-07-15 17:27:10 +00:00
Do not try to stop the shelly ble scanner if not connected (#83424)
Co-authored-by: Shay Levy <levyshay1@gmail.com>
This commit is contained in:
parent
41d5256533
commit
b665a060f7
@ -564,7 +564,8 @@ class ShellyRpcCoordinator(DataUpdateCoordinator):
|
|||||||
|
|
||||||
async def shutdown(self) -> None:
|
async def shutdown(self) -> None:
|
||||||
"""Shutdown the coordinator."""
|
"""Shutdown the coordinator."""
|
||||||
await async_stop_scanner(self.device)
|
if self.device.connected:
|
||||||
|
await async_stop_scanner(self.device)
|
||||||
await self.device.shutdown()
|
await self.device.shutdown()
|
||||||
await self._async_disconnected()
|
await self._async_disconnected()
|
||||||
|
|
||||||
|
@ -1,12 +1,16 @@
|
|||||||
"""Test cases for the Shelly component."""
|
"""Test cases for the Shelly component."""
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
from unittest.mock import AsyncMock
|
from unittest.mock import AsyncMock, patch
|
||||||
|
|
||||||
from aioshelly.exceptions import DeviceConnectionError, InvalidAuthError
|
from aioshelly.exceptions import DeviceConnectionError, InvalidAuthError
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
from homeassistant.components.shelly.const import DOMAIN
|
from homeassistant.components.shelly.const import (
|
||||||
|
CONF_BLE_SCANNER_MODE,
|
||||||
|
DOMAIN,
|
||||||
|
BLEScannerMode,
|
||||||
|
)
|
||||||
from homeassistant.config_entries import SOURCE_REAUTH, ConfigEntryState
|
from homeassistant.config_entries import SOURCE_REAUTH, ConfigEntryState
|
||||||
from homeassistant.const import STATE_ON, STATE_UNAVAILABLE
|
from homeassistant.const import STATE_ON, STATE_UNAVAILABLE
|
||||||
from homeassistant.helpers import device_registry
|
from homeassistant.helpers import device_registry
|
||||||
@ -183,3 +187,27 @@ async def test_entry_unload_device_not_ready(
|
|||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert entry.state is ConfigEntryState.NOT_LOADED
|
assert entry.state is ConfigEntryState.NOT_LOADED
|
||||||
|
|
||||||
|
|
||||||
|
async def test_entry_unload_not_connected(hass, mock_rpc_device, monkeypatch):
|
||||||
|
"""Test entry unload when not connected."""
|
||||||
|
with patch(
|
||||||
|
"homeassistant.components.shelly.coordinator.async_stop_scanner"
|
||||||
|
) as mock_stop_scanner:
|
||||||
|
|
||||||
|
entry = await init_integration(
|
||||||
|
hass, 2, options={CONF_BLE_SCANNER_MODE: BLEScannerMode.ACTIVE}
|
||||||
|
)
|
||||||
|
entity_id = "switch.test_switch_0"
|
||||||
|
|
||||||
|
assert entry.state is ConfigEntryState.LOADED
|
||||||
|
assert hass.states.get(entity_id).state is STATE_ON
|
||||||
|
assert not mock_stop_scanner.call_count
|
||||||
|
|
||||||
|
monkeypatch.setattr(mock_rpc_device, "connected", False)
|
||||||
|
|
||||||
|
await hass.config_entries.async_reload(entry.entry_id)
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
assert not mock_stop_scanner.call_count
|
||||||
|
assert entry.state is ConfigEntryState.LOADED
|
||||||
|
Loading…
x
Reference in New Issue
Block a user