Don't block Supervisor entry setup with refreshing updates (#109809)
parent
3ec0ea3ef9
commit
db16b739a6
|
@ -1001,12 +1001,18 @@ class HassioDataUpdateCoordinator(DataUpdateCoordinator): # pylint: disable=has
|
||||||
raise_on_entry_error: bool = False,
|
raise_on_entry_error: bool = False,
|
||||||
) -> None:
|
) -> None:
|
||||||
"""Refresh data."""
|
"""Refresh data."""
|
||||||
if not scheduled:
|
if not scheduled and not raise_on_auth_failed:
|
||||||
# Force refreshing updates for non-scheduled updates
|
# Force refreshing updates for non-scheduled updates
|
||||||
|
# If `raise_on_auth_failed` is set, it means this is
|
||||||
|
# the first refresh and we do not want to delay
|
||||||
|
# startup or cause a timeout so we only refresh the
|
||||||
|
# updates if this is not a scheduled refresh and
|
||||||
|
# we are not doing the first refresh.
|
||||||
try:
|
try:
|
||||||
await self.hassio.refresh_updates()
|
await self.hassio.refresh_updates()
|
||||||
except HassioAPIError as err:
|
except HassioAPIError as err:
|
||||||
_LOGGER.warning("Error on Supervisor API: %s", err)
|
_LOGGER.warning("Error on Supervisor API: %s", err)
|
||||||
|
|
||||||
await super()._async_refresh(
|
await super()._async_refresh(
|
||||||
log_failures, raise_on_auth_failed, scheduled, raise_on_entry_error
|
log_failures, raise_on_auth_failed, scheduled, raise_on_entry_error
|
||||||
)
|
)
|
||||||
|
|
|
@ -459,7 +459,7 @@ class HassIO:
|
||||||
|
|
||||||
This method returns a coroutine.
|
This method returns a coroutine.
|
||||||
"""
|
"""
|
||||||
return self.send_command("/refresh_updates", timeout=None)
|
return self.send_command("/refresh_updates", timeout=300)
|
||||||
|
|
||||||
@api_data
|
@api_data
|
||||||
def retrieve_discovery_messages(self) -> Coroutine:
|
def retrieve_discovery_messages(self) -> Coroutine:
|
||||||
|
|
|
@ -245,7 +245,7 @@ async def test_setup_api_ping(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result
|
assert result
|
||||||
assert aioclient_mock.call_count == 20
|
assert aioclient_mock.call_count == 19
|
||||||
assert hass.components.hassio.get_core_info()["version_latest"] == "1.0.0"
|
assert hass.components.hassio.get_core_info()["version_latest"] == "1.0.0"
|
||||||
assert hass.components.hassio.is_hassio()
|
assert hass.components.hassio.is_hassio()
|
||||||
|
|
||||||
|
@ -290,7 +290,7 @@ async def test_setup_api_push_api_data(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result
|
assert result
|
||||||
assert aioclient_mock.call_count == 20
|
assert aioclient_mock.call_count == 19
|
||||||
assert not aioclient_mock.mock_calls[1][2]["ssl"]
|
assert not aioclient_mock.mock_calls[1][2]["ssl"]
|
||||||
assert aioclient_mock.mock_calls[1][2]["port"] == 9999
|
assert aioclient_mock.mock_calls[1][2]["port"] == 9999
|
||||||
assert aioclient_mock.mock_calls[1][2]["watchdog"]
|
assert aioclient_mock.mock_calls[1][2]["watchdog"]
|
||||||
|
@ -309,7 +309,7 @@ async def test_setup_api_push_api_data_server_host(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result
|
assert result
|
||||||
assert aioclient_mock.call_count == 20
|
assert aioclient_mock.call_count == 19
|
||||||
assert not aioclient_mock.mock_calls[1][2]["ssl"]
|
assert not aioclient_mock.mock_calls[1][2]["ssl"]
|
||||||
assert aioclient_mock.mock_calls[1][2]["port"] == 9999
|
assert aioclient_mock.mock_calls[1][2]["port"] == 9999
|
||||||
assert not aioclient_mock.mock_calls[1][2]["watchdog"]
|
assert not aioclient_mock.mock_calls[1][2]["watchdog"]
|
||||||
|
@ -326,7 +326,7 @@ async def test_setup_api_push_api_data_default(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result
|
assert result
|
||||||
assert aioclient_mock.call_count == 20
|
assert aioclient_mock.call_count == 19
|
||||||
assert not aioclient_mock.mock_calls[1][2]["ssl"]
|
assert not aioclient_mock.mock_calls[1][2]["ssl"]
|
||||||
assert aioclient_mock.mock_calls[1][2]["port"] == 8123
|
assert aioclient_mock.mock_calls[1][2]["port"] == 8123
|
||||||
refresh_token = aioclient_mock.mock_calls[1][2]["refresh_token"]
|
refresh_token = aioclient_mock.mock_calls[1][2]["refresh_token"]
|
||||||
|
@ -406,7 +406,7 @@ async def test_setup_api_existing_hassio_user(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result
|
assert result
|
||||||
assert aioclient_mock.call_count == 20
|
assert aioclient_mock.call_count == 19
|
||||||
assert not aioclient_mock.mock_calls[1][2]["ssl"]
|
assert not aioclient_mock.mock_calls[1][2]["ssl"]
|
||||||
assert aioclient_mock.mock_calls[1][2]["port"] == 8123
|
assert aioclient_mock.mock_calls[1][2]["port"] == 8123
|
||||||
assert aioclient_mock.mock_calls[1][2]["refresh_token"] == token.token
|
assert aioclient_mock.mock_calls[1][2]["refresh_token"] == token.token
|
||||||
|
@ -423,7 +423,7 @@ async def test_setup_core_push_timezone(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result
|
assert result
|
||||||
assert aioclient_mock.call_count == 20
|
assert aioclient_mock.call_count == 19
|
||||||
assert aioclient_mock.mock_calls[2][2]["timezone"] == "testzone"
|
assert aioclient_mock.mock_calls[2][2]["timezone"] == "testzone"
|
||||||
|
|
||||||
with patch("homeassistant.util.dt.set_default_time_zone"):
|
with patch("homeassistant.util.dt.set_default_time_zone"):
|
||||||
|
@ -443,7 +443,7 @@ async def test_setup_hassio_no_additional_data(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result
|
assert result
|
||||||
assert aioclient_mock.call_count == 20
|
assert aioclient_mock.call_count == 19
|
||||||
assert aioclient_mock.mock_calls[-1][3]["Authorization"] == "Bearer 123456"
|
assert aioclient_mock.mock_calls[-1][3]["Authorization"] == "Bearer 123456"
|
||||||
|
|
||||||
|
|
||||||
|
@ -525,14 +525,14 @@ async def test_service_calls(
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 24
|
assert aioclient_mock.call_count == 23
|
||||||
assert aioclient_mock.mock_calls[-1][2] == "test"
|
assert aioclient_mock.mock_calls[-1][2] == "test"
|
||||||
|
|
||||||
await hass.services.async_call("hassio", "host_shutdown", {})
|
await hass.services.async_call("hassio", "host_shutdown", {})
|
||||||
await hass.services.async_call("hassio", "host_reboot", {})
|
await hass.services.async_call("hassio", "host_reboot", {})
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 26
|
assert aioclient_mock.call_count == 25
|
||||||
|
|
||||||
await hass.services.async_call("hassio", "backup_full", {})
|
await hass.services.async_call("hassio", "backup_full", {})
|
||||||
await hass.services.async_call(
|
await hass.services.async_call(
|
||||||
|
@ -547,7 +547,7 @@ async def test_service_calls(
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 28
|
assert aioclient_mock.call_count == 27
|
||||||
assert aioclient_mock.mock_calls[-1][2] == {
|
assert aioclient_mock.mock_calls[-1][2] == {
|
||||||
"name": "2021-11-13 03:48:00",
|
"name": "2021-11-13 03:48:00",
|
||||||
"homeassistant": True,
|
"homeassistant": True,
|
||||||
|
@ -572,7 +572,7 @@ async def test_service_calls(
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 30
|
assert aioclient_mock.call_count == 29
|
||||||
assert aioclient_mock.mock_calls[-1][2] == {
|
assert aioclient_mock.mock_calls[-1][2] == {
|
||||||
"addons": ["test"],
|
"addons": ["test"],
|
||||||
"folders": ["ssl"],
|
"folders": ["ssl"],
|
||||||
|
@ -591,7 +591,7 @@ async def test_service_calls(
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 31
|
assert aioclient_mock.call_count == 30
|
||||||
assert aioclient_mock.mock_calls[-1][2] == {
|
assert aioclient_mock.mock_calls[-1][2] == {
|
||||||
"name": "backup_name",
|
"name": "backup_name",
|
||||||
"location": "backup_share",
|
"location": "backup_share",
|
||||||
|
@ -607,7 +607,7 @@ async def test_service_calls(
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 32
|
assert aioclient_mock.call_count == 31
|
||||||
assert aioclient_mock.mock_calls[-1][2] == {
|
assert aioclient_mock.mock_calls[-1][2] == {
|
||||||
"name": "2021-11-13 03:48:00",
|
"name": "2021-11-13 03:48:00",
|
||||||
"location": None,
|
"location": None,
|
||||||
|
@ -625,7 +625,7 @@ async def test_service_calls(
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 34
|
assert aioclient_mock.call_count == 33
|
||||||
assert aioclient_mock.mock_calls[-1][2] == {
|
assert aioclient_mock.mock_calls[-1][2] == {
|
||||||
"name": "2021-11-13 11:48:00",
|
"name": "2021-11-13 11:48:00",
|
||||||
"location": None,
|
"location": None,
|
||||||
|
@ -702,12 +702,12 @@ async def test_service_calls_core(
|
||||||
await hass.services.async_call("homeassistant", "stop")
|
await hass.services.async_call("homeassistant", "stop")
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 6
|
assert aioclient_mock.call_count == 5
|
||||||
|
|
||||||
await hass.services.async_call("homeassistant", "check_config")
|
await hass.services.async_call("homeassistant", "check_config")
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 6
|
assert aioclient_mock.call_count == 5
|
||||||
|
|
||||||
with patch(
|
with patch(
|
||||||
"homeassistant.config.async_check_ha_config_file", return_value=None
|
"homeassistant.config.async_check_ha_config_file", return_value=None
|
||||||
|
@ -716,7 +716,7 @@ async def test_service_calls_core(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
assert mock_check_config.called
|
assert mock_check_config.called
|
||||||
|
|
||||||
assert aioclient_mock.call_count == 7
|
assert aioclient_mock.call_count == 6
|
||||||
|
|
||||||
|
|
||||||
async def test_entry_load_and_unload(hass: HomeAssistant) -> None:
|
async def test_entry_load_and_unload(hass: HomeAssistant) -> None:
|
||||||
|
@ -897,14 +897,17 @@ async def test_coordinator_updates(
|
||||||
config_entry.add_to_hass(hass)
|
config_entry.add_to_hass(hass)
|
||||||
assert await hass.config_entries.async_setup(config_entry.entry_id)
|
assert await hass.config_entries.async_setup(config_entry.entry_id)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
# Initial refresh without stats
|
|
||||||
assert refresh_updates_mock.call_count == 1
|
# Initial refresh, no update refresh call
|
||||||
|
assert refresh_updates_mock.call_count == 0
|
||||||
|
|
||||||
with patch(
|
with patch(
|
||||||
"homeassistant.components.hassio.HassIO.refresh_updates",
|
"homeassistant.components.hassio.HassIO.refresh_updates",
|
||||||
) as refresh_updates_mock:
|
) as refresh_updates_mock:
|
||||||
async_fire_time_changed(hass, dt_util.now() + timedelta(minutes=20))
|
async_fire_time_changed(hass, dt_util.now() + timedelta(minutes=20))
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
# Scheduled refresh, no update refresh call
|
||||||
assert refresh_updates_mock.call_count == 0
|
assert refresh_updates_mock.call_count == 0
|
||||||
|
|
||||||
with patch(
|
with patch(
|
||||||
|
@ -921,13 +924,14 @@ async def test_coordinator_updates(
|
||||||
},
|
},
|
||||||
blocking=True,
|
blocking=True,
|
||||||
)
|
)
|
||||||
assert refresh_updates_mock.call_count == 0
|
|
||||||
|
|
||||||
# There is a REQUEST_REFRESH_DELAYs cooldown on the debouncer
|
# There is a REQUEST_REFRESH_DELAYs cooldown on the debouncer
|
||||||
|
assert refresh_updates_mock.call_count == 0
|
||||||
async_fire_time_changed(
|
async_fire_time_changed(
|
||||||
hass, dt_util.now() + timedelta(seconds=REQUEST_REFRESH_DELAY)
|
hass, dt_util.now() + timedelta(seconds=REQUEST_REFRESH_DELAY)
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
assert refresh_updates_mock.call_count == 1
|
||||||
|
|
||||||
with patch(
|
with patch(
|
||||||
"homeassistant.components.hassio.HassIO.refresh_updates",
|
"homeassistant.components.hassio.HassIO.refresh_updates",
|
||||||
|
@ -968,14 +972,14 @@ async def test_coordinator_updates_stats_entities_enabled(
|
||||||
assert await hass.config_entries.async_setup(config_entry.entry_id)
|
assert await hass.config_entries.async_setup(config_entry.entry_id)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
# Initial refresh without stats
|
# Initial refresh without stats
|
||||||
assert refresh_updates_mock.call_count == 1
|
assert refresh_updates_mock.call_count == 0
|
||||||
|
|
||||||
# Refresh with stats once we know which ones are needed
|
# Refresh with stats once we know which ones are needed
|
||||||
async_fire_time_changed(
|
async_fire_time_changed(
|
||||||
hass, dt_util.now() + timedelta(seconds=REQUEST_REFRESH_DELAY)
|
hass, dt_util.now() + timedelta(seconds=REQUEST_REFRESH_DELAY)
|
||||||
)
|
)
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
assert refresh_updates_mock.call_count == 2
|
assert refresh_updates_mock.call_count == 1
|
||||||
|
|
||||||
with patch(
|
with patch(
|
||||||
"homeassistant.components.hassio.HassIO.refresh_updates",
|
"homeassistant.components.hassio.HassIO.refresh_updates",
|
||||||
|
@ -1059,7 +1063,7 @@ async def test_setup_hardware_integration(
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
assert result
|
assert result
|
||||||
assert aioclient_mock.call_count == 20
|
assert aioclient_mock.call_count == 19
|
||||||
assert len(mock_setup_entry.mock_calls) == 1
|
assert len(mock_setup_entry.mock_calls) == 1
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue