[mqtt.homeassistant] Fix components with an empty name (#17933)

As opposed to null name. In either case, it's not usable,
and we need to use our fallbacks.

Signed-off-by: Cody Cutrer <cody@cutrer.us>
This commit is contained in:
Cody Cutrer 2024-12-20 14:02:28 -07:00 committed by GitHub
parent 7a3380a020
commit fc9e564a2c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 81 additions and 3 deletions

View File

@ -225,7 +225,7 @@ public abstract class AbstractComponent<C extends AbstractChannelConfiguration>
protected ComponentChannel.Builder buildChannel(String channelID, ComponentChannelType channelType, protected ComponentChannel.Builder buildChannel(String channelID, ComponentChannelType channelType,
Value valueState, String label, ChannelStateUpdateListener channelStateUpdateListener) { Value valueState, String label, ChannelStateUpdateListener channelStateUpdateListener) {
if (groupId == null) { if (groupId == null && newStyleChannels) {
channelID = componentId; channelID = componentId;
} }
return new ComponentChannel.Builder(this, channelID, channelType.getChannelTypeUID(), valueState, label, return new ComponentChannel.Builder(this, channelID, channelType.getChannelTypeUID(), valueState, label,
@ -304,12 +304,15 @@ public abstract class AbstractComponent<C extends AbstractChannelConfiguration>
*/ */
public String getName() { public String getName() {
String result = channelConfiguration.getName(); String result = channelConfiguration.getName();
if (result.isBlank()) {
result = null;
}
Device device = channelConfiguration.getDevice(); Device device = channelConfiguration.getDevice();
if (result == null && device != null) { if (result == null && device != null) {
result = device.getName(); result = device.getName();
} }
if (result == null) { if (result == null || result.isBlank()) {
result = haID.objectID; result = haID.objectID;
} }
return result; return result;

View File

@ -38,6 +38,7 @@ import org.openhab.core.library.unit.Units;
@NonNullByDefault @NonNullByDefault
public class ClimateTests extends AbstractComponentTests { public class ClimateTests extends AbstractComponentTests {
public static final String CONFIG_TOPIC = "climate/0x847127fffe11dd6a_climate_zigbee2mqtt"; public static final String CONFIG_TOPIC = "climate/0x847127fffe11dd6a_climate_zigbee2mqtt";
public static final String TION_CONFIG_TOPIC = "climate/living-room-tion-3s/living-room-tion-3s";
@SuppressWarnings("null") @SuppressWarnings("null")
@Test @Test
@ -397,8 +398,82 @@ public class ClimateTests extends AbstractComponentTests {
assertState(component, Climate.TARGET_HUMIDITY_CH_ID, new QuantityType<>(50, Units.PERCENT)); assertState(component, Climate.TARGET_HUMIDITY_CH_ID, new QuantityType<>(50, Units.PERCENT));
} }
@SuppressWarnings("null")
@Test
public void testClimateWithEmptyName() {
var component = discoverComponent(configTopicToMqtt(TION_CONFIG_TOPIC), """
{
"curr_temp_t": "living-room-tion-3s/climate/living-room-tion-3s/current_temperature/state",
"mode_cmd_t": "living-room-tion-3s/climate/living-room-tion-3s/mode/command",
"mode_stat_t": "living-room-tion-3s/climate/living-room-tion-3s/mode/state",
"modes": [
"off",
"heat",
"fan_only",
"heat_cool"
],
"temp_cmd_t": "living-room-tion-3s/climate/living-room-tion-3s/target_temperature/command",
"temp_stat_t": "living-room-tion-3s/climate/living-room-tion-3s/target_temperature/state",
"min_temp": 1,
"max_temp": 25,
"temp_step": 1,
"precision": 1,
"temp_unit": "C",
"min_hum": 30,
"max_hum": 99,
"act_t": "living-room-tion-3s/climate/living-room-tion-3s/action/state",
"fan_mode_cmd_t": "living-room-tion-3s/climate/living-room-tion-3s/fan_mode/command",
"fan_mode_stat_t": "living-room-tion-3s/climate/living-room-tion-3s/fan_mode/state",
"fan_modes": [
"1",
"2",
"3",
"4",
"5",
"6"
],
"name": "",
"ic": "mdi:air-filter",
"avty_t": "living-room-tion-3s/status",
"uniq_id": "ESPclimateliving-room-tion-3s",
"dev": {
"ids": "f09e9e213ab0",
"name": "living-room-tion-3s",
"sw": "2024.8.0 (ESPHome 2024.11.3)",
"mdl": "tion",
"mf": "dentra",
"cns": [
[
"mac",
"f09e9e213ab0"
]
]
}
}
""");
assertThat(component.channels.size(), is(5));
assertThat(component.getName(), is("living-room-tion-3s"));
assertChannel(component, Climate.ACTION_CH_ID, "living-room-tion-3s/climate/living-room-tion-3s/action/state",
"", "living-room-tion-3s", TextValue.class);
assertChannel(component, Climate.CURRENT_TEMPERATURE_CH_ID_DEPRECATED,
"living-room-tion-3s/climate/living-room-tion-3s/current_temperature/state", "", "living-room-tion-3s",
NumberValue.class);
assertChannel(component, Climate.FAN_MODE_CH_ID_DEPRECATED,
"living-room-tion-3s/climate/living-room-tion-3s/fan_mode/state",
"living-room-tion-3s/climate/living-room-tion-3s/fan_mode/command", "living-room-tion-3s",
TextValue.class);
assertChannel(component, Climate.MODE_CH_ID, "living-room-tion-3s/climate/living-room-tion-3s/mode/state",
"living-room-tion-3s/climate/living-room-tion-3s/mode/command", "living-room-tion-3s", TextValue.class);
assertChannel(component, Climate.TEMPERATURE_CH_ID,
"living-room-tion-3s/climate/living-room-tion-3s/target_temperature/state",
"living-room-tion-3s/climate/living-room-tion-3s/target_temperature/command", "living-room-tion-3s",
NumberValue.class);
}
@Override @Override
protected Set<String> getConfigTopics() { protected Set<String> getConfigTopics() {
return Set.of(CONFIG_TOPIC); return Set.of(CONFIG_TOPIC, TION_CONFIG_TOPIC);
} }
} }