import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.GroupModInputMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.MeterModInputMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.MultipartRequestInputMessageFactory;
-import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.OF10BarrierInputMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.OF10FeaturesRequestMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.OF10FlowModInputMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.OF10GetQueueConfigInputMessageFactory;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.TableModInput;
/**
+ * Util class for init registration of additional deserializers.
* @author giuseppex.petralia@intel.com
- *
*/
public class AdditionalMessageDeserializerInitializer {
private AdditionalMessageDeserializerInitializer() {
helper.registerDeserializer(14, null, FlowModInput.class, new OF10FlowModInputMessageFactory());
helper.registerDeserializer(15, null, PortModInput.class, new OF10PortModInputMessageFactory());
helper.registerDeserializer(16, null, MultipartRequestInput.class, new OF10StatsRequestInputFactory());
- helper.registerDeserializer(18, null, BarrierInput.class, new OF10BarrierInputMessageFactory());
+ helper.registerDeserializer(18, null, BarrierInput.class, new BarrierInputMessageFactory());
helper.registerDeserializer(20, null, GetQueueConfigInput.class, new OF10GetQueueConfigInputMessageFactory());
// register OF v1.3 message deserializers
helper = new SimpleDeserializerRegistryHelper(EncodeConstants.OF14_VERSION_ID, registry);
helper.registerDeserializer(7, null, GetConfigInput.class, new GetConfigInputMessageFactory());
helper.registerDeserializer(9, null, SetConfigInput.class, new SetConfigInputMessageFactory());
+ helper.registerDeserializer(20, null, BarrierInput.class, new BarrierInputMessageFactory());
// register OF v1.5 message deserializers
helper = new SimpleDeserializerRegistryHelper(EncodeConstants.OF15_VERSION_ID, registry);
helper.registerDeserializer(7, null, GetConfigInput.class, new GetConfigInputMessageFactory());
helper.registerDeserializer(9, null, SetConfigInput.class, new SetConfigInputMessageFactory());
+ helper.registerDeserializer(20, null, BarrierInput.class, new BarrierInputMessageFactory());
}
}
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.GetConfigReplyMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.HelloMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.MultipartReplyMessageFactory;
-import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.OF10BarrierReplyMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.OF10ErrorMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.OF10FeaturesReplyMessageFactory;
import org.opendaylight.openflowjava.protocol.impl.deserialization.factories.OF10FlowRemovedMessageFactory;
helper.registerDeserializer(11, null, FlowRemovedMessage.class, new OF10FlowRemovedMessageFactory());
helper.registerDeserializer(12, null, PortStatusMessage.class, new OF10PortStatusMessageFactory());
helper.registerDeserializer(17, null, MultipartReplyMessage.class, new OF10StatsReplyMessageFactory());
- helper.registerDeserializer(19, null, BarrierOutput.class, new OF10BarrierReplyMessageFactory());
+ helper.registerDeserializer(19, null, BarrierOutput.class, new BarrierReplyMessageFactory());
helper.registerDeserializer(21, null, GetQueueConfigOutput.class, new OF10QueueGetConfigReplyMessageFactory());
// register OF v1.3 message deserializers
helper.registerDeserializer(2, null, EchoRequestMessage.class, new EchoRequestMessageFactory());
helper.registerDeserializer(3, null, EchoOutput.class, new EchoReplyMessageFactory());
helper.registerDeserializer(8, null, GetConfigOutput.class, new GetConfigReplyMessageFactory());
+ helper.registerDeserializer(21, null, BarrierOutput.class, new BarrierReplyMessageFactory());
// register OF v1.5 message deserializers
helper = new SimpleDeserializerRegistryHelper(EncodeConstants.OF15_VERSION_ID, registry);
helper.registerDeserializer(2, null, EchoRequestMessage.class, new EchoRequestMessageFactory());
helper.registerDeserializer(3, null, EchoOutput.class, new EchoReplyMessageFactory());
helper.registerDeserializer(8, null, GetConfigOutput.class, new GetConfigReplyMessageFactory());
+ helper.registerDeserializer(21, null, BarrierOutput.class, new BarrierReplyMessageFactory());
}
}
helper.registerTypeToClass((short) 2, EchoRequestMessage.class);
helper.registerTypeToClass((short) 3, EchoOutput.class);
helper.registerTypeToClass((short) 8, GetConfigOutput.class);
+ helper.registerTypeToClass((short) 21, BarrierOutput.class);
// init OF v1.5 mapping
helper = new TypeToClassInitHelper(EncodeConstants.OF15_VERSION_ID, messageClassMap);
helper.registerTypeToClass((short) 2, EchoRequestMessage.class);
helper.registerTypeToClass((short) 3, EchoOutput.class);
helper.registerTypeToClass((short) 8, GetConfigOutput.class);
+ helper.registerTypeToClass((short) 21, BarrierOutput.class);
}
/**
helper = new TypeToClassInitHelper(EncodeConstants.OF14_VERSION_ID, messageClassMap);
helper.registerTypeToClass((short) 7, GetConfigInput.class);
helper.registerTypeToClass((short) 9, SetConfigInput.class);
+ helper.registerTypeToClass((short) 20, BarrierInput.class);
// init OF v1.5 mapping
helper = new TypeToClassInitHelper(EncodeConstants.OF15_VERSION_ID, messageClassMap);
helper.registerTypeToClass((short) 7, GetConfigInput.class);
helper.registerTypeToClass((short) 9, SetConfigInput.class);
+ helper.registerTypeToClass((short) 20, BarrierInput.class);
}
}
import io.netty.buffer.ByteBuf;
import org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
-import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
+import org.opendaylight.openflowjava.protocol.impl.util.VersionAssignableFactory;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierInput;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierInputBuilder;
/**
+ * Translates BarrierRequest messages.
+ * OF protocol versions: 1.0, 1.3, 1.4, 1.5.
* @author giuseppex.petralia@intel.com
- *
*/
-public class BarrierInputMessageFactory implements OFDeserializer<BarrierInput>{
+public class BarrierInputMessageFactory extends VersionAssignableFactory implements OFDeserializer<BarrierInput>{
@Override
public BarrierInput deserialize(ByteBuf rawMessage) {
BarrierInputBuilder builder = new BarrierInputBuilder();
- builder.setVersion((short) EncodeConstants.OF13_VERSION_ID);
+ builder.setVersion(getVersion());
builder.setXid(rawMessage.readUnsignedInt());
return builder.build();
}
package org.opendaylight.openflowjava.protocol.impl.deserialization.factories;
import io.netty.buffer.ByteBuf;
-
import org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
-import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
+import org.opendaylight.openflowjava.protocol.impl.util.VersionAssignableFactory;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierOutput;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierOutputBuilder;
/**
- * Translates BarrierReply messages (both OpenFlow v1.0 and OpenFlow v1.3)
+ * Translates BarrierReply messages.
+ * OF protocol versions: 1.0, 1.3, 1.4, 1.5.
* @author michal.polkorab
* @author timotej.kubas
*/
-public class BarrierReplyMessageFactory implements OFDeserializer<BarrierOutput> {
+public class BarrierReplyMessageFactory extends VersionAssignableFactory implements OFDeserializer<BarrierOutput> {
@Override
public BarrierOutput deserialize(ByteBuf rawMessage) {
BarrierOutputBuilder builder = new BarrierOutputBuilder();
- builder.setVersion((short) EncodeConstants.OF13_VERSION_ID);
+ builder.setVersion(getVersion());
builder.setXid(rawMessage.readUnsignedInt());
return builder.build();
}
+++ /dev/null
-/*
- * Copyright (c) 2015 NetIDE Consortium 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 org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
-import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierInput;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierInputBuilder;
-
-/**
- * @author giuseppex.petralia@intel.com
- *
- */
-public class OF10BarrierInputMessageFactory implements OFDeserializer<BarrierInput> {
-
- @Override
- public BarrierInput deserialize(ByteBuf rawMessage) {
- BarrierInputBuilder builder = new BarrierInputBuilder();
- builder.setVersion((short) EncodeConstants.OF10_VERSION_ID);
- builder.setXid(rawMessage.readUnsignedInt());
- return builder.build();
- }
-
-}
+++ /dev/null
-/*
- * 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 org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
-import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierOutput;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierOutputBuilder;
-
-/**
- * Translates BarrierReply messages (both OpenFlow v1.0 and OpenFlow v1.3)
- * @author michal.polkorab
- * @author timotej.kubas
- */
-public class OF10BarrierReplyMessageFactory implements OFDeserializer<BarrierOutput> {
-
- @Override
- public BarrierOutput deserialize(ByteBuf rawMessage) {
- BarrierOutputBuilder builder = new BarrierOutputBuilder();
- builder.setVersion((short) EncodeConstants.OF10_VERSION_ID);
- builder.setXid(rawMessage.readUnsignedInt());
- return builder.build();
- }
-}
assertEquals("Wrong class", EchoRequestMessage.class, messageClassMap.get(new TypeToClassKey(version, 2)));
assertEquals("Wrong class", EchoOutput.class, messageClassMap.get(new TypeToClassKey(version, 3)));
assertEquals("Wrong class", GetConfigOutput.class, messageClassMap.get(new TypeToClassKey(version, 8)));
+ assertEquals("Wrong class", BarrierOutput.class, messageClassMap.get(new TypeToClassKey(version, 21)));
version = EncodeConstants.OF15_VERSION_ID;
assertEquals("Wrong class", HelloMessage.class, messageClassMap.get(new TypeToClassKey(version, 0)));
assertEquals("Wrong class", EchoRequestMessage.class, messageClassMap.get(new TypeToClassKey(version, 2)));
assertEquals("Wrong class", EchoOutput.class, messageClassMap.get(new TypeToClassKey(version, 3)));
assertEquals("Wrong class", GetConfigOutput.class, messageClassMap.get(new TypeToClassKey(version, 8)));
+ assertEquals("Wrong class", BarrierOutput.class, messageClassMap.get(new TypeToClassKey(version, 21)));
}
@Test
version = EncodeConstants.OF14_VERSION_ID;
assertEquals("Wrong class", GetConfigInput.class, messageClassMap.get(new TypeToClassKey(version, 7)));
assertEquals("Wrong class", SetConfigInput.class, messageClassMap.get(new TypeToClassKey(version, 9)));
+ assertEquals("Wrong class", BarrierInput.class, messageClassMap.get(new TypeToClassKey(version, 20)));
version = EncodeConstants.OF15_VERSION_ID;
assertEquals("Wrong class", GetConfigInput.class, messageClassMap.get(new TypeToClassKey(version, 7)));
assertEquals("Wrong class", SetConfigInput.class, messageClassMap.get(new TypeToClassKey(version, 9)));
+ assertEquals("Wrong class", BarrierInput.class, messageClassMap.get(new TypeToClassKey(version, 20)));
}
}
\ No newline at end of file
package org.opendaylight.openflowjava.protocol.impl.deserialization.factories;
import io.netty.buffer.ByteBuf;
-import org.junit.Before;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.List;
import org.junit.Test;
-import org.opendaylight.openflowjava.protocol.api.extensibility.DeserializerRegistry;
-import org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
import org.opendaylight.openflowjava.protocol.api.keys.MessageCodeKey;
import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
-import org.opendaylight.openflowjava.protocol.impl.deserialization.DeserializerRegistryImpl;
import org.opendaylight.openflowjava.protocol.impl.util.BufferHelper;
+import org.opendaylight.openflowjava.protocol.impl.util.DefaultDeserializerFactoryTest;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierInput;
/**
+ * Test for {@link org.opendaylight.openflowjava.protocol.impl.deserialization.factories.BarrierInputMessageFactory}.
* @author giuseppex.petralia@intel.com
- *
*/
-public class BarrierInputMessageFactoryTest {
- private OFDeserializer<BarrierInput> factory;
+public class BarrierInputMessageFactoryTest extends DefaultDeserializerFactoryTest<BarrierInput> {
+
- @Before
- public void startUp() {
- DeserializerRegistry desRegistry = new DeserializerRegistryImpl();
- desRegistry.init();
- factory = desRegistry
- .getDeserializer(new MessageCodeKey(EncodeConstants.OF13_VERSION_ID, 20, BarrierInput.class));
+ /**
+ * Initializes deserializer registry and lookups OF13 deserializer.
+ */
+ public BarrierInputMessageFactoryTest() {
+ super(new MessageCodeKey(EncodeConstants.OF13_VERSION_ID, 20, BarrierInput.class));
}
+ /**
+ * Testing of {@link BarrierInputMessageFactory} for correct header version.
+ */
@Test
- public void test() {
+ public void testVersions() {
+ List<Byte> versions = new ArrayList<>(Arrays.asList(
+ EncodeConstants.OF13_VERSION_ID,
+ EncodeConstants.OF14_VERSION_ID,
+ EncodeConstants.OF15_VERSION_ID
+ ));
ByteBuf bb = BufferHelper.buildBuffer();
- BarrierInput deserializedMessage = BufferHelper.deserialize(factory, bb);
- BufferHelper.checkHeaderV13(deserializedMessage);
+ testHeaderVersions(versions, bb);
+
+ // OFP v1.0 need to be tested separately cause of different message type value
+ messageCodeKey = new MessageCodeKey(EncodeConstants.OF10_VERSION_ID, 18, BarrierInput.class);
+ testHeaderVersions(Collections.singletonList(EncodeConstants.OF10_VERSION_ID), bb);
}
}
package org.opendaylight.openflowjava.protocol.impl.deserialization.factories;
import io.netty.buffer.ByteBuf;
-
-import org.junit.Before;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.List;
import org.junit.Test;
-import org.opendaylight.openflowjava.protocol.api.extensibility.DeserializerRegistry;
-import org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
import org.opendaylight.openflowjava.protocol.api.keys.MessageCodeKey;
-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.openflowjava.protocol.impl.util.BufferHelper;
+import org.opendaylight.openflowjava.protocol.impl.util.DefaultDeserializerFactoryTest;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierOutput;
/**
+ * Test for {@link org.opendaylight.openflowjava.protocol.impl.deserialization.factories.BarrierReplyMessageFactory}.
* @author michal.polkorab
* @author timotej.kubas
*/
-public class BarrierReplyMessageFactoryTest {
-
- private OFDeserializer<BarrierOutput> barrierFactory;
+public class BarrierReplyMessageFactoryTest extends DefaultDeserializerFactoryTest<BarrierOutput> {
/**
- * Initializes deserializer registry and lookups correct deserializer
+ * Initializes deserializer registry and lookups OF13 deserializer.
*/
- @Before
- public void startUp() {
- DeserializerRegistry registry = new DeserializerRegistryImpl();
- registry.init();
- barrierFactory = registry.getDeserializer(
- new MessageCodeKey(EncodeConstants.OF13_VERSION_ID, 21, BarrierOutput.class));
+ public BarrierReplyMessageFactoryTest() {
+ super(new MessageCodeKey(EncodeConstants.OF13_VERSION_ID, 21, BarrierOutput.class));
}
/**
- * Testing of {@link BarrierReplyMessageFactory} for correct translation into POJO
+ * Testing of {@link BarrierReplyMessageFactory} for correct header version.
*/
@Test
- public void test() {
+ public void testVersions() {
+ List<Byte> versions = new ArrayList<>(Arrays.asList(
+ EncodeConstants.OF13_VERSION_ID,
+ EncodeConstants.OF14_VERSION_ID,
+ EncodeConstants.OF15_VERSION_ID
+ ));
ByteBuf bb = BufferHelper.buildBuffer();
- BarrierOutput builtByFactory = BufferHelper.deserialize(
- barrierFactory, bb);
+ testHeaderVersions(versions, bb);
- BufferHelper.checkHeaderV13(builtByFactory);
+ // OFP v1.0 need to be tested separately cause of different message type value
+ messageCodeKey = new MessageCodeKey(EncodeConstants.OF10_VERSION_ID, 19, BarrierOutput.class);
+ testHeaderVersions(Collections.singletonList(EncodeConstants.OF10_VERSION_ID), bb);
}
}
+++ /dev/null
-/*
- * Copyright (c) 2015 NetIDE Consortium 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 org.junit.Before;
-import org.junit.Test;
-import org.opendaylight.openflowjava.protocol.api.extensibility.DeserializerRegistry;
-import org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
-import org.opendaylight.openflowjava.protocol.api.keys.MessageCodeKey;
-import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
-import org.opendaylight.openflowjava.protocol.impl.deserialization.DeserializerRegistryImpl;
-import org.opendaylight.openflowjava.protocol.impl.util.BufferHelper;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.BarrierInput;
-
-/**
- * @author giuseppex.petralia@intel.com
- *
- */
-public class OF10BarrierInputMessageFactoryTest {
- private OFDeserializer<BarrierInput> factory;
-
- @Before
- public void startUp() {
- DeserializerRegistry desRegistry = new DeserializerRegistryImpl();
- desRegistry.init();
- factory = desRegistry
- .getDeserializer(new MessageCodeKey(EncodeConstants.OF10_VERSION_ID, 18, BarrierInput.class));
- }
-
- @Test
- public void test() {
- ByteBuf bb = BufferHelper.buildBuffer();
- BarrierInput deserializedMessage = BufferHelper.deserialize(factory, bb);
- BufferHelper.checkHeaderV10(deserializedMessage);
- }
-}
+++ /dev/null
-/*
- * 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 org.junit.Before;
-import org.junit.Test;
-import org.opendaylight.openflowjava.protocol.api.extensibility.DeserializerRegistry;
-import org.opendaylight.openflowjava.protocol.api.extensibility.OFDeserializer;
-import org.opendaylight.openflowjava.protocol.api.keys.MessageCodeKey;
-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.protocol.rev130731.BarrierOutput;
-
-/**
- * @author michal.polkorab
- * @author timotej.kubas
- */
-public class OF10BarrierReplyMessageFactoryTest {
-
- private OFDeserializer<BarrierOutput> barrierFactory;
-
- /**
- * Initializes deserializer registry and lookups correct deserializer
- */
- @Before
- public void startUp() {
- DeserializerRegistry registry = new DeserializerRegistryImpl();
- registry.init();
- barrierFactory = registry.getDeserializer(
- new MessageCodeKey(EncodeConstants.OF10_VERSION_ID, 19, BarrierOutput.class));
- }
-
- /**
- * Testing of {@link OF10BarrierReplyMessageFactory} for correct translation into POJO
- */
- @Test
- public void testV10() {
- ByteBuf bb = BufferHelper.buildBuffer();
- BarrierOutput builtByFactory = BufferHelper.deserialize(
- barrierFactory, bb);
-
- BufferHelper.checkHeaderV10(builtByFactory);
- }
-}
private DeserializerRegistry registry;
protected OFDeserializer<T> factory;
- private MessageCodeKey messageCodeKey;
+ protected MessageCodeKey messageCodeKey;
public DefaultDeserializerFactoryTest(final MessageCodeKey key) {
this.registry = new DeserializerRegistryImpl();