mirror of
https://github.com/danieldemus/openhab-core.git
synced 2025-01-25 11:45:49 +01:00
Channel groups should not require static channels (#696)
* channel groups should not require static channels * Added unit tests Also-by: Christoph Weitkamp <github@christophweitkamp.de> Signed-off-by: Thomas Weißschuh <thomas@t-8ch.de>
This commit is contained in:
parent
7838a6a46f
commit
82b7ff6db9
@ -56,7 +56,7 @@ public class ChannelGroupTypeConverter extends AbstractDescriptionTypeConverter<
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
protected List<ChannelXmlResult> readChannelTypeDefinitions(NodeIterator nodeIterator) throws ConversionException {
|
||||
return (List<ChannelXmlResult>) nodeIterator.nextList("channels", true);
|
||||
return (List<ChannelXmlResult>) nodeIterator.nextList("channels", false);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -88,7 +88,7 @@
|
||||
<xs:element name="label" type="xs:string"/>
|
||||
<xs:element name="description" type="xs:string" minOccurs="0"/>
|
||||
<xs:element name="category" type="xs:string" minOccurs="0"/>
|
||||
<xs:element name="channels" type="thing-description:channels" minOccurs="1"/>
|
||||
<xs:element name="channels" type="thing-description:channels" minOccurs="0"/>
|
||||
</xs:sequence>
|
||||
<xs:attribute name="id" type="config-description:idRestrictionPattern" use="required"/>
|
||||
<xs:attribute name="advanced" type="xs:boolean" default="false" use="optional"/>
|
||||
|
@ -24,6 +24,9 @@ import java.util.Set;
|
||||
import org.eclipse.smarthome.core.thing.binding.ThingTypeProvider;
|
||||
import org.eclipse.smarthome.core.thing.type.BridgeType;
|
||||
import org.eclipse.smarthome.core.thing.type.ChannelDefinition;
|
||||
import org.eclipse.smarthome.core.thing.type.ChannelGroupDefinition;
|
||||
import org.eclipse.smarthome.core.thing.type.ChannelGroupType;
|
||||
import org.eclipse.smarthome.core.thing.type.ChannelGroupTypeRegistry;
|
||||
import org.eclipse.smarthome.core.thing.type.ChannelType;
|
||||
import org.eclipse.smarthome.core.thing.type.ChannelTypeRegistry;
|
||||
import org.eclipse.smarthome.core.thing.type.ThingType;
|
||||
@ -40,11 +43,12 @@ public class ThingTypesTest extends JavaOSGiTest {
|
||||
|
||||
private LoadedTestBundle loadedTestBundle() throws Exception {
|
||||
return new LoadedTestBundle("ThingTypesTest.bundle", bundleContext, this::getService,
|
||||
new StuffAddition().thingTypes(3));
|
||||
new StuffAddition().thingTypes(4));
|
||||
}
|
||||
|
||||
private ThingTypeProvider thingTypeProvider;
|
||||
private ChannelTypeRegistry channelTypeRegistry;
|
||||
private ChannelGroupTypeRegistry channelGroupTypeRegistry;
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
@ -53,6 +57,9 @@ public class ThingTypesTest extends JavaOSGiTest {
|
||||
|
||||
channelTypeRegistry = getService(ChannelTypeRegistry.class);
|
||||
assertThat(channelTypeRegistry, is(notNullValue()));
|
||||
|
||||
channelGroupTypeRegistry = getService(ChannelGroupTypeRegistry.class);
|
||||
assertThat(channelGroupTypeRegistry, is(notNullValue()));
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -60,6 +67,7 @@ public class ThingTypesTest extends JavaOSGiTest {
|
||||
try (final AutoCloseable unused = loadedTestBundle()) {
|
||||
Collection<ThingType> thingTypes = thingTypeProvider.getThingTypes(null);
|
||||
|
||||
// HUE Bridge
|
||||
BridgeType bridgeType = (BridgeType) thingTypes.stream().filter(it -> it.toString().equals("hue:bridge"))
|
||||
.findFirst().get();
|
||||
assertThat(bridgeType, is(notNullValue()));
|
||||
@ -71,6 +79,7 @@ public class ThingTypesTest extends JavaOSGiTest {
|
||||
assertThat(bridgeType.getProperties().get("vendor"), is("Philips"));
|
||||
assertThat(bridgeType.getRepresentationProperty(), is("serialNumber"));
|
||||
|
||||
// HUE Lamp
|
||||
ThingType thingType = thingTypes.stream().filter(it -> it.toString().equals("hue:lamp")).findFirst().get();
|
||||
|
||||
assertThat(thingType, is(notNullValue()));
|
||||
@ -163,11 +172,42 @@ public class ThingTypesTest extends JavaOSGiTest {
|
||||
assertThat(state.getOptions().get(0).getValue(), is(equalTo("SOUND")));
|
||||
assertThat(state.getOptions().get(0).getLabel(), is(equalTo("My great sound.")));
|
||||
|
||||
// HUE Lamp with group
|
||||
thingType = thingTypes.stream().filter(it -> it.toString().equals("hue:lamp-with-group")).findFirst().get();
|
||||
assertThat(thingType, is(notNullValue()));
|
||||
assertThat(thingType.getProperties().size(), is(0));
|
||||
assertThat(thingType.getCategory(), is(nullValue()));
|
||||
assertThat(thingType.isListed(), is(true));
|
||||
assertThat(thingType.getExtensibleChannelTypeIds(), containsInAnyOrder("brightness", "alarm"));
|
||||
|
||||
List<ChannelGroupDefinition> channelGroupDefinitions = thingType.getChannelGroupDefinitions();
|
||||
assertThat(channelGroupDefinitions.size(), is(2));
|
||||
|
||||
// Channel Group
|
||||
ChannelGroupDefinition channelGroupDefinition = channelGroupDefinitions.stream()
|
||||
.filter(it -> it.getId().equals("lampgroup")).findFirst().get();
|
||||
assertThat(channelGroupDefinition, is(notNullValue()));
|
||||
ChannelGroupType channelGroupType = channelGroupTypeRegistry
|
||||
.getChannelGroupType(channelGroupDefinition.getTypeUID());
|
||||
assertThat(channelGroupType, is(notNullValue()));
|
||||
channelDefinitions = channelGroupType.getChannelDefinitions();
|
||||
assertThat(channelDefinitions.size(), is(3));
|
||||
|
||||
// Channel Group without channels
|
||||
channelGroupDefinition = channelGroupDefinitions.stream()
|
||||
.filter(it -> it.getId().equals("lampgroup-without-channels")).findFirst().get();
|
||||
assertThat(channelGroupDefinition, is(notNullValue()));
|
||||
channelGroupType = channelGroupTypeRegistry.getChannelGroupType(channelGroupDefinition.getTypeUID());
|
||||
assertThat(channelGroupType, is(notNullValue()));
|
||||
channelDefinitions = channelGroupType.getChannelDefinitions();
|
||||
assertThat(channelDefinitions.size(), is(0));
|
||||
|
||||
// HUE Lamp without channels
|
||||
thingType = thingTypes.stream().filter(it -> it.toString().equals("hue:lamp-without-channels")).findFirst()
|
||||
.get();
|
||||
assertThat(thingType, is(notNullValue()));
|
||||
channelDefinitions = thingType.getChannelDefinitions();
|
||||
assertThat(channelDefinitions.size(), is(0));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1,6 +1,5 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<thing:thing-descriptions bindingId="hue"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
<thing:thing-descriptions bindingId="hue" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xmlns:thing="http://eclipse.org/smarthome/schemas/thing-description/v1.0.0"
|
||||
xsi:schemaLocation="http://eclipse.org/smarthome/schemas/thing-description/v1.0.0 org.eclipse.smarthome.thing-description.xsd">
|
||||
|
||||
@ -63,7 +62,7 @@
|
||||
<representation-property>uniqueId</representation-property>
|
||||
</thing-type>
|
||||
|
||||
<!-- HUE Lamp with Group -->
|
||||
<!-- HUE Lamp with group -->
|
||||
<thing-type id="lamp-with-group" extensible="brightness, alarm">
|
||||
|
||||
<label>HUE Lamp</label>
|
||||
@ -71,17 +70,34 @@
|
||||
|
||||
<channel-groups>
|
||||
<channel-group id="lampgroup" typeId="lampgroup" />
|
||||
<channel-group id="lampgroup-without-channels" typeId="lampgroup-without-channels" />
|
||||
</channel-groups>
|
||||
</thing-type>
|
||||
|
||||
<!-- HUE Lamp without channels -->
|
||||
<thing-type id="lamp-without-channels" listed="false" extensible="alarm,brightness">
|
||||
<supported-bridge-type-refs>
|
||||
<bridge-type-ref id="bridge" />
|
||||
</supported-bridge-type-refs>
|
||||
|
||||
<label>HUE Lamp</label>
|
||||
<description>My own great HUE Lamp without channels.</description>
|
||||
|
||||
<category>Lightbulb</category>
|
||||
|
||||
<properties>
|
||||
<property name="key1">value1</property>
|
||||
<property name="key2">value2</property>
|
||||
</properties>
|
||||
<representation-property>uniqueId</representation-property>
|
||||
</thing-type>
|
||||
|
||||
<!-- HUE Lamp Color Channel -->
|
||||
<channel-type id="color">
|
||||
<item-type>ColorItem</item-type>
|
||||
<label>HUE Lamp Color</label>
|
||||
<description>The color channel allows to control the color of the hue
|
||||
lamp. It is also possible to dim values and switch the lamp on and
|
||||
off.
|
||||
<description>The color channel allows to control the color of the hue lamp. It is also possible to dim values and
|
||||
switch the lamp on and off.
|
||||
</description>
|
||||
<tags>
|
||||
<tag>Hue</tag>
|
||||
@ -116,8 +132,7 @@
|
||||
<tag>Hue</tag>
|
||||
<tag>AlarmSystem</tag>
|
||||
</tags>
|
||||
<state min="0" max="100.0" step="10.0" pattern="%d Peek"
|
||||
readOnly="true">
|
||||
<state min="0" max="100.0" step="10.0" pattern="%d Peek" readOnly="true">
|
||||
<options>
|
||||
<option value="SOUND">My great sound.</option>
|
||||
<option value="LIGHT" />
|
||||
@ -136,4 +151,10 @@
|
||||
</channels>
|
||||
</channel-group-type>
|
||||
|
||||
<!-- Channel Group without channels -->
|
||||
<channel-group-type id="lampgroup-without-channels" advanced="true">
|
||||
<label>Alarm System</label>
|
||||
<description>The alarm system without channels.</description>
|
||||
</channel-group-type>
|
||||
|
||||
</thing:thing-descriptions>
|
||||
|
Loading…
Reference in New Issue
Block a user