2021-07-28 19:41:11 +00:00
|
|
|
"""Tests for Renault setup process."""
|
2021-08-16 10:52:58 +00:00
|
|
|
from unittest.mock import patch
|
2021-07-28 19:41:11 +00:00
|
|
|
|
|
|
|
import aiohttp
|
2021-10-18 11:27:44 +00:00
|
|
|
import pytest
|
2021-07-28 19:41:11 +00:00
|
|
|
from renault_api.gigya.exceptions import InvalidCredentialsException
|
|
|
|
|
|
|
|
from homeassistant.components.renault.const import DOMAIN
|
2021-10-18 11:27:44 +00:00
|
|
|
from homeassistant.config_entries import ConfigEntry, ConfigEntryState
|
2021-08-27 05:22:23 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
2021-07-28 19:41:11 +00:00
|
|
|
|
2021-10-18 11:27:44 +00:00
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def override_platforms():
|
|
|
|
"""Override PLATFORMS."""
|
|
|
|
with patch("homeassistant.components.renault.PLATFORMS", []):
|
|
|
|
yield
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True, name="vehicle_type", params=["zoe_40"])
|
|
|
|
def override_vehicle_type(request) -> str:
|
|
|
|
"""Parametrize vehicle type."""
|
|
|
|
return request.param
|
2021-07-28 19:41:11 +00:00
|
|
|
|
|
|
|
|
2021-10-18 11:27:44 +00:00
|
|
|
@pytest.mark.usefixtures("patch_renault_account", "patch_get_vehicles")
|
|
|
|
async def test_setup_unload_entry(hass: HomeAssistant, config_entry: ConfigEntry):
|
2021-07-28 19:41:11 +00:00
|
|
|
"""Test entry setup and unload."""
|
2021-10-18 11:27:44 +00:00
|
|
|
await hass.config_entries.async_setup(config_entry.entry_id)
|
|
|
|
await hass.async_block_till_done()
|
2021-07-28 19:41:11 +00:00
|
|
|
|
2021-08-16 10:52:58 +00:00
|
|
|
assert len(hass.config_entries.async_entries(DOMAIN)) == 1
|
|
|
|
assert config_entry.state is ConfigEntryState.LOADED
|
2021-08-16 11:49:04 +00:00
|
|
|
assert config_entry.entry_id in hass.data[DOMAIN]
|
2021-07-28 19:41:11 +00:00
|
|
|
|
2021-08-16 10:52:58 +00:00
|
|
|
# Unload the entry and verify that the data has been removed
|
|
|
|
await hass.config_entries.async_unload(config_entry.entry_id)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert config_entry.state is ConfigEntryState.NOT_LOADED
|
2021-08-16 11:49:04 +00:00
|
|
|
assert config_entry.entry_id not in hass.data[DOMAIN]
|
2021-07-28 19:41:11 +00:00
|
|
|
|
|
|
|
|
2021-10-18 11:27:44 +00:00
|
|
|
async def test_setup_entry_bad_password(hass: HomeAssistant, config_entry: ConfigEntry):
|
2021-07-28 19:41:11 +00:00
|
|
|
"""Test entry setup and unload."""
|
|
|
|
# Create a mock entry so we don't have to go through config flow
|
|
|
|
with patch(
|
|
|
|
"renault_api.renault_session.RenaultSession.login",
|
|
|
|
side_effect=InvalidCredentialsException(403042, "invalid loginID or password"),
|
|
|
|
):
|
2021-08-16 10:52:58 +00:00
|
|
|
await hass.config_entries.async_setup(config_entry.entry_id)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert len(hass.config_entries.async_entries(DOMAIN)) == 1
|
|
|
|
assert config_entry.state is ConfigEntryState.SETUP_ERROR
|
|
|
|
assert not hass.data.get(DOMAIN)
|
2021-07-28 19:41:11 +00:00
|
|
|
|
|
|
|
|
2021-10-18 11:27:44 +00:00
|
|
|
async def test_setup_entry_exception(hass: HomeAssistant, config_entry: ConfigEntry):
|
2021-07-28 19:41:11 +00:00
|
|
|
"""Test ConfigEntryNotReady when API raises an exception during entry setup."""
|
|
|
|
# In this case we are testing the condition where async_setup_entry raises
|
|
|
|
# ConfigEntryNotReady.
|
|
|
|
with patch(
|
|
|
|
"renault_api.renault_session.RenaultSession.login",
|
|
|
|
side_effect=aiohttp.ClientConnectionError,
|
2021-08-16 10:52:58 +00:00
|
|
|
):
|
|
|
|
await hass.config_entries.async_setup(config_entry.entry_id)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
|
|
|
|
assert len(hass.config_entries.async_entries(DOMAIN)) == 1
|
|
|
|
assert config_entry.state is ConfigEntryState.SETUP_RETRY
|
|
|
|
assert not hass.data.get(DOMAIN)
|