mirror of
https://github.com/home-assistant/core.git
synced 2025-11-16 06:20:07 +00:00
Improved error handling for oauth2 configuration in weheat integration (#156217)
This commit is contained in:
@@ -14,11 +14,12 @@ from homeassistant.core import HomeAssistant
|
|||||||
from homeassistant.exceptions import ConfigEntryAuthFailed, ConfigEntryNotReady
|
from homeassistant.exceptions import ConfigEntryAuthFailed, ConfigEntryNotReady
|
||||||
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
from homeassistant.helpers.aiohttp_client import async_get_clientsession
|
||||||
from homeassistant.helpers.config_entry_oauth2_flow import (
|
from homeassistant.helpers.config_entry_oauth2_flow import (
|
||||||
|
ImplementationUnavailableError,
|
||||||
OAuth2Session,
|
OAuth2Session,
|
||||||
async_get_config_entry_implementation,
|
async_get_config_entry_implementation,
|
||||||
)
|
)
|
||||||
|
|
||||||
from .const import API_URL, LOGGER
|
from .const import API_URL, DOMAIN, LOGGER
|
||||||
from .coordinator import (
|
from .coordinator import (
|
||||||
HeatPumpInfo,
|
HeatPumpInfo,
|
||||||
WeheatConfigEntry,
|
WeheatConfigEntry,
|
||||||
@@ -32,7 +33,13 @@ PLATFORMS: list[Platform] = [Platform.BINARY_SENSOR, Platform.SENSOR]
|
|||||||
|
|
||||||
async def async_setup_entry(hass: HomeAssistant, entry: WeheatConfigEntry) -> bool:
|
async def async_setup_entry(hass: HomeAssistant, entry: WeheatConfigEntry) -> bool:
|
||||||
"""Set up Weheat from a config entry."""
|
"""Set up Weheat from a config entry."""
|
||||||
|
try:
|
||||||
implementation = await async_get_config_entry_implementation(hass, entry)
|
implementation = await async_get_config_entry_implementation(hass, entry)
|
||||||
|
except ImplementationUnavailableError as err:
|
||||||
|
raise ConfigEntryNotReady(
|
||||||
|
translation_domain=DOMAIN,
|
||||||
|
translation_key="oauth2_implementation_unavailable",
|
||||||
|
) from err
|
||||||
|
|
||||||
session = OAuth2Session(hass, entry, implementation)
|
session = OAuth2Session(hass, entry, implementation)
|
||||||
|
|
||||||
|
|||||||
@@ -124,5 +124,10 @@
|
|||||||
"name": "Water outlet temperature"
|
"name": "Water outlet temperature"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"exceptions": {
|
||||||
|
"oauth2_implementation_unavailable": {
|
||||||
|
"message": "[%key:common::exceptions::oauth2_implementation_unavailable::message%]"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,6 +9,9 @@ from weheat.abstractions.discovery import HeatPumpDiscovery
|
|||||||
from homeassistant.components.weheat import UnauthorizedException
|
from homeassistant.components.weheat import UnauthorizedException
|
||||||
from homeassistant.config_entries import ConfigEntryState
|
from homeassistant.config_entries import ConfigEntryState
|
||||||
from homeassistant.core import HomeAssistant
|
from homeassistant.core import HomeAssistant
|
||||||
|
from homeassistant.helpers.config_entry_oauth2_flow import (
|
||||||
|
ImplementationUnavailableError,
|
||||||
|
)
|
||||||
|
|
||||||
from . import setup_integration
|
from . import setup_integration
|
||||||
|
|
||||||
@@ -83,3 +86,21 @@ async def test_setup_fail_discover(
|
|||||||
await setup_integration(hass, mock_config_entry)
|
await setup_integration(hass, mock_config_entry)
|
||||||
|
|
||||||
assert mock_config_entry.state is ConfigEntryState.SETUP_ERROR
|
assert mock_config_entry.state is ConfigEntryState.SETUP_ERROR
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.usefixtures("setup_credentials")
|
||||||
|
async def test_oauth_implementation_not_available(
|
||||||
|
hass: HomeAssistant,
|
||||||
|
mock_config_entry: MockConfigEntry,
|
||||||
|
) -> None:
|
||||||
|
"""Test that unavailable OAuth implementation raises ConfigEntryNotReady."""
|
||||||
|
mock_config_entry.add_to_hass(hass)
|
||||||
|
|
||||||
|
with patch(
|
||||||
|
"homeassistant.components.weheat.async_get_config_entry_implementation",
|
||||||
|
side_effect=ImplementationUnavailableError,
|
||||||
|
):
|
||||||
|
await hass.config_entries.async_setup(mock_config_entry.entry_id)
|
||||||
|
await hass.async_block_till_done()
|
||||||
|
|
||||||
|
assert mock_config_entry.state is ConfigEntryState.SETUP_RETRY
|
||||||
|
|||||||
Reference in New Issue
Block a user