Remove trailing whitespace
[openflowjava.git] / openflow-protocol-impl / src / test / java / org / opendaylight / openflowjava / protocol / impl / serialization / factories / SetAsyncInputMessageFactoryTest.java
index 217177cc471c54b25d4f57dcc2f62913decad1ea..d31a117ad8079d9b8bd024cba0d443696ba72b05 100644 (file)
-/* Copyright (C)2013 Pantheon Technologies, s.r.o. All rights reserved. */\r
-package org.opendaylight.openflowjava.protocol.impl.serialization.factories;\r
-\r
-import io.netty.buffer.ByteBuf;\r
-import io.netty.buffer.UnpooledByteBufAllocator;\r
-\r
-import java.util.ArrayList;\r
-import java.util.List;\r
-\r
-import org.junit.Assert;\r
-import org.junit.Test;\r
-import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.HelloMessageFactoryTest;\r
-import org.opendaylight.openflowjava.protocol.impl.util.BufferHelper;\r
-import org.opendaylight.openflowjava.protocol.impl.util.ByteBufUtils;\r
-import org.opendaylight.openflowjava.protocol.impl.util.EncodeConstants;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.FlowRemovedReason;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PacketInReason;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PortReason;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.SetAsyncInput;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.SetAsyncInputBuilder;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.FlowRemovedMask;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.FlowRemovedMaskBuilder;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PacketInMask;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PacketInMaskBuilder;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PortStatusMask;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PortStatusMaskBuilder;\r
-import org.slf4j.Logger;\r
-import org.slf4j.LoggerFactory;\r
-\r
-/**\r
- * @author timotej.kubas\r
- * @author michal.polkorab\r
- */\r
-public class SetAsyncInputMessageFactoryTest {\r
-    private static final Logger LOGGER = LoggerFactory\r
-            .getLogger(SetAsyncInputMessageFactoryTest.class);\r
-    /**\r
-     * @throws Exception \r
-     * Testing of {@link SetAsyncInputMessageFactory} for correct translation from POJO\r
-     */\r
-    @Test\r
-    public void testSetAsyncInputMessage() throws Exception {\r
-        SetAsyncInputBuilder builder = new SetAsyncInputBuilder();\r
-        BufferHelper.setupHeader(builder, EncodeConstants.OF13_VERSION_ID);\r
-        builder.setPacketInMask(createPacketInMask());\r
-        builder.setPortStatusMask(createPortStatusMask());\r
-        builder.setFlowRemovedMask(createFlowRemowedMask());\r
-        SetAsyncInput message = builder.build();\r
-        \r
-        ByteBuf out = UnpooledByteBufAllocator.DEFAULT.buffer();\r
-        SetAsyncInputMessageFactory factory = SetAsyncInputMessageFactory.getInstance();\r
-        factory.messageToBuffer(HelloMessageFactoryTest.VERSION_YET_SUPPORTED, out, message);\r
-        LOGGER.debug("<< " + ByteBufUtils.byteBufToHexString(out));\r
-        BufferHelper.checkHeaderV13(out, factory.getMessageType(), factory.computeLength(message));\r
-        Assert.assertEquals("Wrong packetInMask", 5, out.readUnsignedInt());\r
-        Assert.assertEquals("Wrong packetInMask", 7, out.readUnsignedInt());\r
-        Assert.assertEquals("Wrong portStatusMask", 6, out.readUnsignedInt());\r
-        Assert.assertEquals("Wrong portStatusMask", 0, out.readUnsignedInt());\r
-        Assert.assertEquals("Wrong flowRemovedMask", 10, out.readUnsignedInt());\r
-        Assert.assertEquals("Wrong flowRemovedMask", 5, out.readUnsignedInt());\r
-        \r
-    }\r
-    \r
-    private static List<PacketInMask> createPacketInMask() {\r
-        List<PacketInMask> masks = new ArrayList<>();\r
-        PacketInMaskBuilder builder;\r
-        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER\r
-        builder = new PacketInMaskBuilder();\r
-        List<PacketInReason> packetInReasonList = new ArrayList<>();\r
-        packetInReasonList.add(PacketInReason.OFPRNOMATCH);\r
-        packetInReasonList.add(PacketInReason.OFPRINVALIDTTL);\r
-        builder.setMask(packetInReasonList);\r
-        masks.add(builder.build());\r
-        // OFPCR_ROLE_SLAVE\r
-        builder = new PacketInMaskBuilder();\r
-        packetInReasonList = new ArrayList<>();\r
-        packetInReasonList.add(PacketInReason.OFPRNOMATCH);\r
-        packetInReasonList.add(PacketInReason.OFPRACTION);\r
-        packetInReasonList.add(PacketInReason.OFPRINVALIDTTL);\r
-        builder.setMask(packetInReasonList);\r
-        masks.add(builder.build());\r
-        System.out.println(masks.size());\r
-        return masks;\r
-    }\r
-    \r
-    private static List<PortStatusMask> createPortStatusMask() {\r
-        List<PortStatusMask> masks = new ArrayList<>();\r
-        PortStatusMaskBuilder builder;\r
-        builder = new PortStatusMaskBuilder();\r
-        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER\r
-        List<PortReason> portReasonList = new ArrayList<>();\r
-        portReasonList.add(PortReason.OFPPRDELETE);\r
-        portReasonList.add(PortReason.OFPPRMODIFY);\r
-        builder.setMask(portReasonList);\r
-        masks.add(builder.build());\r
-        // OFPCR_ROLE_SLAVE\r
-        builder = new PortStatusMaskBuilder();\r
-        portReasonList = new ArrayList<>();\r
-        builder.setMask(portReasonList);\r
-        masks.add(builder.build());\r
-        return masks;\r
-    }\r
-    \r
-    private static List<FlowRemovedMask> createFlowRemowedMask() {\r
-        List<FlowRemovedMask> masks = new ArrayList<>();\r
-        FlowRemovedMaskBuilder builder;\r
-        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER\r
-        builder = new FlowRemovedMaskBuilder();\r
-        List<FlowRemovedReason> flowRemovedReasonList = new ArrayList<>();\r
-        flowRemovedReasonList.add(FlowRemovedReason.OFPRRHARDTIMEOUT);\r
-        flowRemovedReasonList.add(FlowRemovedReason.OFPRRGROUPDELETE);\r
-        builder.setMask(flowRemovedReasonList);\r
-        masks.add(builder.build());\r
-        // OFPCR_ROLE_SLAVE\r
-        builder = new FlowRemovedMaskBuilder();\r
-        flowRemovedReasonList = new ArrayList<>();\r
-        flowRemovedReasonList.add(FlowRemovedReason.OFPRRIDLETIMEOUT);\r
-        flowRemovedReasonList.add(FlowRemovedReason.OFPRRDELETE);\r
-        builder.setMask(flowRemovedReasonList);\r
-        masks.add(builder.build());\r
-        return masks;\r
-    }\r
-}\r
+/*
+ * Copyright (c) 2013 Pantheon Technologies s.r.o. and others. All rights reserved.
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v1.0 which accompanies this distribution,
+ * and is available at http://www.eclipse.org/legal/epl-v10.html
+ */
+
+package org.opendaylight.openflowjava.protocol.impl.serialization.factories;
+
+import io.netty.buffer.ByteBuf;
+import io.netty.buffer.UnpooledByteBufAllocator;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.junit.Assert;
+import org.junit.Before;
+import org.junit.Test;
+import org.opendaylight.openflowjava.protocol.api.extensibility.MessageTypeKey;
+import org.opendaylight.openflowjava.protocol.api.extensibility.OFSerializer;
+import org.opendaylight.openflowjava.protocol.api.extensibility.SerializerRegistry;
+import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
+import org.opendaylight.openflowjava.protocol.impl.serialization.SerializerRegistryImpl;
+import org.opendaylight.openflowjava.protocol.impl.util.BufferHelper;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.FlowRemovedReason;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PacketInReason;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PortReason;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.SetAsyncInput;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.SetAsyncInputBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.FlowRemovedMask;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.FlowRemovedMaskBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PacketInMask;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PacketInMaskBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PortStatusMask;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PortStatusMaskBuilder;
+
+/**
+ * @author timotej.kubas
+ * @author michal.polkorab
+ */
+public class SetAsyncInputMessageFactoryTest {
+
+    private SerializerRegistry registry;
+    private OFSerializer<SetAsyncInput> setAsyncFactory;
+
+    /**
+     * Initializes serializer registry and stores correct factory in field
+     */
+    @Before
+    public void startUp() {
+        registry = new SerializerRegistryImpl();
+        registry.init();
+        setAsyncFactory = registry.getSerializer(
+                new MessageTypeKey<>(EncodeConstants.OF13_VERSION_ID, SetAsyncInput.class));
+    }
+
+    /**
+     * @throws Exception
+     * Testing of {@link SetAsyncInputMessageFactory} for correct translation from POJO
+     */
+    @Test
+    public void testSetAsyncInputMessage() throws Exception {
+        SetAsyncInputBuilder builder = new SetAsyncInputBuilder();
+        BufferHelper.setupHeader(builder, EncodeConstants.OF13_VERSION_ID);
+        builder.setPacketInMask(createPacketInMask());
+        builder.setPortStatusMask(createPortStatusMask());
+        builder.setFlowRemovedMask(createFlowRemowedMask());
+        SetAsyncInput message = builder.build();
+
+        ByteBuf out = UnpooledByteBufAllocator.DEFAULT.buffer();
+        setAsyncFactory.serialize(message, out);
+
+        BufferHelper.checkHeaderV13(out,(byte) 28, 32);
+        Assert.assertEquals("Wrong packetInMask", 7, out.readUnsignedInt());
+        Assert.assertEquals("Wrong packetInMask", 0, out.readUnsignedInt());
+        Assert.assertEquals("Wrong portStatusMask", 7, out.readUnsignedInt());
+        Assert.assertEquals("Wrong portStatusMask", 0, out.readUnsignedInt());
+        Assert.assertEquals("Wrong flowRemovedMask", 15, out.readUnsignedInt());
+        Assert.assertEquals("Wrong flowRemovedMask", 0, out.readUnsignedInt());
+
+    }
+
+    private static List<PacketInMask> createPacketInMask() {
+        List<PacketInMask> masks = new ArrayList<>();
+        PacketInMaskBuilder builder;
+        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER
+        builder = new PacketInMaskBuilder();
+        List<PacketInReason> packetInReasonList = new ArrayList<>();
+        packetInReasonList.add(PacketInReason.OFPRNOMATCH);
+        packetInReasonList.add(PacketInReason.OFPRACTION);
+        packetInReasonList.add(PacketInReason.OFPRINVALIDTTL);
+        builder.setMask(packetInReasonList);
+        masks.add(builder.build());
+        // OFPCR_ROLE_SLAVE
+        builder = new PacketInMaskBuilder();
+        packetInReasonList = new ArrayList<>();
+        builder.setMask(packetInReasonList);
+        masks.add(builder.build());
+        return masks;
+    }
+
+    private static List<PortStatusMask> createPortStatusMask() {
+        List<PortStatusMask> masks = new ArrayList<>();
+        PortStatusMaskBuilder builder;
+        builder = new PortStatusMaskBuilder();
+        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER
+        List<PortReason> portReasonList = new ArrayList<>();
+        portReasonList.add(PortReason.OFPPRADD);
+        portReasonList.add(PortReason.OFPPRDELETE);
+        portReasonList.add(PortReason.OFPPRMODIFY);
+        builder.setMask(portReasonList);
+        masks.add(builder.build());
+        // OFPCR_ROLE_SLAVE
+        builder = new PortStatusMaskBuilder();
+        portReasonList = new ArrayList<>();
+        builder.setMask(portReasonList);
+        masks.add(builder.build());
+        return masks;
+    }
+
+    private static List<FlowRemovedMask> createFlowRemowedMask() {
+        List<FlowRemovedMask> masks = new ArrayList<>();
+        FlowRemovedMaskBuilder builder;
+        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER
+        builder = new FlowRemovedMaskBuilder();
+        List<FlowRemovedReason> flowRemovedReasonList = new ArrayList<>();
+        flowRemovedReasonList.add(FlowRemovedReason.OFPRRIDLETIMEOUT);
+        flowRemovedReasonList.add(FlowRemovedReason.OFPRRHARDTIMEOUT);
+        flowRemovedReasonList.add(FlowRemovedReason.OFPRRDELETE);
+        flowRemovedReasonList.add(FlowRemovedReason.OFPRRGROUPDELETE);
+        builder.setMask(flowRemovedReasonList);
+        masks.add(builder.build());
+        // OFPCR_ROLE_SLAVE
+        builder = new FlowRemovedMaskBuilder();
+        flowRemovedReasonList = new ArrayList<>();
+        builder.setMask(flowRemovedReasonList);
+        masks.add(builder.build());
+        return masks;
+    }
+
+    /**
+     * @throws Exception
+     * Testing of {@link SetAsyncInputMessageFactory} for correct translation from POJO
+     */
+    @Test
+    public void testSetAsyncInputWithNullMasks() throws Exception {
+        SetAsyncInputBuilder builder = new SetAsyncInputBuilder();
+        BufferHelper.setupHeader(builder, EncodeConstants.OF13_VERSION_ID);
+        builder.setPacketInMask(null);
+        builder.setPortStatusMask(null);
+        builder.setFlowRemovedMask(null);
+        SetAsyncInput message = builder.build();
+
+        ByteBuf out = UnpooledByteBufAllocator.DEFAULT.buffer();
+        setAsyncFactory.serialize(message, out);
+
+        BufferHelper.checkHeaderV13(out,(byte) 28, 8);
+        Assert.assertTrue("Unexpected data", out.readableBytes() == 0);
+    }
+}
\ No newline at end of file