mirror of
https://github.com/home-assistant/core.git
synced 2025-12-24 12:59:34 +00:00
Don't directly update config entries (#20877)
* Don't directly update config entries * Use ConfigEntryNotReady * Fix tests * Remove old test * Lint
This commit is contained in:
@@ -1,6 +1,9 @@
|
||||
"""Test Hue bridge."""
|
||||
from unittest.mock import Mock, patch
|
||||
|
||||
import pytest
|
||||
|
||||
from homeassistant.exceptions import ConfigEntryNotReady
|
||||
from homeassistant.components.hue import bridge, errors
|
||||
|
||||
from tests.common import mock_coro
|
||||
@@ -48,32 +51,10 @@ async def test_bridge_setup_timeout(hass):
|
||||
entry.data = {'host': '1.2.3.4', 'username': 'mock-username'}
|
||||
hue_bridge = bridge.HueBridge(hass, entry, False, False)
|
||||
|
||||
with patch.object(bridge, 'get_bridge', side_effect=errors.CannotConnect):
|
||||
assert await hue_bridge.async_setup() is False
|
||||
|
||||
assert len(hass.helpers.event.async_call_later.mock_calls) == 1
|
||||
# Assert we are going to wait 2 seconds
|
||||
assert hass.helpers.event.async_call_later.mock_calls[0][1][0] == 2
|
||||
|
||||
|
||||
async def test_reset_cancels_retry_setup():
|
||||
"""Test resetting a bridge while we're waiting to retry setup."""
|
||||
hass = Mock()
|
||||
entry = Mock()
|
||||
entry.data = {'host': '1.2.3.4', 'username': 'mock-username'}
|
||||
hue_bridge = bridge.HueBridge(hass, entry, False, False)
|
||||
|
||||
with patch.object(bridge, 'get_bridge', side_effect=errors.CannotConnect):
|
||||
assert await hue_bridge.async_setup() is False
|
||||
|
||||
mock_call_later = hass.helpers.event.async_call_later
|
||||
|
||||
assert len(mock_call_later.mock_calls) == 1
|
||||
|
||||
assert await hue_bridge.async_reset()
|
||||
|
||||
assert len(mock_call_later.mock_calls) == 2
|
||||
assert len(mock_call_later.return_value.mock_calls) == 1
|
||||
with patch.object(
|
||||
bridge, 'get_bridge', side_effect=errors.CannotConnect
|
||||
), pytest.raises(ConfigEntryNotReady):
|
||||
await hue_bridge.async_setup()
|
||||
|
||||
|
||||
async def test_reset_if_entry_had_wrong_auth():
|
||||
|
||||
Reference in New Issue
Block a user