Extensibility support (deserialization part)
[openflowjava.git] / openflow-protocol-impl / src / test / java / org / opendaylight / openflowjava / protocol / impl / deserialization / factories / ErrorMessageFactoryTest.java
index e139a77ad1ef912cceab1cce9d74cea76887eab4..5df6b7719b987544f162d68c94dfe2e91934eca0 100644 (file)
@@ -11,8 +11,14 @@ package org.opendaylight.openflowjava.protocol.impl.deserialization.factories;
 import io.netty.buffer.ByteBuf;
 
 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.impl.util.EncodeConstants;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ErrorMessage;
 
 /**
@@ -21,14 +27,26 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731
  */
 public class ErrorMessageFactoryTest {
 
+    private OFDeserializer<ErrorMessage> errorFactory;
+
+    /**
+     * Initializes deserializer registry and lookups correct deserializer
+     */
+    @Before
+    public void startUp() {
+        DeserializerRegistry registry = new DeserializerRegistryImpl();
+        registry.init();
+        errorFactory = registry.getDeserializer(
+                new MessageCodeKey(EncodeConstants.OF13_VERSION_ID, 1, ErrorMessage.class));
+    }
+
     /**
      * Test of {@link ErrorMessageFactory} for correct translation into POJO
      */
     @Test
     public void testWithoutData() {
         ByteBuf bb = BufferHelper.buildBuffer("00 01 00 02");
-        ErrorMessage builtByFactory = BufferHelper.decodeV13(
-                ErrorMessageFactory.getInstance(), bb);
+        ErrorMessage builtByFactory = BufferHelper.deserialize(errorFactory, bb);
 
         BufferHelper.checkHeaderV13(builtByFactory);
         Assert.assertEquals("Wrong type", 1, builtByFactory.getType().intValue());
@@ -44,8 +62,7 @@ public class ErrorMessageFactoryTest {
     @Test
     public void testWithData() {
         ByteBuf bb = BufferHelper.buildBuffer("00 00 00 01 00 01 02 03");
-        ErrorMessage builtByFactory = BufferHelper.decodeV13(
-                ErrorMessageFactory.getInstance(), bb);
+        ErrorMessage builtByFactory = BufferHelper.deserialize(errorFactory, bb);
 
         BufferHelper.checkHeaderV13(builtByFactory);
         Assert.assertEquals("Wrong type", 0, builtByFactory.getType().intValue());
@@ -61,8 +78,7 @@ public class ErrorMessageFactoryTest {
     @Test
     public void testWithIncorrectTypeEnum() {
         ByteBuf bb = BufferHelper.buildBuffer("00 20 00 05 00 01 02 03");
-        ErrorMessage builtByFactory = BufferHelper.decodeV13(
-                ErrorMessageFactory.getInstance(), bb);
+        ErrorMessage builtByFactory = BufferHelper.deserialize(errorFactory, bb);
 
         BufferHelper.checkHeaderV13(builtByFactory);
         Assert.assertEquals("Wrong type", 32, builtByFactory.getType().intValue());
@@ -78,8 +94,7 @@ public class ErrorMessageFactoryTest {
     @Test
     public void testWithIncorrectCodeEnum() {
         ByteBuf bb = BufferHelper.buildBuffer("00 03 00 10 00 01 02 03");
-        ErrorMessage builtByFactory = BufferHelper.decodeV13(
-                ErrorMessageFactory.getInstance(), bb);
+        ErrorMessage builtByFactory = BufferHelper.deserialize(errorFactory, bb);
 
         BufferHelper.checkHeaderV13(builtByFactory);
         Assert.assertEquals("Wrong type", 3, builtByFactory.getType().intValue());