From 26a52a154042bbf68e0eb8eecceb0841a3e01906 Mon Sep 17 00:00:00 2001 From: Jacob Laursen Date: Tue, 2 May 2023 08:41:10 +0200 Subject: [PATCH] Fix discovery label consistency (#14919) Signed-off-by: Jacob Laursen --- .../openhab/binding/hue/internal/HueBindingConstants.java | 4 +++- .../discovery/HueBridgeMDNSDiscoveryParticipant.java | 2 +- .../hue/internal/discovery/HueBridgeNupnpDiscovery.java | 6 +++--- .../internal/discovery/HueBridgeNupnpDiscoveryOSGITest.java | 3 ++- 4 files changed, 9 insertions(+), 6 deletions(-) diff --git a/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/HueBindingConstants.java b/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/HueBindingConstants.java index 41158e1fd..f4420fa61 100644 --- a/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/HueBindingConstants.java +++ b/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/HueBindingConstants.java @@ -101,7 +101,9 @@ public class HueBindingConstants { public static final String NORMALIZE_ID_REGEX = "[^a-zA-Z0-9_]"; - // + public static final String DISCOVERY_LABEL_PATTERN = "Philips Hue (%s)"; + + // I18N string references public static final String TEXT_OFFLINE_COMMUNICATION_ERROR = "@text/offline.communication-error"; public static final String TEXT_OFFLINE_CONFIGURATION_ERROR_INVALID_SSL_CERIFICATE = "@text/offline.conf-error-invalid-ssl-certificate"; diff --git a/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeMDNSDiscoveryParticipant.java b/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeMDNSDiscoveryParticipant.java index 4df029f12..023c68000 100644 --- a/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeMDNSDiscoveryParticipant.java +++ b/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeMDNSDiscoveryParticipant.java @@ -107,7 +107,7 @@ public class HueBridgeMDNSDiscoveryParticipant implements MDNSDiscoveryParticipa if (uid != null) { String host = service.getHostAddresses()[0]; String id = service.getPropertyString(MDNS_PROPERTY_BRIDGE_ID); - String friendlyName = String.format("%s (%s)", service.getName(), host); + String friendlyName = String.format(DISCOVERY_LABEL_PATTERN, host); return DiscoveryResultBuilder.create(uid) // .withProperties(Map.of( // HOST, host, // diff --git a/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeNupnpDiscovery.java b/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeNupnpDiscovery.java index 5adcc716b..d011317e0 100644 --- a/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeNupnpDiscovery.java +++ b/bundles/org.openhab.binding.hue/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeNupnpDiscovery.java @@ -49,10 +49,10 @@ import com.google.gson.reflect.TypeToken; @NonNullByDefault public class HueBridgeNupnpDiscovery extends AbstractDiscoveryService { - private static final String MODEL_NAME_PHILIPS_HUE = "\"name\":\"Philips hue\""; protected static final String BRIDGE_INDICATOR = "fffe"; + + private static final String MODEL_NAME_PHILIPS_HUE = "\"name\":\"Philips hue\""; private static final String DISCOVERY_URL = "https://discovery.meethue.com/"; - protected static final String LABEL_PATTERN = "Philips Hue (%s)"; private static final String CONFIG_URL_PATTERN = "http://%s/api/0/config"; private static final int REQUEST_TIMEOUT = 5000; private static final int DISCOVERY_TIMEOUT = 10; @@ -81,7 +81,7 @@ public class HueBridgeNupnpDiscovery extends AbstractDiscoveryService { .withProperties(Map.of( // HOST, host, // Thing.PROPERTY_SERIAL_NUMBER, serialNumber)) // - .withLabel(String.format(LABEL_PATTERN, host)) // + .withLabel(String.format(DISCOVERY_LABEL_PATTERN, host)) // .withRepresentationProperty(Thing.PROPERTY_SERIAL_NUMBER) // .build(); thingDiscovered(result); diff --git a/itests/org.openhab.binding.hue.tests/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeNupnpDiscoveryOSGITest.java b/itests/org.openhab.binding.hue.tests/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeNupnpDiscoveryOSGITest.java index 5d9ceb18d..ec54594a7 100644 --- a/itests/org.openhab.binding.hue.tests/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeNupnpDiscoveryOSGITest.java +++ b/itests/org.openhab.binding.hue.tests/src/main/java/org/openhab/binding/hue/internal/discovery/HueBridgeNupnpDiscoveryOSGITest.java @@ -27,6 +27,7 @@ import java.util.stream.Collectors; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; +import org.openhab.binding.hue.internal.HueBindingConstants; import org.openhab.core.config.discovery.DiscoveryListener; import org.openhab.core.config.discovery.DiscoveryResult; import org.openhab.core.config.discovery.DiscoveryService; @@ -61,7 +62,7 @@ public class HueBridgeNupnpDiscoveryOSGITest extends JavaOSGiTest { private void checkDiscoveryResult(DiscoveryResult result, String expIp, String expSn) { assertThat(result.getBridgeUID(), nullValue()); - assertThat(result.getLabel(), is(String.format(HueBridgeNupnpDiscovery.LABEL_PATTERN, expIp))); + assertThat(result.getLabel(), is(String.format(HueBindingConstants.DISCOVERY_LABEL_PATTERN, expIp))); assertThat(result.getProperties().get("ipAddress"), is(expIp)); assertThat(result.getProperties().get("serialNumber"), is(expSn)); }