2017-03-05 09:41:54 +00:00
|
|
|
"""Test component/platform setup."""
|
2023-01-22 16:26:24 +00:00
|
|
|
|
2020-04-27 17:05:02 +00:00
|
|
|
import asyncio
|
2017-03-05 09:41:54 +00:00
|
|
|
import threading
|
2021-03-29 20:53:47 +00:00
|
|
|
from unittest.mock import AsyncMock, Mock, patch
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2020-04-27 17:05:02 +00:00
|
|
|
import pytest
|
2017-03-05 09:41:54 +00:00
|
|
|
import voluptuous as vol
|
|
|
|
|
2020-04-27 17:05:02 +00:00
|
|
|
from homeassistant import config_entries, setup
|
2019-12-09 15:52:24 +00:00
|
|
|
from homeassistant.const import EVENT_COMPONENT_LOADED, EVENT_HOMEASSISTANT_START
|
2023-02-08 07:51:43 +00:00
|
|
|
from homeassistant.core import HomeAssistant, callback
|
2022-03-03 23:03:03 +00:00
|
|
|
from homeassistant.exceptions import HomeAssistantError
|
2024-02-24 21:31:25 +00:00
|
|
|
from homeassistant.helpers import discovery, translation
|
2019-01-29 00:14:55 +00:00
|
|
|
from homeassistant.helpers.config_validation import (
|
2019-07-31 19:25:30 +00:00
|
|
|
PLATFORM_SCHEMA,
|
|
|
|
PLATFORM_SCHEMA_BASE,
|
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2023-01-27 11:51:58 +00:00
|
|
|
from .common import (
|
2020-04-27 17:05:02 +00:00
|
|
|
MockConfigEntry,
|
2019-07-31 19:25:30 +00:00
|
|
|
MockModule,
|
|
|
|
MockPlatform,
|
|
|
|
assert_setup_component,
|
2019-12-09 15:52:24 +00:00
|
|
|
mock_integration,
|
2023-11-16 15:55:08 +00:00
|
|
|
mock_platform,
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
@pytest.fixture
|
2020-04-27 17:05:02 +00:00
|
|
|
def mock_handlers():
|
|
|
|
"""Mock config flows."""
|
|
|
|
|
|
|
|
class MockFlowHandler(config_entries.ConfigFlow):
|
|
|
|
"""Define a mock flow handler."""
|
|
|
|
|
|
|
|
VERSION = 1
|
|
|
|
|
|
|
|
with patch.dict(config_entries.HANDLERS, {"comp": MockFlowHandler}):
|
|
|
|
yield
|
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_validate_component_config(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test validating component configuration."""
|
|
|
|
config_schema = vol.Schema({"comp_conf": {"hello": str}}, required=True)
|
|
|
|
mock_integration(hass, MockModule("comp_conf", config_schema=config_schema))
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with assert_setup_component(0):
|
|
|
|
assert not await setup.async_setup_component(hass, "comp_conf", {})
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with assert_setup_component(0):
|
|
|
|
assert not await setup.async_setup_component(
|
|
|
|
hass, "comp_conf", {"comp_conf": None}
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with assert_setup_component(0):
|
|
|
|
assert not await setup.async_setup_component(
|
|
|
|
hass, "comp_conf", {"comp_conf": {}}
|
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with assert_setup_component(0):
|
|
|
|
assert not await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"comp_conf",
|
|
|
|
{"comp_conf": {"hello": "world", "invalid": "extra"}},
|
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with assert_setup_component(1):
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass, "comp_conf", {"comp_conf": {"hello": "world"}}
|
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2023-02-21 08:27:13 +00:00
|
|
|
async def test_validate_platform_config(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test validating platform configuration."""
|
|
|
|
platform_schema = PLATFORM_SCHEMA.extend({"hello": str})
|
|
|
|
platform_schema_base = PLATFORM_SCHEMA_BASE.extend({})
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule("platform_conf", platform_schema_base=platform_schema_base),
|
|
|
|
)
|
2023-11-16 15:55:08 +00:00
|
|
|
mock_platform(
|
2022-01-19 20:47:21 +00:00
|
|
|
hass,
|
2023-11-16 15:55:08 +00:00
|
|
|
"whatever.platform_conf",
|
2022-01-19 20:47:21 +00:00
|
|
|
MockPlatform(platform_schema=platform_schema),
|
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with assert_setup_component(0):
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"platform_conf",
|
|
|
|
{"platform_conf": {"platform": "not_existing", "hello": "world"}},
|
2019-04-11 08:26:36 +00:00
|
|
|
)
|
2022-01-19 20:47:21 +00:00
|
|
|
|
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("platform_conf")
|
|
|
|
|
|
|
|
with assert_setup_component(1):
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"platform_conf",
|
|
|
|
{"platform_conf": {"platform": "whatever", "hello": "world"}},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("platform_conf")
|
|
|
|
|
|
|
|
with assert_setup_component(1):
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"platform_conf",
|
|
|
|
{"platform_conf": [{"platform": "whatever", "hello": "world"}]},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-01-29 00:14:55 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("platform_conf")
|
|
|
|
|
|
|
|
# Any falsey platform config will be ignored (None, {}, etc)
|
|
|
|
with assert_setup_component(0) as config:
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass, "platform_conf", {"platform_conf": None}
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2022-01-19 20:47:21 +00:00
|
|
|
assert "platform_conf" in hass.config.components
|
|
|
|
assert not config["platform_conf"] # empty
|
2019-01-29 00:14:55 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass, "platform_conf", {"platform_conf": {}}
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2022-01-19 20:47:21 +00:00
|
|
|
assert "platform_conf" in hass.config.components
|
|
|
|
assert not config["platform_conf"] # empty
|
|
|
|
|
|
|
|
|
2023-02-21 08:27:13 +00:00
|
|
|
async def test_validate_platform_config_2(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test component PLATFORM_SCHEMA_BASE prio over PLATFORM_SCHEMA."""
|
|
|
|
platform_schema = PLATFORM_SCHEMA.extend({"hello": str})
|
|
|
|
platform_schema_base = PLATFORM_SCHEMA_BASE.extend({"hello": "world"})
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule(
|
|
|
|
"platform_conf",
|
|
|
|
platform_schema=platform_schema,
|
|
|
|
platform_schema_base=platform_schema_base,
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
2023-11-16 15:55:08 +00:00
|
|
|
mock_platform(
|
2022-01-19 20:47:21 +00:00
|
|
|
hass,
|
2023-11-16 15:55:08 +00:00
|
|
|
"whatever.platform_conf",
|
2022-01-19 20:47:21 +00:00
|
|
|
MockPlatform("whatever", platform_schema=platform_schema),
|
|
|
|
)
|
2019-01-29 00:14:55 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with assert_setup_component(1):
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"platform_conf",
|
|
|
|
{
|
|
|
|
# pass
|
|
|
|
"platform_conf": {"platform": "whatever", "hello": "world"},
|
|
|
|
# fail: key hello violates component platform_schema_base
|
|
|
|
"platform_conf 2": {"platform": "whatever", "hello": "there"},
|
|
|
|
},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-01-29 00:14:55 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
|
2023-02-21 08:27:13 +00:00
|
|
|
async def test_validate_platform_config_3(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test fallback to component PLATFORM_SCHEMA."""
|
|
|
|
component_schema = PLATFORM_SCHEMA_BASE.extend({"hello": str})
|
|
|
|
platform_schema = PLATFORM_SCHEMA.extend({"cheers": str, "hello": "world"})
|
|
|
|
mock_integration(
|
|
|
|
hass, MockModule("platform_conf", platform_schema=component_schema)
|
|
|
|
)
|
|
|
|
|
2023-11-16 15:55:08 +00:00
|
|
|
mock_platform(
|
2022-01-19 20:47:21 +00:00
|
|
|
hass,
|
2023-11-16 15:55:08 +00:00
|
|
|
"whatever.platform_conf",
|
2022-01-19 20:47:21 +00:00
|
|
|
MockPlatform("whatever", platform_schema=platform_schema),
|
|
|
|
)
|
|
|
|
|
|
|
|
with assert_setup_component(1):
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"platform_conf",
|
|
|
|
{
|
|
|
|
# pass
|
|
|
|
"platform_conf": {"platform": "whatever", "hello": "world"},
|
|
|
|
# fail: key hello violates component platform_schema
|
|
|
|
"platform_conf 2": {"platform": "whatever", "hello": "there"},
|
|
|
|
},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-02-02 17:31:28 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_validate_platform_config_4(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test entity_namespace in PLATFORM_SCHEMA."""
|
|
|
|
component_schema = PLATFORM_SCHEMA_BASE
|
|
|
|
platform_schema = PLATFORM_SCHEMA
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule("platform_conf", platform_schema_base=component_schema),
|
|
|
|
)
|
|
|
|
|
2023-11-16 15:55:08 +00:00
|
|
|
mock_platform(
|
2022-01-19 20:47:21 +00:00
|
|
|
hass,
|
2023-11-16 15:55:08 +00:00
|
|
|
"whatever.platform_conf",
|
2022-01-19 20:47:21 +00:00
|
|
|
MockPlatform(platform_schema=platform_schema),
|
|
|
|
)
|
|
|
|
|
|
|
|
with assert_setup_component(1):
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"platform_conf",
|
|
|
|
{
|
|
|
|
"platform_conf": {
|
|
|
|
# pass: entity_namespace accepted by PLATFORM_SCHEMA
|
|
|
|
"platform": "whatever",
|
|
|
|
"entity_namespace": "yummy",
|
|
|
|
}
|
|
|
|
},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2019-02-02 17:31:28 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("platform_conf")
|
2019-02-02 17:31:28 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_not_found(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""setup_component should not crash if component doesn't exist."""
|
|
|
|
assert await setup.async_setup_component(hass, "non_existing", {}) is False
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_not_double_initialized(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test we do not set up a component twice."""
|
|
|
|
mock_setup = Mock(return_value=True)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
mock_integration(hass, MockModule("comp", setup=mock_setup))
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert await setup.async_setup_component(hass, "comp", {})
|
|
|
|
assert mock_setup.called
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
mock_setup.reset_mock()
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert await setup.async_setup_component(hass, "comp", {})
|
|
|
|
assert not mock_setup.called
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_not_installed_if_requirement_fails(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Component setup should fail if requirement can't install."""
|
|
|
|
hass.config.skip_pip = False
|
|
|
|
mock_integration(hass, MockModule("comp", requirements=["package==0.0.1"]))
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with patch("homeassistant.util.package.install_package", return_value=False):
|
|
|
|
assert not await setup.async_setup_component(hass, "comp", {})
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert "comp" not in hass.config.components
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_not_setup_twice_if_loaded_during_other_setup(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test component setup while waiting for lock is not set up twice."""
|
|
|
|
result = []
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
async def async_setup(hass, config):
|
|
|
|
"""Tracking Setup."""
|
|
|
|
result.append(1)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
mock_integration(hass, MockModule("comp", async_setup=async_setup))
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
def setup_component():
|
|
|
|
"""Set up the component."""
|
|
|
|
setup.setup_component(hass, "comp", {})
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
thread = threading.Thread(target=setup_component)
|
|
|
|
thread.start()
|
|
|
|
await setup.async_setup_component(hass, "comp", {})
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
await hass.async_add_executor_job(thread.join)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert len(result) == 1
|
2019-04-09 16:30:32 +00:00
|
|
|
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_not_setup_missing_dependencies(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test we do not set up a component if not all dependencies loaded."""
|
|
|
|
deps = ["maybe_existing"]
|
|
|
|
mock_integration(hass, MockModule("comp", dependencies=deps))
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert not await setup.async_setup_component(hass, "comp", {})
|
|
|
|
assert "comp" not in hass.config.components
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
2019-07-31 19:25:30 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
mock_integration(hass, MockModule("comp2", dependencies=deps))
|
|
|
|
mock_integration(hass, MockModule("maybe_existing"))
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert await setup.async_setup_component(hass, "comp2", {})
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_failing_setup(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test component that fails setup."""
|
|
|
|
mock_integration(hass, MockModule("comp", setup=lambda hass, config: False))
|
2019-07-31 19:25:30 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert not await setup.async_setup_component(hass, "comp", {})
|
|
|
|
assert "comp" not in hass.config.components
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_exception_setup(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test component that raises exception during setup."""
|
2024-02-22 22:34:46 +00:00
|
|
|
setup.async_set_domains_to_be_loaded(hass, {"comp"})
|
2022-01-19 20:47:21 +00:00
|
|
|
|
|
|
|
def exception_setup(hass, config):
|
|
|
|
"""Raise exception."""
|
|
|
|
raise Exception("fail!")
|
|
|
|
|
|
|
|
mock_integration(hass, MockModule("comp", setup=exception_setup))
|
2019-04-11 08:26:36 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert not await setup.async_setup_component(hass, "comp", {})
|
|
|
|
assert "comp" not in hass.config.components
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
|
2024-02-22 22:34:46 +00:00
|
|
|
async def test_component_base_exception_setup(hass: HomeAssistant) -> None:
|
|
|
|
"""Test component that raises exception during setup."""
|
|
|
|
setup.async_set_domains_to_be_loaded(hass, {"comp"})
|
|
|
|
|
|
|
|
def exception_setup(hass, config):
|
|
|
|
"""Raise exception."""
|
|
|
|
raise BaseException("fail!")
|
|
|
|
|
|
|
|
mock_integration(hass, MockModule("comp", setup=exception_setup))
|
|
|
|
|
|
|
|
with pytest.raises(BaseException):
|
|
|
|
await setup.async_setup_component(hass, "comp", {})
|
|
|
|
|
|
|
|
assert "comp" not in hass.config.components
|
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_setup_with_validation_and_dependency(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test all config is passed to dependencies."""
|
|
|
|
|
|
|
|
def config_check_setup(hass, config):
|
|
|
|
"""Test that config is passed in."""
|
|
|
|
if config.get("comp_a", {}).get("valid", False):
|
|
|
|
return True
|
|
|
|
raise Exception(f"Config not passed in: {config}")
|
|
|
|
|
|
|
|
platform = MockPlatform()
|
|
|
|
|
|
|
|
mock_integration(hass, MockModule("comp_a", setup=config_check_setup))
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule("platform_a", setup=config_check_setup, dependencies=["comp_a"]),
|
|
|
|
)
|
|
|
|
|
2023-11-16 15:55:08 +00:00
|
|
|
mock_platform(hass, "platform_a.switch", platform)
|
2022-01-19 20:47:21 +00:00
|
|
|
|
|
|
|
await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"switch",
|
|
|
|
{"comp_a": {"valid": True}, "switch": {"platform": "platform_a"}},
|
|
|
|
)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert "comp_a" in hass.config.components
|
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_platform_specific_config_validation(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test platform that specifies config."""
|
|
|
|
platform_schema = PLATFORM_SCHEMA.extend({"valid": True}, extra=vol.PREVENT_EXTRA)
|
|
|
|
|
|
|
|
mock_setup = Mock(spec_set=True)
|
|
|
|
|
2023-11-16 15:55:08 +00:00
|
|
|
mock_platform(
|
2022-01-19 20:47:21 +00:00
|
|
|
hass,
|
2023-11-16 15:55:08 +00:00
|
|
|
"platform_a.switch",
|
2022-01-19 20:47:21 +00:00
|
|
|
MockPlatform(platform_schema=platform_schema, setup_platform=mock_setup),
|
|
|
|
)
|
|
|
|
|
2023-11-22 20:16:12 +00:00
|
|
|
with assert_setup_component(0, "switch"), patch(
|
2023-11-24 16:34:45 +00:00
|
|
|
"homeassistant.setup.async_notify_setup_error"
|
2023-11-22 20:16:12 +00:00
|
|
|
) as mock_notify:
|
2022-01-19 20:47:21 +00:00
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
2019-07-31 19:25:30 +00:00
|
|
|
"switch",
|
2022-01-19 20:47:21 +00:00
|
|
|
{"switch": {"platform": "platform_a", "invalid": True}},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2022-01-19 20:47:21 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_setup.call_count == 0
|
2023-11-22 20:16:12 +00:00
|
|
|
assert len(mock_notify.mock_calls) == 1
|
2022-01-19 20:47:21 +00:00
|
|
|
|
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("switch")
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2023-11-22 20:16:12 +00:00
|
|
|
with assert_setup_component(0), patch(
|
2023-11-24 16:34:45 +00:00
|
|
|
"homeassistant.setup.async_notify_setup_error"
|
2023-11-22 20:16:12 +00:00
|
|
|
) as mock_notify:
|
2022-01-19 20:47:21 +00:00
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"switch",
|
|
|
|
{
|
|
|
|
"switch": {
|
|
|
|
"platform": "platform_a",
|
|
|
|
"valid": True,
|
|
|
|
"invalid_extra": True,
|
|
|
|
}
|
|
|
|
},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2022-01-19 20:47:21 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_setup.call_count == 0
|
2023-11-22 20:16:12 +00:00
|
|
|
assert len(mock_notify.mock_calls) == 1
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("switch")
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2023-11-22 20:16:12 +00:00
|
|
|
with assert_setup_component(1, "switch"), patch(
|
2023-11-24 16:34:45 +00:00
|
|
|
"homeassistant.setup.async_notify_setup_error"
|
2023-11-22 20:16:12 +00:00
|
|
|
) as mock_notify:
|
2022-01-19 20:47:21 +00:00
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"switch",
|
|
|
|
{"switch": {"platform": "platform_a", "valid": True}},
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2022-01-19 20:47:21 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert mock_setup.call_count == 1
|
2023-11-22 20:16:12 +00:00
|
|
|
assert len(mock_notify.mock_calls) == 0
|
2019-07-31 19:25:30 +00:00
|
|
|
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_disable_component_if_invalid_return(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test disabling component if invalid return."""
|
|
|
|
mock_integration(
|
|
|
|
hass, MockModule("disabled_component", setup=lambda hass, config: None)
|
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert not await setup.async_setup_component(hass, "disabled_component", {})
|
|
|
|
assert "disabled_component" not in hass.config.components
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule("disabled_component", setup=lambda hass, config: False),
|
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert not await setup.async_setup_component(hass, "disabled_component", {})
|
|
|
|
assert "disabled_component" not in hass.config.components
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
mock_integration(
|
|
|
|
hass, MockModule("disabled_component", setup=lambda hass, config: True)
|
|
|
|
)
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
assert await setup.async_setup_component(hass, "disabled_component", {})
|
|
|
|
assert "disabled_component" in hass.config.components
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_all_work_done_before_start(hass: HomeAssistant) -> None:
|
2022-01-19 20:47:21 +00:00
|
|
|
"""Test all init work done till start."""
|
|
|
|
call_order = []
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
async def component1_setup(hass, config):
|
|
|
|
"""Set up mock component."""
|
|
|
|
await discovery.async_discover(
|
|
|
|
hass, "test_component2", {}, "test_component2", {}
|
2019-07-31 19:25:30 +00:00
|
|
|
)
|
2022-01-19 20:47:21 +00:00
|
|
|
await discovery.async_discover(
|
|
|
|
hass, "test_component3", {}, "test_component3", {}
|
|
|
|
)
|
|
|
|
return True
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
def component_track_setup(hass, config):
|
|
|
|
"""Set up mock component."""
|
|
|
|
call_order.append(1)
|
|
|
|
return True
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
mock_integration(hass, MockModule("test_component1", async_setup=component1_setup))
|
2017-03-05 09:41:54 +00:00
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
mock_integration(hass, MockModule("test_component2", setup=component_track_setup))
|
|
|
|
|
|
|
|
mock_integration(hass, MockModule("test_component3", setup=component_track_setup))
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def track_start(event):
|
|
|
|
"""Track start event."""
|
|
|
|
call_order.append(2)
|
|
|
|
|
|
|
|
hass.bus.async_listen_once(EVENT_HOMEASSISTANT_START, track_start)
|
|
|
|
|
|
|
|
hass.add_job(setup.async_setup_component(hass, "test_component1", {}))
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
await hass.async_start()
|
|
|
|
assert call_order == [1, 1, 2]
|
2017-03-05 09:41:54 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_component_warn_slow_setup(hass: HomeAssistant) -> None:
|
2017-03-08 04:31:57 +00:00
|
|
|
"""Warn we log when a component setup takes a long time."""
|
2019-07-31 19:25:30 +00:00
|
|
|
mock_integration(hass, MockModule("test_component1"))
|
2020-04-27 17:05:02 +00:00
|
|
|
with patch.object(hass.loop, "call_later") as mock_call:
|
2020-04-07 16:33:23 +00:00
|
|
|
result = await setup.async_setup_component(hass, "test_component1", {})
|
2017-03-08 04:31:57 +00:00
|
|
|
assert result
|
|
|
|
assert mock_call.called
|
|
|
|
|
2020-08-05 12:58:19 +00:00
|
|
|
assert len(mock_call.mock_calls) == 3
|
2017-03-08 04:31:57 +00:00
|
|
|
timeout, logger_method = mock_call.mock_calls[0][1][:2]
|
|
|
|
|
|
|
|
assert timeout == setup.SLOW_SETUP_WARNING
|
|
|
|
assert logger_method == setup._LOGGER.warning
|
|
|
|
|
|
|
|
assert mock_call().cancel.called
|
2018-01-02 20:16:32 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_platform_no_warn_slow(hass: HomeAssistant) -> None:
|
2018-01-02 20:16:32 +00:00
|
|
|
"""Do not warn for long entity setup time."""
|
2019-04-11 08:26:36 +00:00
|
|
|
mock_integration(
|
2019-07-31 19:25:30 +00:00
|
|
|
hass, MockModule("test_component1", platform_schema=PLATFORM_SCHEMA)
|
|
|
|
)
|
2020-04-27 17:05:02 +00:00
|
|
|
with patch.object(hass.loop, "call_later") as mock_call:
|
2020-04-07 16:33:23 +00:00
|
|
|
result = await setup.async_setup_component(hass, "test_component1", {})
|
2018-01-02 20:16:32 +00:00
|
|
|
assert result
|
2020-08-05 12:58:19 +00:00
|
|
|
assert len(mock_call.mock_calls) == 0
|
2020-05-27 18:43:05 +00:00
|
|
|
|
|
|
|
|
2023-02-21 08:27:13 +00:00
|
|
|
async def test_platform_error_slow_setup(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
2020-05-27 18:43:05 +00:00
|
|
|
"""Don't block startup more than SLOW_SETUP_MAX_WAIT."""
|
|
|
|
|
2022-01-19 20:47:21 +00:00
|
|
|
with patch.object(setup, "SLOW_SETUP_MAX_WAIT", 0.1):
|
2020-05-27 18:43:05 +00:00
|
|
|
called = []
|
|
|
|
|
|
|
|
async def async_setup(*args):
|
|
|
|
"""Tracking Setup."""
|
|
|
|
called.append(1)
|
|
|
|
await asyncio.sleep(2)
|
|
|
|
|
|
|
|
mock_integration(hass, MockModule("test_component1", async_setup=async_setup))
|
|
|
|
result = await setup.async_setup_component(hass, "test_component1", {})
|
|
|
|
assert len(called) == 1
|
|
|
|
assert not result
|
2023-11-20 11:55:16 +00:00
|
|
|
assert "'test_component1' is taking longer than 0.1 seconds" in caplog.text
|
2018-11-28 21:20:13 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_when_setup_already_loaded(hass: HomeAssistant) -> None:
|
2018-11-28 21:20:13 +00:00
|
|
|
"""Test when setup."""
|
|
|
|
calls = []
|
|
|
|
|
|
|
|
async def mock_callback(hass, component):
|
|
|
|
"""Mock callback."""
|
|
|
|
calls.append(component)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
setup.async_when_setup(hass, "test", mock_callback)
|
2018-11-28 21:20:13 +00:00
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert calls == []
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
hass.config.components.add("test")
|
|
|
|
hass.bus.async_fire(EVENT_COMPONENT_LOADED, {"component": "test"})
|
2018-11-28 21:20:13 +00:00
|
|
|
await hass.async_block_till_done()
|
2019-07-31 19:25:30 +00:00
|
|
|
assert calls == ["test"]
|
2018-11-28 21:20:13 +00:00
|
|
|
|
|
|
|
# Event listener should be gone
|
2019-07-31 19:25:30 +00:00
|
|
|
hass.bus.async_fire(EVENT_COMPONENT_LOADED, {"component": "test"})
|
2018-11-28 21:20:13 +00:00
|
|
|
await hass.async_block_till_done()
|
2019-07-31 19:25:30 +00:00
|
|
|
assert calls == ["test"]
|
2018-11-28 21:20:13 +00:00
|
|
|
|
|
|
|
# Should be called right away
|
2019-07-31 19:25:30 +00:00
|
|
|
setup.async_when_setup(hass, "test", mock_callback)
|
2018-11-28 21:20:13 +00:00
|
|
|
await hass.async_block_till_done()
|
2019-07-31 19:25:30 +00:00
|
|
|
assert calls == ["test", "test"]
|
2019-10-31 18:38:06 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_async_when_setup_or_start_already_loaded(hass: HomeAssistant) -> None:
|
2021-04-13 21:10:58 +00:00
|
|
|
"""Test when setup or start."""
|
|
|
|
calls = []
|
|
|
|
|
|
|
|
async def mock_callback(hass, component):
|
|
|
|
"""Mock callback."""
|
|
|
|
calls.append(component)
|
|
|
|
|
|
|
|
setup.async_when_setup_or_start(hass, "test", mock_callback)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert calls == []
|
|
|
|
|
|
|
|
hass.config.components.add("test")
|
|
|
|
hass.bus.async_fire(EVENT_COMPONENT_LOADED, {"component": "test"})
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert calls == ["test"]
|
|
|
|
|
|
|
|
# Event listener should be gone
|
|
|
|
hass.bus.async_fire(EVENT_COMPONENT_LOADED, {"component": "test"})
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert calls == ["test"]
|
|
|
|
|
|
|
|
# Should be called right away
|
|
|
|
setup.async_when_setup_or_start(hass, "test", mock_callback)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert calls == ["test", "test"]
|
|
|
|
|
|
|
|
setup.async_when_setup_or_start(hass, "not_loaded", mock_callback)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert calls == ["test", "test"]
|
|
|
|
hass.bus.async_fire(EVENT_HOMEASSISTANT_START)
|
|
|
|
await hass.async_block_till_done()
|
|
|
|
assert calls == ["test", "test", "not_loaded"]
|
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_setup_import_blows_up(hass: HomeAssistant) -> None:
|
2019-10-31 18:38:06 +00:00
|
|
|
"""Test that we handle it correctly when importing integration blows up."""
|
2020-04-27 17:05:02 +00:00
|
|
|
with patch(
|
2022-01-26 04:39:32 +00:00
|
|
|
"homeassistant.loader.Integration.get_component", side_effect=ImportError
|
2019-10-31 18:38:06 +00:00
|
|
|
):
|
|
|
|
assert not await setup.async_setup_component(hass, "sun", {})
|
2020-04-27 17:05:02 +00:00
|
|
|
|
|
|
|
|
2023-02-21 08:27:13 +00:00
|
|
|
async def test_parallel_entry_setup(hass: HomeAssistant, mock_handlers) -> None:
|
2020-04-27 17:05:02 +00:00
|
|
|
"""Test config entries are set up in parallel."""
|
|
|
|
MockConfigEntry(domain="comp", data={"value": 1}).add_to_hass(hass)
|
|
|
|
MockConfigEntry(domain="comp", data={"value": 2}).add_to_hass(hass)
|
|
|
|
|
|
|
|
calls = []
|
|
|
|
|
|
|
|
async def mock_async_setup_entry(hass, entry):
|
|
|
|
"""Mock setting up an entry."""
|
|
|
|
calls.append(entry.data["value"])
|
|
|
|
await asyncio.sleep(0)
|
|
|
|
calls.append(entry.data["value"])
|
|
|
|
return True
|
|
|
|
|
|
|
|
mock_integration(
|
2020-08-27 11:56:20 +00:00
|
|
|
hass,
|
|
|
|
MockModule(
|
|
|
|
"comp",
|
|
|
|
async_setup_entry=mock_async_setup_entry,
|
|
|
|
),
|
2020-04-27 17:05:02 +00:00
|
|
|
)
|
2023-11-16 15:55:08 +00:00
|
|
|
mock_platform(hass, "comp.config_flow", None)
|
2020-04-27 17:05:02 +00:00
|
|
|
await setup.async_setup_component(hass, "comp", {})
|
|
|
|
|
|
|
|
assert calls == [1, 2, 1, 2]
|
2020-08-26 08:20:14 +00:00
|
|
|
|
|
|
|
|
2023-02-21 08:27:13 +00:00
|
|
|
async def test_integration_disabled(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
2020-08-26 08:20:14 +00:00
|
|
|
"""Test we can disable an integration."""
|
|
|
|
disabled_reason = "Dependency contains code that breaks Home Assistant"
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule("test_component1", partial_manifest={"disabled": disabled_reason}),
|
|
|
|
)
|
|
|
|
result = await setup.async_setup_component(hass, "test_component1", {})
|
|
|
|
assert not result
|
|
|
|
assert disabled_reason in caplog.text
|
2021-03-29 10:51:48 +00:00
|
|
|
|
|
|
|
|
2023-02-21 08:27:13 +00:00
|
|
|
async def test_integration_logs_is_custom(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
2022-03-03 23:03:03 +00:00
|
|
|
"""Test we highlight it's a custom component when errors happen."""
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule("test_component1"),
|
|
|
|
built_in=False,
|
|
|
|
)
|
|
|
|
with patch(
|
|
|
|
"homeassistant.setup.async_process_deps_reqs",
|
|
|
|
side_effect=HomeAssistantError("Boom"),
|
|
|
|
):
|
|
|
|
result = await setup.async_setup_component(hass, "test_component1", {})
|
|
|
|
assert not result
|
2023-11-20 11:55:16 +00:00
|
|
|
assert "Setup failed for custom integration 'test_component1': Boom" in caplog.text
|
2022-03-03 23:03:03 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_async_get_loaded_integrations(hass: HomeAssistant) -> None:
|
2022-11-28 15:51:43 +00:00
|
|
|
"""Test we can enumerate loaded integrations."""
|
2021-03-29 10:51:48 +00:00
|
|
|
hass.config.components.add("notbase")
|
|
|
|
hass.config.components.add("switch")
|
|
|
|
hass.config.components.add("notbase.switch")
|
|
|
|
hass.config.components.add("myintegration")
|
|
|
|
hass.config.components.add("device_tracker")
|
2023-12-05 07:43:58 +00:00
|
|
|
hass.config.components.add("other.device_tracker")
|
2021-03-29 10:51:48 +00:00
|
|
|
hass.config.components.add("myintegration.light")
|
|
|
|
assert setup.async_get_loaded_integrations(hass) == {
|
|
|
|
"other",
|
|
|
|
"switch",
|
|
|
|
"notbase",
|
|
|
|
"myintegration",
|
|
|
|
"device_tracker",
|
|
|
|
}
|
2021-03-29 20:53:47 +00:00
|
|
|
|
|
|
|
|
2023-02-21 08:27:13 +00:00
|
|
|
async def test_integration_no_setup(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
2021-03-29 20:53:47 +00:00
|
|
|
"""Test we fail integration setup without setup functions."""
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule("test_integration_without_setup", setup=False),
|
|
|
|
)
|
|
|
|
result = await setup.async_setup_component(
|
|
|
|
hass, "test_integration_without_setup", {}
|
|
|
|
)
|
|
|
|
assert not result
|
|
|
|
assert "No setup or config entry setup function defined" in caplog.text
|
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_integration_only_setup_entry(hass: HomeAssistant) -> None:
|
2021-03-29 20:53:47 +00:00
|
|
|
"""Test we have an integration with only a setup entry method."""
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule(
|
|
|
|
"test_integration_only_entry",
|
|
|
|
setup=False,
|
|
|
|
async_setup_entry=AsyncMock(return_value=True),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
assert await setup.async_setup_component(hass, "test_integration_only_entry", {})
|
2021-04-05 08:11:44 +00:00
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_async_start_setup(hass: HomeAssistant) -> None:
|
2021-04-05 08:11:44 +00:00
|
|
|
"""Test setup started context manager keeps track of setup times."""
|
|
|
|
with setup.async_start_setup(hass, ["august"]):
|
2024-02-18 02:47:55 +00:00
|
|
|
assert isinstance(hass.data[setup.DATA_SETUP_STARTED]["august"], float)
|
2021-04-05 08:11:44 +00:00
|
|
|
with setup.async_start_setup(hass, ["august"]):
|
2024-02-18 02:47:55 +00:00
|
|
|
assert isinstance(hass.data[setup.DATA_SETUP_STARTED]["august_2"], float)
|
2021-04-05 08:11:44 +00:00
|
|
|
|
|
|
|
assert "august" not in hass.data[setup.DATA_SETUP_STARTED]
|
2024-02-18 02:47:55 +00:00
|
|
|
assert isinstance(hass.data[setup.DATA_SETUP_TIME]["august"], float)
|
2021-04-05 08:11:44 +00:00
|
|
|
assert "august_2" not in hass.data[setup.DATA_SETUP_TIME]
|
|
|
|
|
|
|
|
|
2023-02-08 07:51:43 +00:00
|
|
|
async def test_async_start_setup_platforms(hass: HomeAssistant) -> None:
|
2021-04-05 08:11:44 +00:00
|
|
|
"""Test setup started context manager keeps track of setup times for platforms."""
|
2023-12-05 07:43:58 +00:00
|
|
|
with setup.async_start_setup(hass, ["august.sensor"]):
|
2024-02-18 02:47:55 +00:00
|
|
|
assert isinstance(hass.data[setup.DATA_SETUP_STARTED]["august.sensor"], float)
|
2021-04-05 08:11:44 +00:00
|
|
|
|
|
|
|
assert "august" not in hass.data[setup.DATA_SETUP_STARTED]
|
2024-02-18 02:47:55 +00:00
|
|
|
assert isinstance(hass.data[setup.DATA_SETUP_TIME]["august"], float)
|
2021-04-05 08:11:44 +00:00
|
|
|
assert "sensor" not in hass.data[setup.DATA_SETUP_TIME]
|
2023-05-29 19:01:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_setup_config_entry_from_yaml(
|
|
|
|
hass: HomeAssistant, caplog: pytest.LogCaptureFixture
|
|
|
|
) -> None:
|
|
|
|
"""Test attempting to setup an integration which only supports config_entries."""
|
|
|
|
expected_warning = (
|
2023-11-20 11:55:16 +00:00
|
|
|
"The 'test_integration_only_entry' integration does not support YAML setup, "
|
2023-05-29 19:01:47 +00:00
|
|
|
"please remove it from your configuration"
|
|
|
|
)
|
|
|
|
|
|
|
|
mock_integration(
|
|
|
|
hass,
|
|
|
|
MockModule(
|
|
|
|
"test_integration_only_entry",
|
|
|
|
setup=False,
|
|
|
|
async_setup_entry=AsyncMock(return_value=True),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
assert await setup.async_setup_component(hass, "test_integration_only_entry", {})
|
|
|
|
assert expected_warning not in caplog.text
|
|
|
|
caplog.clear()
|
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("test_integration_only_entry")
|
|
|
|
|
|
|
|
# There should be a warning, but setup should not fail
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass, "test_integration_only_entry", {"test_integration_only_entry": None}
|
|
|
|
)
|
|
|
|
assert expected_warning in caplog.text
|
|
|
|
caplog.clear()
|
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("test_integration_only_entry")
|
|
|
|
|
|
|
|
# There should be a warning, but setup should not fail
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass, "test_integration_only_entry", {"test_integration_only_entry": {}}
|
|
|
|
)
|
|
|
|
assert expected_warning in caplog.text
|
|
|
|
caplog.clear()
|
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("test_integration_only_entry")
|
|
|
|
|
|
|
|
# There should be a warning, but setup should not fail
|
|
|
|
assert await setup.async_setup_component(
|
|
|
|
hass,
|
|
|
|
"test_integration_only_entry",
|
|
|
|
{"test_integration_only_entry": {"hello": "world"}},
|
|
|
|
)
|
|
|
|
assert expected_warning in caplog.text
|
|
|
|
caplog.clear()
|
|
|
|
hass.data.pop(setup.DATA_SETUP)
|
|
|
|
hass.config.components.remove("test_integration_only_entry")
|
2024-02-24 21:31:25 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_loading_component_loads_translations(hass: HomeAssistant) -> None:
|
|
|
|
"""Test that loading a component loads translations."""
|
|
|
|
assert translation.async_translations_loaded(hass, {"comp"}) is False
|
|
|
|
mock_setup = Mock(return_value=True)
|
|
|
|
|
|
|
|
mock_integration(hass, MockModule("comp", setup=mock_setup))
|
|
|
|
|
|
|
|
assert await setup.async_setup_component(hass, "comp", {})
|
|
|
|
assert mock_setup.called
|
|
|
|
assert translation.async_translations_loaded(hass, {"comp"}) is True
|
2024-02-26 19:49:43 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def test_importing_integration_in_executor(
|
|
|
|
hass: HomeAssistant, enable_custom_integrations: None
|
|
|
|
) -> None:
|
|
|
|
"""Test we can import an integration in an executor."""
|
|
|
|
assert await setup.async_setup_component(hass, "test_package_loaded_executor", {})
|
|
|
|
assert await setup.async_setup_component(hass, "test_package_loaded_executor", {})
|
|
|
|
await hass.async_block_till_done()
|