1
0
mirror of https://github.com/home-assistant/core.git synced 2026-04-02 16:36:08 +01:00
Files
core/tests/components/solarman/test_init.py
SOLARMAN f3cea5160b Add solarman integration (#152525)
Co-authored-by: xiaozhouhhh <13588112144@163.com>
Co-authored-by: Joostlek <joostlek@outlook.com>
2026-03-24 16:09:14 +01:00

53 lines
1.7 KiB
Python

"""Test init of Solarman integration."""
from unittest.mock import AsyncMock
import pytest
from homeassistant.config_entries import ConfigEntryState
from homeassistant.core import HomeAssistant
from tests.common import MockConfigEntry
@pytest.mark.parametrize("device_fixture", ["SP-2W-EU"], indirect=True)
async def test_load_unload(
hass: HomeAssistant,
mock_config_entry: MockConfigEntry,
mock_solarman: AsyncMock,
) -> None:
"""Test setting up and removing a config entry."""
# Add the mock config entry to Home Assistant
mock_config_entry.add_to_hass(hass)
# Set up the integration using the config entry
assert await hass.config_entries.async_setup(mock_config_entry.entry_id)
# Wait for all background tasks to complete
await hass.async_block_till_done()
# Verify the config entry is successfully loaded
assert mock_config_entry.state is ConfigEntryState.LOADED
# Unload the integration
await hass.config_entries.async_unload(mock_config_entry.entry_id)
await hass.async_block_till_done()
# Verify the config entry is properly unloaded
assert mock_config_entry.state is ConfigEntryState.NOT_LOADED
@pytest.mark.parametrize("device_fixture", ["SP-2W-EU"], indirect=True)
async def test_load_failure(
hass: HomeAssistant, mock_config_entry: MockConfigEntry, mock_solarman: AsyncMock
) -> None:
"""Test setup failure."""
mock_solarman.fetch_data.side_effect = TimeoutError
mock_config_entry.add_to_hass(hass)
await hass.config_entries.async_setup(mock_config_entry.entry_id)
await hass.async_block_till_done()
# Verify the config entry enters retry state due to failure
assert mock_config_entry.state is ConfigEntryState.SETUP_RETRY