From a9ae169c513f90151e6d4363c588faeedb6978e3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rouven=20Sch=C3=BCrch?= <803221+ardanedh@users.noreply.github.com> Date: Mon, 25 Oct 2021 12:01:10 +0200 Subject: [PATCH] Fixes #11054: NoSuchElementException when no functional groups set (#11434) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Rouven Schürch --- .../internal/handler/DeviceHandler.java | 16 +++++++++----- .../structure/devices/impl/DeviceImpl.java | 4 +++- .../devices/impl/DeviceImplTest.java | 21 +++++++++++++++++++ 3 files changed, 35 insertions(+), 6 deletions(-) diff --git a/bundles/org.openhab.binding.digitalstrom/src/main/java/org/openhab/binding/digitalstrom/internal/handler/DeviceHandler.java b/bundles/org.openhab.binding.digitalstrom/src/main/java/org/openhab/binding/digitalstrom/internal/handler/DeviceHandler.java index 6228b2c98cd5b..962657c798944 100644 --- a/bundles/org.openhab.binding.digitalstrom/src/main/java/org/openhab/binding/digitalstrom/internal/handler/DeviceHandler.java +++ b/bundles/org.openhab.binding.digitalstrom/src/main/java/org/openhab/binding/digitalstrom/internal/handler/DeviceHandler.java @@ -32,6 +32,7 @@ import org.openhab.binding.digitalstrom.internal.lib.structure.devices.GeneralDeviceInformation; import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.DeviceSceneSpec; import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.DeviceStateUpdate; +import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.constants.ApplicationGroup; import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.constants.ChangeableDeviceConfigEnum; import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.constants.DeviceBinarayInputEnum; import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.constants.OutputModeEnum; @@ -457,9 +458,11 @@ public synchronized void onDeviceAdded(GeneralDeviceInformation device) { checkOutputChannel(); } else if (this.device.isBlind()) { // load channel for set the angle of jalousie devices - String channelTypeID = DsChannelTypeProvider.getOutputChannelTypeID( - ((Device) device).getFunctionalColorGroup().getColor(), ((Device) device).getOutputMode(), - ((Device) device).getOutputChannels()); + ApplicationGroup.Color color = ((Device) device).getFunctionalColorGroup() != null + ? ((Device) device).getFunctionalColorGroup().getColor() + : null; + String channelTypeID = DsChannelTypeProvider.getOutputChannelTypeID(color, + ((Device) device).getOutputMode(), ((Device) device).getOutputChannels()); loadOutputChannel(new ChannelTypeUID(BINDING_ID, channelTypeID), DsChannelTypeProvider.getItemType(channelTypeID)); } @@ -713,8 +716,11 @@ private void checkOutputChannel() { if (!device.isDeviceWithOutput()) { loadOutputChannel(null, null); } - String channelTypeID = DsChannelTypeProvider.getOutputChannelTypeID(device.getFunctionalColorGroup().getColor(), - device.getOutputMode(), device.getOutputChannels()); + ApplicationGroup.Color color = device.getFunctionalColorGroup() != null + ? device.getFunctionalColorGroup().getColor() + : null; + String channelTypeID = DsChannelTypeProvider.getOutputChannelTypeID(color, device.getOutputMode(), + device.getOutputChannels()); logger.debug("load channel: typeID={}, itemType={}", DsChannelTypeProvider.getOutputChannelTypeID(device.getFunctionalColorGroup().getColor(), device.getOutputMode(), device.getOutputChannels()), diff --git a/bundles/org.openhab.binding.digitalstrom/src/main/java/org/openhab/binding/digitalstrom/internal/lib/structure/devices/impl/DeviceImpl.java b/bundles/org.openhab.binding.digitalstrom/src/main/java/org/openhab/binding/digitalstrom/internal/lib/structure/devices/impl/DeviceImpl.java index ccec7c0a566b9..eaf3033648753 100644 --- a/bundles/org.openhab.binding.digitalstrom/src/main/java/org/openhab/binding/digitalstrom/internal/lib/structure/devices/impl/DeviceImpl.java +++ b/bundles/org.openhab.binding.digitalstrom/src/main/java/org/openhab/binding/digitalstrom/internal/lib/structure/devices/impl/DeviceImpl.java @@ -20,6 +20,7 @@ import java.util.List; import java.util.Map; import java.util.Map.Entry; +import java.util.Optional; import java.util.Set; import org.openhab.binding.digitalstrom.internal.DigitalSTROMBindingConstants; @@ -405,7 +406,8 @@ public boolean isBlind() { @Override public synchronized ApplicationGroup getFunctionalColorGroup() { - return groupList.stream().findFirst().get(); + Optional applicationGroup = groupList.stream().findFirst(); + return applicationGroup.isPresent() ? applicationGroup.get() : null; } @Override diff --git a/bundles/org.openhab.binding.digitalstrom/src/test/java/org/openhab/binding/digitalstrom/internal/lib/structure/devices/impl/DeviceImplTest.java b/bundles/org.openhab.binding.digitalstrom/src/test/java/org/openhab/binding/digitalstrom/internal/lib/structure/devices/impl/DeviceImplTest.java index b3ea80a65fb17..269f8c8796270 100644 --- a/bundles/org.openhab.binding.digitalstrom/src/test/java/org/openhab/binding/digitalstrom/internal/lib/structure/devices/impl/DeviceImplTest.java +++ b/bundles/org.openhab.binding.digitalstrom/src/test/java/org/openhab/binding/digitalstrom/internal/lib/structure/devices/impl/DeviceImplTest.java @@ -14,15 +14,18 @@ import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.core.Is.*; +import static org.junit.jupiter.api.Assertions.assertNull; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import org.eclipse.jdt.annotation.NonNullByDefault; +import org.junit.jupiter.api.DisplayName; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.mockito.junit.jupiter.MockitoExtension; +import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.constants.ApplicationGroup; import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.constants.OutputChannelEnum; import org.openhab.binding.digitalstrom.internal.lib.structure.devices.deviceparameters.constants.OutputModeEnum; import org.openhab.binding.digitalstrom.internal.lib.util.JsonModel; @@ -150,6 +153,24 @@ void isBlindPositionConMixedChannels() { assertThat(deviceImpl.isBlind(), is(true)); } + @Test + @DisplayName("No functional color group set, expect a null value returned") + void noFunctionalColorGroupSet() { + DeviceImpl deviceImpl = new DeviceImpl(new JsonObject()); + ApplicationGroup functionalColorGroup = deviceImpl.getFunctionalColorGroup(); + assertNull(functionalColorGroup); + } + + @Test + @DisplayName("Multiple functional color groups set, expect the first group returned which had previously been added") + void multipleFunctionalColorGroupSet() { + DeviceImpl deviceImpl = new DeviceImpl(new JsonObject()); + deviceImpl.addGroup(ApplicationGroup.JOKER.getId()); + deviceImpl.addGroup(ApplicationGroup.ACCESS.getId()); + + assertThat(deviceImpl.getFunctionalColorGroup(), is(ApplicationGroup.JOKER)); + } + private static JsonObject createJsonObject(OutputModeEnum outputMode, List channels) { JsonModel model = new JsonModel(outputMode.getMode(), channels);