Bug 752 - removed model ambiguities
[openflowjava.git] / openflow-protocol-impl / src / test / java / org / opendaylight / openflowjava / protocol / impl / util / MatchDeserializerTest.java
index 018feb1d3e0e5aff95b718235a67c4ecc4ffbd6b..4de1c3a88ca3407ccec1d60355a0b1de0ee4152f 100644 (file)
@@ -15,9 +15,79 @@ import org.junit.Assert;
 import org.junit.Test;\r
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv4Address;\r
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv6Address;\r
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev100924.MacAddress;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.BosMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.DscpMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.EcnMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.EthTypeMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.Icmpv4CodeMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.Icmpv4TypeMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.Icmpv6CodeMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.Icmpv6TypeMatchEntry;\r
 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.Ipv4AddressMatchEntry;\r
 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.Ipv6AddressMatchEntry;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.oxm.fields.MatchEntries;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.Ipv6FlabelMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.IsidMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.MacAddressMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.MaskMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.MetadataMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.MplsLabelMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.OpCodeMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.PortMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.PortNumberMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.ProtocolNumberMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.PseudoFieldMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.TcMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.VlanPcpMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.VlanVidMatchEntry;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.Ipv6ExthdrFlags;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.ArpOp;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.ArpSha;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.ArpSpa;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.ArpTha;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.ArpTpa;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.EthDst;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.EthSrc;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.EthType;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.ExperimenterClass;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Icmpv4Code;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Icmpv4Type;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Icmpv6Code;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Icmpv6Type;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.InPhyPort;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.InPort;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.IpDscp;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.IpEcn;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.IpProto;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv4Dst;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv4Src;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv6Dst;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv6Exthdr;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv6Flabel;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv6NdSll;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv6NdTarget;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv6NdTll;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Ipv6Src;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Metadata;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.MplsBos;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.MplsLabel;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.MplsTc;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Nxm0Class;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.Nxm1Class;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.OpenflowBasicClass;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.OxmMatchType;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.PbbIsid;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.SctpDst;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.SctpSrc;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.TcpDst;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.TcpSrc;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.TunnelId;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.UdpDst;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.UdpSrc;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.VlanPcp;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.VlanVid;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.match.grouping.Match;\r
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.oxm.fields.grouping.MatchEntries;\r
 \r
 /**\r
  * @author michal.polkorab\r
@@ -26,7 +96,7 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.oxm.
 public class MatchDeserializerTest {\r
     \r
     /**\r
-     * Testing match deserialization\r
+     * Testing Ipv4 address deserialization\r
      */\r
     @Test\r
     public void testIpv4Address() {\r
@@ -39,7 +109,7 @@ public class MatchDeserializerTest {
     }\r
     \r
     /**\r
-     * Testing match deserialization\r
+     * Testing Ipv6 address deserialization\r
      */\r
     @Test\r
     public void testIpv6Address() {\r
@@ -50,5 +120,339 @@ public class MatchDeserializerTest {
         Assert.assertEquals("Wrong Ipv6 address format", new Ipv6Address("0000:0001:0002:0003:0004:0005:0006:0F07"),\r
                 entry.getAugmentation(Ipv6AddressMatchEntry.class).getIpv6Address());\r
     }\r
+    \r
+    /**\r
+     * Testing match deserialization\r
+     */\r
+    @Test\r
+    public void testMatch() {\r
+        ByteBuf buffer = ByteBufUtils.hexStringToByteBuf("00 01 01 AC "\r
+                + "80 00 00 04 00 00 00 01 "\r
+                + "00 00 02 04 00 00 00 02 "\r
+                + "00 01 05 10 00 00 00 00 00 00 00 03 00 00 00 00 00 00 00 04 "\r
+                + "FF FF 07 0C 00 00 00 00 00 05 00 00 00 00 00 06 "\r
+                + "80 00 09 0C 00 00 00 00 00 07 00 00 00 00 00 08 "\r
+                + "80 00 0A 02 00 09 "\r
+                + "80 00 0D 04 00 0A 00 0B "\r
+                + "80 00 0E 01 0C "\r
+                + "80 00 10 01 0D "\r
+                + "80 00 12 01 0E "\r
+                + "80 00 14 01 0F "\r
+                + "80 00 17 08 0A 00 00 01 00 00 FF 00 "\r
+                + "80 00 19 08 0A 00 00 02 00 00 00 FF "\r
+                + "80 00 1A 02 00 03 "\r
+                + "80 00 1C 02 00 04 "\r
+                + "80 00 1E 02 00 05 "\r
+                + "80 00 20 02 00 06 "\r
+                + "80 00 22 02 00 07 "\r
+                + "80 00 24 02 00 08 "\r
+                + "80 00 26 01 05 "\r
+                + "80 00 28 01 07 "\r
+                + "80 00 2A 02 00 10 "\r
+                + "80 00 2D 08 0A 00 00 09 00 00 FF 00 "\r
+                + "80 00 2F 08 0A 00 00 0A 00 00 00 FF "\r
+                + "80 00 31 0C 00 00 00 00 00 01 00 00 00 00 00 03 "\r
+                + "80 00 33 0C 00 00 00 00 00 02 00 00 00 00 00 04 "\r
+                + "80 00 35 20 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 15 "\r
+                +             "00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 16 "\r
+                + "80 00 37 20 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 17 "\r
+                +             "00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 18 "\r
+                + "80 00 39 08 00 00 00 02 00 00 00 03 "\r
+                + "80 00 3A 01 15 "\r
+                + "80 00 3C 01 17 "\r
+                + "80 00 3E 10 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 20 " //ipv6ndtarget\r
+                + "80 00 40 06 00 05 00 00 00 01 "\r
+                + "80 00 42 06 00 05 00 00 00 02 "\r
+                + "80 00 44 04 00 00 02 03 "\r
+                + "80 00 46 01 03 "\r
+                + "80 00 48 01 01 "\r
+                + "80 00 4B 06 00 00 02 00 00 01 "\r
+                + "80 00 4D 10 00 00 00 00 00 00 00 07 00 00 00 00 00 00 00 FF "\r
+                + "80 00 4F 04 01 66 03 04 "\r
+                + "00 00 00 00");\r
+\r
+        Match match = MatchDeserializer.createMatch(buffer);\r
+        Assert.assertEquals("Wrong match type", OxmMatchType.class, match.getType());\r
+        Assert.assertEquals("Wrong match entries size", 40, match.getMatchEntries().size());\r
+        List<MatchEntries> entries = match.getMatchEntries();\r
+        MatchEntries entry0 = entries.get(0);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry0.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", InPort.class, entry0.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry0.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 1,\r
+                entry0.getAugmentation(PortNumberMatchEntry.class).getPortNumber().getValue().intValue());\r
+        MatchEntries entry1 = entries.get(1);\r
+        Assert.assertEquals("Wrong entry class", Nxm0Class.class, entry1.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", InPhyPort.class, entry1.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry1.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 2,\r
+                entry1.getAugmentation(PortNumberMatchEntry.class).getPortNumber().getValue().intValue());\r
+        MatchEntries entry2 = entries.get(2);\r
+        Assert.assertEquals("Wrong entry class", Nxm1Class.class, entry2.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Metadata.class, entry2.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry2.isHasMask());\r
+        Assert.assertArrayEquals("Wrong entry value", ByteBufUtils.hexStringToBytes("00 00 00 00 00 00 00 03"), \r
+                entry2.getAugmentation(MetadataMatchEntry.class).getMetadata());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 00 00 00 00 04"), \r
+                entry2.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry3 = entries.get(3);\r
+        Assert.assertEquals("Wrong entry class", ExperimenterClass.class, entry3.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", EthDst.class, entry3.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry3.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new MacAddress("00:00:00:00:00:05"), \r
+                entry3.getAugmentation(MacAddressMatchEntry.class).getMacAddress());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 00 00 06"), \r
+                entry3.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry4 = entries.get(4);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry4.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", EthSrc.class, entry4.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry4.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new MacAddress("00:00:00:00:00:07"), \r
+                entry4.getAugmentation(MacAddressMatchEntry.class).getMacAddress());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 00 00 08"), \r
+                entry4.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry5 = entries.get(5);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry5.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", EthType.class, entry5.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry5.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 9,\r
+                entry5.getAugmentation(EthTypeMatchEntry.class).getEthType().getValue().intValue());\r
+        MatchEntries entry6 = entries.get(6);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry6.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", VlanVid.class, entry6.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry6.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 10,\r
+                entry6.getAugmentation(VlanVidMatchEntry.class).getVlanVid().intValue());\r
+        Assert.assertEquals("Wrong entry value", false, \r
+                entry6.getAugmentation(VlanVidMatchEntry.class).isCfiBit());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 0B"), \r
+                entry6.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry7 = entries.get(7);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry7.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", VlanPcp.class, entry7.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry7.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 12,\r
+                entry7.getAugmentation(VlanPcpMatchEntry.class).getVlanPcp().intValue());\r
+        MatchEntries entry8 = entries.get(8);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry8.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", IpDscp.class, entry8.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry8.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 13,\r
+                entry8.getAugmentation(DscpMatchEntry.class).getDscp().getValue().intValue());\r
+        MatchEntries entry9 = entries.get(9);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry9.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", IpEcn.class, entry9.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry9.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 14,\r
+                entry9.getAugmentation(EcnMatchEntry.class).getEcn().intValue());\r
+        MatchEntries entry10 = entries.get(10);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry10.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", IpProto.class, entry10.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry10.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 15,\r
+                entry10.getAugmentation(ProtocolNumberMatchEntry.class).getProtocolNumber().intValue());\r
+        MatchEntries entry11 = entries.get(11);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry11.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv4Src.class, entry11.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry11.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new Ipv4Address("10.0.0.1"),\r
+                entry11.getAugmentation(Ipv4AddressMatchEntry.class).getIpv4Address());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 FF 00"), \r
+                entry11.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry12 = entries.get(12);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry12.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv4Dst.class, entry12.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry12.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new Ipv4Address("10.0.0.2"),\r
+                entry12.getAugmentation(Ipv4AddressMatchEntry.class).getIpv4Address());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 FF"), \r
+                entry12.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry13 = entries.get(13);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry13.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", TcpSrc.class, entry13.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry13.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 3,\r
+                entry13.getAugmentation(PortMatchEntry.class).getPort().getValue().intValue());\r
+        MatchEntries entry14 = entries.get(14);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry14.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", TcpDst.class, entry14.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry14.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 4,\r
+                entry14.getAugmentation(PortMatchEntry.class).getPort().getValue().intValue());\r
+        MatchEntries entry15 = entries.get(15);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry15.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", UdpSrc.class, entry15.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry15.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 5,\r
+                entry15.getAugmentation(PortMatchEntry.class).getPort().getValue().intValue());\r
+        MatchEntries entry16 = entries.get(16);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry16.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", UdpDst.class, entry16.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry16.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 6,\r
+                entry16.getAugmentation(PortMatchEntry.class).getPort().getValue().intValue());\r
+        MatchEntries entry17 = entries.get(17);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry17.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", SctpSrc.class, entry17.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry17.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 7,\r
+                entry17.getAugmentation(PortMatchEntry.class).getPort().getValue().intValue());\r
+        MatchEntries entry18 = entries.get(18);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry18.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", SctpDst.class, entry18.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry18.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 8,\r
+                entry18.getAugmentation(PortMatchEntry.class).getPort().getValue().intValue());\r
+        MatchEntries entry19 = entries.get(19);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry19.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Icmpv4Type.class, entry19.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry19.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 5,\r
+                entry19.getAugmentation(Icmpv4TypeMatchEntry.class).getIcmpv4Type().intValue());\r
+        MatchEntries entry20 = entries.get(20);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry20.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Icmpv4Code.class, entry20.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry20.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 7,\r
+                entry20.getAugmentation(Icmpv4CodeMatchEntry.class).getIcmpv4Code().intValue());\r
+        MatchEntries entry21 = entries.get(21);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry21.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", ArpOp.class, entry21.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry21.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 16,\r
+                entry21.getAugmentation(OpCodeMatchEntry.class).getOpCode().intValue());\r
+        MatchEntries entry22 = entries.get(22);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry22.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", ArpSpa.class, entry22.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry22.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new Ipv4Address("10.0.0.9"),\r
+                entry22.getAugmentation(Ipv4AddressMatchEntry.class).getIpv4Address());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 FF 00"), \r
+                entry22.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry23 = entries.get(23);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry23.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", ArpTpa.class, entry23.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry23.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new Ipv4Address("10.0.0.10"),\r
+                entry23.getAugmentation(Ipv4AddressMatchEntry.class).getIpv4Address());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 FF"), \r
+                entry23.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry24 = entries.get(24);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry24.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", ArpSha.class, entry24.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry24.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new MacAddress("00:00:00:00:00:01"), \r
+                entry24.getAugmentation(MacAddressMatchEntry.class).getMacAddress());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 00 00 03"), \r
+                entry24.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry25 = entries.get(25);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry25.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", ArpTha.class, entry25.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry25.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new MacAddress("00:00:00:00:00:02"), \r
+                entry25.getAugmentation(MacAddressMatchEntry.class).getMacAddress());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 00 00 04"), \r
+                entry25.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry26 = entries.get(26);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry26.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv6Src.class, entry26.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry26.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new Ipv6Address("0000:0000:0000:0000:0000:0000:0000:0015"), \r
+                entry26.getAugmentation(Ipv6AddressMatchEntry.class).getIpv6Address());\r
+        Assert.assertArrayEquals("Wrong entry mask",\r
+                ByteBufUtils.hexStringToBytes("00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 16"), \r
+                entry26.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry27 = entries.get(27);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry27.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv6Dst.class, entry27.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry27.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new Ipv6Address("0000:0000:0000:0000:0000:0000:0000:0017"), \r
+                entry27.getAugmentation(Ipv6AddressMatchEntry.class).getIpv6Address());\r
+        Assert.assertArrayEquals("Wrong entry mask",\r
+                ByteBufUtils.hexStringToBytes("00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 18"), \r
+                entry27.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry28 = entries.get(28);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry28.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv6Flabel.class, entry28.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry28.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 2, \r
+                entry28.getAugmentation(Ipv6FlabelMatchEntry.class).getIpv6Flabel().getValue().intValue());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 03"),\r
+                entry28.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry29 = entries.get(29);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry29.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Icmpv6Type.class, entry29.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry29.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 21, \r
+                entry29.getAugmentation(Icmpv6TypeMatchEntry.class).getIcmpv6Type().intValue());\r
+        MatchEntries entry30 = entries.get(30);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry30.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Icmpv6Code.class, entry30.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry30.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 23, \r
+                entry30.getAugmentation(Icmpv6CodeMatchEntry.class).getIcmpv6Code().intValue());\r
+        MatchEntries entry31 = entries.get(31);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry31.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv6NdTarget.class, entry31.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry31.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new Ipv6Address("0000:0000:0000:0000:0000:0000:0000:0020"), \r
+                entry31.getAugmentation(Ipv6AddressMatchEntry.class).getIpv6Address());\r
+        MatchEntries entry32 = entries.get(32);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry32.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv6NdSll.class, entry32.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry32.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new MacAddress("00:05:00:00:00:01"), \r
+                entry32.getAugmentation(MacAddressMatchEntry.class).getMacAddress());\r
+        MatchEntries entry33 = entries.get(33);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry33.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv6NdTll.class, entry33.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry33.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", new MacAddress("00:05:00:00:00:02"),\r
+                entry33.getAugmentation(MacAddressMatchEntry.class).getMacAddress());\r
+        MatchEntries entry34 = entries.get(34);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry34.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", MplsLabel.class, entry34.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry34.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 515,\r
+                entry34.getAugmentation(MplsLabelMatchEntry.class).getMplsLabel().intValue());\r
+        MatchEntries entry35 = entries.get(35);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry35.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", MplsTc.class, entry35.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry35.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 3,\r
+                entry35.getAugmentation(TcMatchEntry.class).getTc().intValue());\r
+        MatchEntries entry36 = entries.get(36);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry36.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", MplsBos.class, entry36.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", false, entry36.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", true,\r
+                entry36.getAugmentation(BosMatchEntry.class).isBos());\r
+        MatchEntries entry37 = entries.get(37);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry37.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", PbbIsid.class, entry37.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry37.isHasMask());\r
+        Assert.assertEquals("Wrong entry value", 2,\r
+                entry37.getAugmentation(IsidMatchEntry.class).getIsid().intValue());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 01"),\r
+                entry37.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry38 = entries.get(38);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry38.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", TunnelId.class, entry38.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry38.isHasMask());\r
+        Assert.assertArrayEquals("Wrong entry value", ByteBufUtils.hexStringToBytes("00 00 00 00 00 00 00 07"),\r
+                entry38.getAugmentation(MetadataMatchEntry.class).getMetadata());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("00 00 00 00 00 00 00 FF"),\r
+                entry38.getAugmentation(MaskMatchEntry.class).getMask());\r
+        MatchEntries entry39 = entries.get(39);\r
+        Assert.assertEquals("Wrong entry class", OpenflowBasicClass.class, entry39.getOxmClass());\r
+        Assert.assertEquals("Wrong entry field", Ipv6Exthdr.class, entry39.getOxmMatchField());\r
+        Assert.assertEquals("Wrong entry hasMask", true, entry39.isHasMask());\r
+        Assert.assertEquals("Wrong entry value",\r
+                new Ipv6ExthdrFlags(true, false, true, false, true, false, true, false, true),\r
+                entry39.getAugmentation(PseudoFieldMatchEntry.class).getPseudoField());\r
+        Assert.assertArrayEquals("Wrong entry mask", ByteBufUtils.hexStringToBytes("03 04"),\r
+                entry39.getAugmentation(MaskMatchEntry.class).getMask());\r
+        Assert.assertTrue("Unread data", buffer.readableBytes() == 0);\r
+    }\r
 \r
 }\r