Fix MQTT setup after changing config entry flow options (#79103)
Fix issues with config flow options
This commit is contained in:
parent
499c3410d1
commit
c5a58c8501
3 changed files with 42 additions and 22 deletions
|
@ -248,20 +248,7 @@ async def _async_config_entry_updated(hass: HomeAssistant, entry: ConfigEntry) -
|
||||||
|
|
||||||
Causes for this is config entry options changing.
|
Causes for this is config entry options changing.
|
||||||
"""
|
"""
|
||||||
mqtt_data = get_mqtt_data(hass)
|
await hass.config_entries.async_reload(entry.entry_id)
|
||||||
assert (client := mqtt_data.client) is not None
|
|
||||||
|
|
||||||
if (conf := mqtt_data.config) is None:
|
|
||||||
conf = CONFIG_SCHEMA_BASE(dict(entry.data))
|
|
||||||
|
|
||||||
mqtt_data.config = _merge_extended_config(entry, conf)
|
|
||||||
await client.async_disconnect()
|
|
||||||
client.init_client()
|
|
||||||
await client.async_connect()
|
|
||||||
|
|
||||||
await discovery.async_stop(hass)
|
|
||||||
if client.conf.get(CONF_DISCOVERY):
|
|
||||||
await _async_setup_discovery(hass, cast(ConfigType, mqtt_data.config), entry)
|
|
||||||
|
|
||||||
|
|
||||||
async def async_fetch_config(hass: HomeAssistant, entry: ConfigEntry) -> dict | None:
|
async def async_fetch_config(hass: HomeAssistant, entry: ConfigEntry) -> dict | None:
|
||||||
|
@ -317,7 +304,9 @@ async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
||||||
if mqtt_data.subscriptions_to_restore:
|
if mqtt_data.subscriptions_to_restore:
|
||||||
mqtt_data.client.subscriptions = mqtt_data.subscriptions_to_restore
|
mqtt_data.client.subscriptions = mqtt_data.subscriptions_to_restore
|
||||||
mqtt_data.subscriptions_to_restore = []
|
mqtt_data.subscriptions_to_restore = []
|
||||||
entry.add_update_listener(_async_config_entry_updated)
|
mqtt_data.reload_dispatchers.append(
|
||||||
|
entry.add_update_listener(_async_config_entry_updated)
|
||||||
|
)
|
||||||
|
|
||||||
await mqtt_data.client.async_connect()
|
await mqtt_data.client.async_connect()
|
||||||
|
|
||||||
|
|
|
@ -262,7 +262,9 @@ class MQTTOptionsFlowHandler(config_entries.OptionsFlow):
|
||||||
updated_config.update(self.broker_config)
|
updated_config.update(self.broker_config)
|
||||||
updated_config.update(options_config)
|
updated_config.update(options_config)
|
||||||
self.hass.config_entries.async_update_entry(
|
self.hass.config_entries.async_update_entry(
|
||||||
self.config_entry, data=updated_config
|
self.config_entry,
|
||||||
|
data=updated_config,
|
||||||
|
title=str(self.broker_config[CONF_BROKER]),
|
||||||
)
|
)
|
||||||
return self.async_create_entry(title="", data={})
|
return self.async_create_entry(title="", data={})
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
"""Test config flow."""
|
"""Test config flow."""
|
||||||
from unittest.mock import patch
|
from unittest.mock import AsyncMock, patch
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
import voluptuous as vol
|
import voluptuous as vol
|
||||||
|
@ -23,6 +23,15 @@ def mock_finish_setup():
|
||||||
yield mock_finish
|
yield mock_finish
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def mock_reload_after_entry_update():
|
||||||
|
"""Mock out the reload after updating the entry."""
|
||||||
|
with patch(
|
||||||
|
"homeassistant.components.mqtt._async_config_entry_updated"
|
||||||
|
) as mock_reload:
|
||||||
|
yield mock_reload
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def mock_try_connection():
|
def mock_try_connection():
|
||||||
"""Mock the try connection method."""
|
"""Mock the try connection method."""
|
||||||
|
@ -180,6 +189,8 @@ async def test_manual_config_set(
|
||||||
mock_try_connection.assert_called_once_with(hass, "127.0.0.1", 1883, None, None)
|
mock_try_connection.assert_called_once_with(hass, "127.0.0.1", 1883, None, None)
|
||||||
# Check config entry got setup
|
# Check config entry got setup
|
||||||
assert len(mock_finish_setup.mock_calls) == 1
|
assert len(mock_finish_setup.mock_calls) == 1
|
||||||
|
config_entry = hass.config_entries.async_entries(mqtt.DOMAIN)[0]
|
||||||
|
assert config_entry.title == "127.0.0.1"
|
||||||
|
|
||||||
|
|
||||||
async def test_user_single_instance(hass):
|
async def test_user_single_instance(hass):
|
||||||
|
@ -269,7 +280,16 @@ async def test_hassio_confirm(hass, mock_try_connection_success, mock_finish_set
|
||||||
assert len(mock_finish_setup.mock_calls) == 1
|
assert len(mock_finish_setup.mock_calls) == 1
|
||||||
|
|
||||||
|
|
||||||
async def test_option_flow(hass, mqtt_mock_entry_no_yaml_config, mock_try_connection):
|
@patch(
|
||||||
|
"homeassistant.config.async_hass_config_yaml",
|
||||||
|
AsyncMock(return_value={}),
|
||||||
|
)
|
||||||
|
async def test_option_flow(
|
||||||
|
hass,
|
||||||
|
mqtt_mock_entry_no_yaml_config,
|
||||||
|
mock_try_connection,
|
||||||
|
mock_reload_after_entry_update,
|
||||||
|
):
|
||||||
"""Test config flow options."""
|
"""Test config flow options."""
|
||||||
mqtt_mock = await mqtt_mock_entry_no_yaml_config()
|
mqtt_mock = await mqtt_mock_entry_no_yaml_config()
|
||||||
mock_try_connection.return_value = True
|
mock_try_connection.return_value = True
|
||||||
|
@ -339,11 +359,16 @@ async def test_option_flow(hass, mqtt_mock_entry_no_yaml_config, mock_try_connec
|
||||||
}
|
}
|
||||||
|
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
assert mqtt_mock.async_connect.call_count == 1
|
assert config_entry.title == "another-broker"
|
||||||
|
# assert that the entry was reloaded with the new config
|
||||||
|
assert mock_reload_after_entry_update.call_count == 1
|
||||||
|
|
||||||
|
|
||||||
async def test_disable_birth_will(
|
async def test_disable_birth_will(
|
||||||
hass, mqtt_mock_entry_no_yaml_config, mock_try_connection
|
hass,
|
||||||
|
mqtt_mock_entry_no_yaml_config,
|
||||||
|
mock_try_connection,
|
||||||
|
mock_reload_after_entry_update,
|
||||||
):
|
):
|
||||||
"""Test disabling birth and will."""
|
"""Test disabling birth and will."""
|
||||||
mqtt_mock = await mqtt_mock_entry_no_yaml_config()
|
mqtt_mock = await mqtt_mock_entry_no_yaml_config()
|
||||||
|
@ -404,7 +429,8 @@ async def test_disable_birth_will(
|
||||||
}
|
}
|
||||||
|
|
||||||
await hass.async_block_till_done()
|
await hass.async_block_till_done()
|
||||||
assert mqtt_mock.async_connect.call_count == 1
|
# assert that the entry was reloaded with the new config
|
||||||
|
assert mock_reload_after_entry_update.call_count == 1
|
||||||
|
|
||||||
|
|
||||||
def get_default(schema, key):
|
def get_default(schema, key):
|
||||||
|
@ -426,7 +452,10 @@ def get_suggested(schema, key):
|
||||||
|
|
||||||
|
|
||||||
async def test_option_flow_default_suggested_values(
|
async def test_option_flow_default_suggested_values(
|
||||||
hass, mqtt_mock_entry_no_yaml_config, mock_try_connection_success
|
hass,
|
||||||
|
mqtt_mock_entry_no_yaml_config,
|
||||||
|
mock_try_connection_success,
|
||||||
|
mock_reload_after_entry_update,
|
||||||
):
|
):
|
||||||
"""Test config flow options has default/suggested values."""
|
"""Test config flow options has default/suggested values."""
|
||||||
await mqtt_mock_entry_no_yaml_config()
|
await mqtt_mock_entry_no_yaml_config()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue