Remove trailing whitespace
[openflowjava.git] / openflow-protocol-impl / src / test / java / org / opendaylight / openflowjava / protocol / impl / deserialization / factories / GetAsyncReplyMessageFactoryTest.java
index 032cb8e45d8c4e0cdc7b86771d0ebd987634a497..c9dabd87cc51d9cde3983d753841c770468cab0d 100644 (file)
-/* Copyright (C)2013 Pantheon Technologies, s.r.o. All rights reserved. */\r
-package org.opendaylight.openflowjava.protocol.impl.deserialization.factories;\r
-\r
-import java.util.ArrayList;\r
-import java.util.List;\r
-\r
-import io.netty.buffer.ByteBuf;\r
-\r
-import org.junit.Assert;\r
-import org.junit.Test;\r
-import org.opendaylight.openflowjava.protocol.impl.util.BufferHelper;\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.GetAsyncOutput;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.get.async.reply.FlowRemovedMask;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.get.async.reply.FlowRemovedMaskBuilder;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.get.async.reply.PacketInMask;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.get.async.reply.PacketInMaskBuilder;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.get.async.reply.PortStatusMask;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.get.async.reply.PortStatusMaskBuilder;\r
-\r
-/**\r
- * @author timotej.kubas\r
- *\r
- */\r
-public class GetAsyncReplyMessageFactoryTest {\r
-\r
-    /**\r
-     * Testing {@link GetAsyncReplyMessageFactory} for correct translation into POJO\r
-     */\r
-    @Test\r
-    public void testGetAsyncReplyMessage() {\r
-        ByteBuf bb = BufferHelper.buildBuffer("00 00 00 02 "+ \r
-                                              "00 00 00 02 "+\r
-                                              "00 00 00 02 "+\r
-                                              "00 00 00 02 "+\r
-                                              "00 00 00 04 "+\r
-                                              "00 00 00 04");\r
-        GetAsyncOutput builtByFactory = BufferHelper.decodeV13(GetAsyncReplyMessageFactory.getInstance(), bb);\r
-\r
-        BufferHelper.checkHeaderV13(builtByFactory);\r
-        Assert.assertEquals("Wrong packetInMask",createPacketInMask().get(0).getMask(), \r
-                                                 builtByFactory.getPacketInMask().get(0).getMask());\r
-        Assert.assertEquals("Wrong portStatusMask",createPortStatusMask().get(0).getMask(), \r
-                                                   builtByFactory.getPortStatusMask().get(0).getMask());\r
-        Assert.assertEquals("Wrong flowRemovedMask",createFlowRemovedMask().get(0).getMask(), \r
-                                                    builtByFactory.getFlowRemovedMask().get(0).getMask());\r
-    }\r
-    \r
-    private static List<PacketInMask> createPacketInMask() {\r
-        List<PacketInReason> readPIRList = new ArrayList<>();\r
-        List<PacketInMask> inMasks = new ArrayList<>();\r
-        PacketInMaskBuilder maskBuilder = new PacketInMaskBuilder();\r
-        \r
-        readPIRList.add(PacketInReason.forValue(1));\r
-        readPIRList.add(PacketInReason.forValue(1));\r
-        inMasks.add(maskBuilder.setMask(readPIRList).build());\r
-        return inMasks;\r
-    }\r
-    \r
-    private static List<PortStatusMask> createPortStatusMask() {\r
-        List<PortReason> readPortReasonList = new ArrayList<>();\r
-        List<PortStatusMask> inMasks = new ArrayList<>();\r
-        PortStatusMaskBuilder maskBuilder = new PortStatusMaskBuilder();\r
-        \r
-        readPortReasonList.add(PortReason.forValue(1));\r
-        readPortReasonList.add(PortReason.forValue(1));\r
-        inMasks.add(maskBuilder.setMask(readPortReasonList).build()); \r
-        return inMasks;\r
-    }\r
-    \r
-    private static List<FlowRemovedMask> createFlowRemovedMask() {\r
-        List<FlowRemovedReason> readFlowRemovedReasonList = new ArrayList<>();\r
-        List<FlowRemovedMask> inMasks = new ArrayList<>();\r
-        FlowRemovedMaskBuilder maskBuilder = new FlowRemovedMaskBuilder();\r
-        \r
-        readFlowRemovedReasonList.add(FlowRemovedReason.forValue(2));\r
-        readFlowRemovedReasonList.add(FlowRemovedReason.forValue(2));\r
-        inMasks.add(maskBuilder.setMask(readFlowRemovedReasonList).build()); \r
-        return inMasks;\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.deserialization.factories;
+
+import io.netty.buffer.ByteBuf;
+
+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.DeserializerRegistry;
+import org.opendaylight.openflowjava.protocol.api.extensibility.MessageCodeKey;
+import org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
+import org.opendaylight.openflowjava.protocol.impl.deserialization.DeserializerRegistryImpl;
+import org.opendaylight.openflowjava.protocol.impl.util.BufferHelper;
+import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
+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.GetAsyncOutput;
+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
+ *
+ */
+public class GetAsyncReplyMessageFactoryTest {
+
+    private OFDeserializer<GetAsyncOutput> asyncFactory;
+
+    /**
+     * Initializes deserializer registry and lookups correct deserializer
+     */
+    @Before
+    public void startUp() {
+        DeserializerRegistry registry = new DeserializerRegistryImpl();
+        registry.init();
+        asyncFactory = registry.getDeserializer(
+                new MessageCodeKey(EncodeConstants.OF13_VERSION_ID, 27, GetAsyncOutput.class));
+    }
+
+    /**
+     * Testing {@link GetAsyncReplyMessageFactory} for correct translation into POJO
+     */
+    @Test
+    public void testGetAsyncReplyMessage() {
+        ByteBuf bb = BufferHelper.buildBuffer("00 00 00 07 "+
+                                              "00 00 00 00 "+
+                                              "00 00 00 07 "+
+                                              "00 00 00 00 "+
+                                              "00 00 00 0F "+
+                                              "00 00 00 00");
+        GetAsyncOutput builtByFactory = BufferHelper.deserialize(asyncFactory, bb);
+
+        BufferHelper.checkHeaderV13(builtByFactory);
+        Assert.assertEquals("Wrong packetInMask",createPacketInMask(), builtByFactory.getPacketInMask());
+        Assert.assertEquals("Wrong portStatusMask",createPortStatusMask(), builtByFactory.getPortStatusMask());
+        Assert.assertEquals("Wrong flowRemovedMask",createFlowRemovedMask(), builtByFactory.getFlowRemovedMask());
+    }
+
+    private static List<PacketInMask> createPacketInMask() {
+        List<PacketInMask> inMasks = new ArrayList<>();
+        PacketInMaskBuilder maskBuilder;
+        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER
+        maskBuilder = new PacketInMaskBuilder();
+        List<PacketInReason> reasons = new ArrayList<>();
+        reasons.add(PacketInReason.OFPRNOMATCH);
+        reasons.add(PacketInReason.OFPRACTION);
+        reasons.add(PacketInReason.OFPRINVALIDTTL);
+        maskBuilder.setMask(reasons);
+        inMasks.add(maskBuilder.build());
+        // OFPCR_ROLE_SLAVE
+        maskBuilder = new PacketInMaskBuilder();
+        reasons = new ArrayList<>();
+        maskBuilder.setMask(reasons);
+        inMasks.add(maskBuilder.build());
+        return inMasks;
+    }
+
+    private static List<PortStatusMask> createPortStatusMask() {
+        List<PortStatusMask> inMasks = new ArrayList<>();
+        PortStatusMaskBuilder maskBuilder;
+        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER
+        maskBuilder = new PortStatusMaskBuilder();
+        List<PortReason> reasons = new ArrayList<>();
+        reasons.add(PortReason.OFPPRADD);
+        reasons.add(PortReason.OFPPRDELETE);
+        reasons.add(PortReason.OFPPRMODIFY);
+        inMasks.add(maskBuilder.setMask(reasons).build());
+        // OFPCR_ROLE_SLAVE
+        maskBuilder = new PortStatusMaskBuilder();
+        reasons = new ArrayList<>();
+        maskBuilder.setMask(reasons);
+        inMasks.add(maskBuilder.build());
+        return inMasks;
+    }
+
+    private static List<FlowRemovedMask> createFlowRemovedMask() {
+        List<FlowRemovedMask> inMasks = new ArrayList<>();
+        FlowRemovedMaskBuilder maskBuilder;
+        // OFPCR_ROLE_EQUAL or OFPCR_ROLE_MASTER
+        maskBuilder = new FlowRemovedMaskBuilder();
+        List<FlowRemovedReason> reasons = new ArrayList<>();
+        reasons.add(FlowRemovedReason.OFPRRIDLETIMEOUT);
+        reasons.add(FlowRemovedReason.OFPRRHARDTIMEOUT);
+        reasons.add(FlowRemovedReason.OFPRRDELETE);
+        reasons.add(FlowRemovedReason.OFPRRGROUPDELETE);
+        maskBuilder.setMask(reasons);
+        inMasks.add(maskBuilder.build());
+        // OFPCR_ROLE_SLAVE
+        maskBuilder = new FlowRemovedMaskBuilder();
+        reasons = new ArrayList<>();
+        maskBuilder.setMask(reasons);
+        inMasks.add(maskBuilder.build());
+        return inMasks;
+    }
+}
\ No newline at end of file