Remove trailing whitespace
[openflowjava.git] / openflow-protocol-impl / src / test / java / org / opendaylight / openflowjava / protocol / impl / serialization / factories / EchoReplyInputMessageFactoryTest.java
index 8ebe18f89bcc7ad8ebd164a35bcf550920291d5a..be4130a0685cffaa4429ca31a5a76212332ac8ee 100644 (file)
@@ -1,42 +1,93 @@
-/* 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 org.junit.Assert;\r
-import org.junit.Test;\r
-import org.opendaylight.openflowjava.protocol.impl.core.OFFrameDecoder;\r
-import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.HelloMessageFactoryTest;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.EchoReplyInput;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.EchoReplyInputBuilder;\r
-\r
-/**\r
- * @author michal.polkorab\r
- *\r
- */\r
-public class EchoReplyInputMessageFactoryTest {\r
-\r
-    private static final byte ECHO_REPLY_MESSAGE_CODE_TYPE = 3;\r
-    \r
-    /**\r
-     * Testing of {@link EchoReplyInputMessageFactory} for correct translation from POJO\r
-     */\r
-    @Test\r
-    public void test() {\r
-        EchoReplyInputBuilder erib = new EchoReplyInputBuilder();\r
-        erib.setVersion(HelloMessageFactoryTest.VERSION_YET_SUPPORTED);\r
-        erib.setXid(16909060L);\r
-        EchoReplyInput eri = erib.build();\r
-        \r
-        ByteBuf out = UnpooledByteBufAllocator.DEFAULT.buffer();\r
-        EchoReplyInputMessageFactory eimf = EchoReplyInputMessageFactory.getInstance();\r
-        eimf.messageToBuffer(HelloMessageFactoryTest.VERSION_YET_SUPPORTED, out, eri);\r
-        \r
-        Assert.assertTrue(out.readByte() == HelloMessageFactoryTest.VERSION_YET_SUPPORTED);\r
-        Assert.assertTrue(out.readByte() == ECHO_REPLY_MESSAGE_CODE_TYPE);\r
-        Assert.assertTrue(out.readUnsignedShort() == OFFrameDecoder.LENGTH_OF_HEADER);\r
-        Assert.assertTrue(out.readUnsignedInt() == 16909060L);\r
-    }\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 org.junit.Assert;
+import io.netty.buffer.ByteBuf;
+import io.netty.buffer.UnpooledByteBufAllocator;
+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.protocol.rev130731.EchoReplyInput;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.EchoReplyInputBuilder;
+
+/**
+ * @author michal.polkorab
+ *
+ */
+public class EchoReplyInputMessageFactoryTest {
+
+    private static final byte ECHO_REPLY_MESSAGE_CODE_TYPE = 3;
+    private SerializerRegistry registry;
+    private OFSerializer<EchoReplyInput> echoFactory;
+
+    /**
+     * Initializes serializer registry and stores correct factory in field
+     */
+    @Before
+    public void startUp() {
+        registry = new SerializerRegistryImpl();
+        registry.init();
+        echoFactory = registry.getSerializer(
+                new MessageTypeKey<>(EncodeConstants.OF13_VERSION_ID, EchoReplyInput.class));
+    }
+
+    /**
+     * Testing of {@link EchoReplyInputMessageFactory} for correct translation from POJO
+     * @throws Exception
+     */
+    @Test
+    public void testV13() throws Exception {
+        EchoReplyInputBuilder erib = new EchoReplyInputBuilder();
+        BufferHelper.setupHeader(erib, EncodeConstants.OF13_VERSION_ID);
+        EchoReplyInput eri = erib.build();
+        ByteBuf out = UnpooledByteBufAllocator.DEFAULT.buffer();
+        echoFactory.serialize(eri, out);
+        BufferHelper.checkHeaderV13(out, ECHO_REPLY_MESSAGE_CODE_TYPE, 8);
+    }
+
+    /**
+     * Testing of {@link EchoReplyInputMessageFactory} for correct translation from POJO
+     * @throws Exception
+     */
+    @Test
+    public void testV10() throws Exception {
+        EchoReplyInputBuilder erib = new EchoReplyInputBuilder();
+        BufferHelper.setupHeader(erib, EncodeConstants.OF10_VERSION_ID);
+        EchoReplyInput eri = erib.build();
+        ByteBuf out = UnpooledByteBufAllocator.DEFAULT.buffer();
+        echoFactory.serialize(eri, out);
+        BufferHelper.checkHeaderV10(out, ECHO_REPLY_MESSAGE_CODE_TYPE, 8);
+    }
+
+    /**
+     * Testing of {@link EchoReplyInputMessageFactory} for correct message serialization
+     * @throws Exception
+     */
+    @Test
+    public void testDataSerialize()throws Exception {
+        byte[] dataToTest = new byte[]{91,92,93,94,95,96,97,98};
+        EchoReplyInputBuilder erib = new EchoReplyInputBuilder();
+        BufferHelper.setupHeader(erib, EncodeConstants.OF13_VERSION_ID);
+        erib.setData(dataToTest);
+        EchoReplyInput eri = erib.build();
+        ByteBuf out = UnpooledByteBufAllocator.DEFAULT.buffer();
+        echoFactory.serialize(eri, out);
+        BufferHelper.checkHeaderV13(out, ECHO_REPLY_MESSAGE_CODE_TYPE, 8+dataToTest.length);
+        byte[] outData = new byte[dataToTest.length];
+        out.readBytes(outData);
+        Assert.assertArrayEquals("Wrong - different output data.",dataToTest, outData);
+        out.release();
+    }
+}