BUG-2982 : moved path-attributes container to grouping
[bgpcep.git] / bgp / parser-impl / src / test / java / org / opendaylight / protocol / bgp / parser / impl / BGPParserTest.java
index 0c5ceae8fa669b9ae5a36f46c23eb4a81243cf34..c29c707350b5487d8c0b9dcfd2c58312d538feb2 100644 (file)
@@ -13,22 +13,18 @@ import static org.junit.Assert.assertNotNull;
 import static org.junit.Assert.assertNull;
 
 import com.google.common.collect.Lists;
-import com.google.common.collect.Sets;
 import io.netty.buffer.ByteBuf;
 import io.netty.buffer.Unpooled;
 import java.io.ByteArrayOutputStream;
 import java.io.IOException;
 import java.io.InputStream;
-import java.math.BigInteger;
 import java.util.ArrayList;
+import java.util.Collections;
 import java.util.List;
-import java.util.Set;
 import org.junit.BeforeClass;
 import org.junit.Test;
-import org.opendaylight.protocol.bgp.parser.BgpTableTypeImpl;
 import org.opendaylight.protocol.bgp.parser.impl.message.BGPUpdateMessageParser;
 import org.opendaylight.protocol.bgp.parser.impl.message.update.CommunityUtil;
-import org.opendaylight.protocol.bgp.parser.spi.MessageRegistry;
 import org.opendaylight.protocol.bgp.parser.spi.MessageUtil;
 import org.opendaylight.protocol.bgp.parser.spi.pojo.ServiceLoaderBGPExtensionProviderContext;
 import org.opendaylight.protocol.util.ByteArray;
@@ -38,68 +34,40 @@ import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv4Prefix;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv6Address;
 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv6Prefix;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.AreaIdentifier;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.DomainIdentifier;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.Identifier;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.Ipv4InterfaceIdentifier;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.LinkstateAddressFamily;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.LinkstateSubsequentAddressFamily;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.NlriType;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.OspfInterfaceIdentifier;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.ProtocolId;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.linkstate.destination.CLinkstateDestination;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.linkstate.destination.CLinkstateDestinationBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.linkstate.destination.c.linkstate.destination.LinkDescriptorsBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.linkstate.destination.c.linkstate.destination.LocalNodeDescriptorsBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.linkstate.destination.c.linkstate.destination.RemoteNodeDescriptorsBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.node.identifier.c.router.identifier.OspfNodeCaseBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.node.identifier.c.router.identifier.OspfPseudonodeCaseBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.node.identifier.c.router.identifier.ospf.node._case.OspfNodeBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.node.identifier.c.router.identifier.ospf.pseudonode._case.OspfPseudonodeBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.update.path.attributes.LinkstatePathAttributeBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.update.path.attributes.linkstate.path.attribute.link.state.attribute.LinkAttributesCaseBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.update.path.attributes.linkstate.path.attribute.link.state.attribute.link.attributes._case.LinkAttributesBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.update.path.attributes.mp.reach.nlri.advertized.routes.destination.type.DestinationLinkstateCase;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.update.path.attributes.mp.reach.nlri.advertized.routes.destination.type.DestinationLinkstateCaseBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.update.path.attributes.mp.reach.nlri.advertized.routes.destination.type.destination.linkstate._case.DestinationLinkstateBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.Open;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv6.prefixes.DestinationIpv6Builder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv6.prefixes.destination.ipv6.Ipv6Prefixes;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv6.prefixes.destination.ipv6.Ipv6PrefixesBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.update.attributes.mp.reach.nlri.advertized.routes.destination.type.DestinationIpv6CaseBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.Update;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.UpdateBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.open.BgpParameters;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.open.bgp.parameters.CParameters;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.Aggregator;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.AggregatorBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.AsPathBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.AtomicAggregateBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.ClusterIdBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.Communities;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.ExtendedCommunities;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.ExtendedCommunitiesBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.LocalPrefBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.MultiExitDiscBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.OriginBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.OriginatorIdBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.as.path.Segments;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.as.path.SegmentsBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.Attributes;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.AttributesBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.Aggregator;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.AggregatorBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.AsPathBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.AtomicAggregateBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.ClusterIdBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.Communities;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.ExtendedCommunities;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.ExtendedCommunitiesBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.LocalPrefBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.MultiExitDiscBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.OriginBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.OriginatorIdBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.UnrecognizedAttributes;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.as.path.Segments;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.path.attributes.attributes.as.path.SegmentsBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.update.Nlri;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.update.NlriBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.update.PathAttributes;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.update.PathAttributesBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev130919.update.WithdrawnRoutesBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.BgpTableType;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.PathAttributes1;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.PathAttributes1Builder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.PathAttributes2;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.destination.destination.type.DestinationIpv6CaseBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.destination.destination.type.destination.ipv6._case.DestinationIpv6Builder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.open.bgp.parameters.c.parameters.MultiprotocolCase;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.update.path.attributes.MpReachNlri;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.update.path.attributes.MpReachNlriBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.update.path.attributes.mp.reach.nlri.AdvertizedRoutesBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.Attributes1;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.Attributes1Builder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.Attributes2;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.update.attributes.MpReachNlriBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.update.attributes.mp.reach.nlri.AdvertizedRoutesBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.AddressFamily;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.BgpOrigin;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.ClusterIdentifier;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.Ipv4AddressFamily;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.Ipv6AddressFamily;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.SubsequentAddressFamily;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.UnicastSubsequentAddressFamily;
@@ -117,8 +85,6 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.type
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.next.hop.c.next.hop.Ipv6NextHopCaseBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.next.hop.c.next.hop.ipv4.next.hop._case.Ipv4NextHopBuilder;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.next.hop.c.next.hop.ipv6.next.hop._case.Ipv6NextHopBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.network.concepts.rev131125.Metric;
-import org.opendaylight.yangtools.yang.binding.Notification;
 
 public class BGPParserTest {
 
@@ -127,7 +93,7 @@ public class BGPParserTest {
      */
     static final List<byte[]> inputBytes = new ArrayList<byte[]>();
 
-    private static int COUNTER = 17;
+    private static int COUNTER = 7;
 
     private static int MAX_SIZE = 300;
 
@@ -138,26 +104,27 @@ public class BGPParserTest {
     @BeforeClass
     public static void setUp() throws Exception {
         updateParser = new BGPUpdateMessageParser(ServiceLoaderBGPExtensionProviderContext.getSingletonInstance().getAttributeRegistry());
-
         for (int i = 1; i <= COUNTER; i++) {
             final String name = "/up" + i + ".bin";
-            final InputStream is = BGPParserTest.class.getResourceAsStream(name);
-            if (is == null) {
-                throw new IOException("Failed to get resource " + name);
-            }
-
-            final ByteArrayOutputStream bis = new ByteArrayOutputStream();
-            final byte[] data = new byte[MAX_SIZE];
-            int nRead = 0;
-            while ((nRead = is.read(data, 0, data.length)) != -1) {
-                bis.write(data, 0, nRead);
+            try (final InputStream is = BGPParserTest.class.getResourceAsStream(name)){
+                if (is == null) {
+                    throw new IOException("Failed to get resource " + name);
+                }
+                final ByteArrayOutputStream bis = new ByteArrayOutputStream();
+                final byte[] data = new byte[MAX_SIZE];
+                int nRead = 0;
+                while ((nRead = is.read(data, 0, data.length)) != -1) {
+                    bis.write(data, 0, nRead);
+                }
+                bis.flush();
+
+                inputBytes.add(bis.toByteArray());
+                is.close();
             }
-            bis.flush();
-
-            inputBytes.add(bis.toByteArray());
         }
     }
 
+
     @Test
     public void testResource() {
         assertNotNull(inputBytes);
@@ -221,10 +188,10 @@ public class BGPParserTest {
         final List<AsSequence> asnums = Lists.newArrayList(new AsSequenceBuilder().setAs(new AsNumber(65002L)).build());
         final List<Segments> asPath = Lists.newArrayList();
         asPath.add(new SegmentsBuilder().setCSegment(
-                new AListCaseBuilder().setAList(new AListBuilder().setAsSequence(asnums).build()).build()).build());
+            new AListCaseBuilder().setAList(new AListBuilder().setAsSequence(asnums).build()).build()).build());
 
         final Ipv4NextHopCase nextHop = new Ipv4NextHopCaseBuilder().setIpv4NextHop(
-                new Ipv4NextHopBuilder().setGlobal(new Ipv4Address("10.0.0.2")).build()).build();
+            new Ipv4NextHopBuilder().setGlobal(new Ipv4Address("10.0.0.2")).build()).build();
 
         final List<Communities> comms = Lists.newArrayList();
         comms.add((Communities) CommunityUtil.NO_EXPORT);
@@ -249,9 +216,9 @@ public class BGPParserTest {
 
         // check path attributes
 
-        final PathAttributes attrs = message.getPathAttributes();
+        final Attributes attrs = message.getAttributes();
 
-        final PathAttributesBuilder paBuilder = new PathAttributesBuilder();
+        final AttributesBuilder paBuilder = new AttributesBuilder();
 
         paBuilder.setOrigin(new OriginBuilder().setValue(BgpOrigin.Igp).build());
         assertEquals(paBuilder.getOrigin(), attrs.getOrigin());
@@ -271,7 +238,9 @@ public class BGPParserTest {
         paBuilder.setCommunities(comms);
         assertEquals(paBuilder.getCommunities(), attrs.getCommunities());
 
-        builder.setPathAttributes(paBuilder.build());
+        paBuilder.setUnrecognizedAttributes(Collections.<UnrecognizedAttributes> emptyList());
+
+        builder.setAttributes(paBuilder.build());
 
         assertEquals(builder.build(), message);
 
@@ -344,10 +313,10 @@ public class BGPParserTest {
 
         // check NLRI
 
-        final List<Ipv6Prefix> prefs = Lists.newArrayList();
-        prefs.add(new Ipv6Prefix("2001:db8:1:2::/64"));
-        prefs.add(new Ipv6Prefix("2001:db8:1:1::/64"));
-        prefs.add(new Ipv6Prefix("2001:db8:1::/64"));
+        final List<Ipv6Prefixes> prefs = new ArrayList<>();
+        prefs.add(new Ipv6PrefixesBuilder().setPrefix(new Ipv6Prefix("2001:db8:1:2::/64")).build());
+        prefs.add(new Ipv6PrefixesBuilder().setPrefix(new Ipv6Prefix("2001:db8:1:1::/64")).build());
+        prefs.add(new Ipv6PrefixesBuilder().setPrefix(new Ipv6Prefix("2001:db8:1::/64")).build());
 
         assertNull(message.getNlri());
 
@@ -356,19 +325,19 @@ public class BGPParserTest {
         final List<AsSequence> asnums = Lists.newArrayList(new AsSequenceBuilder().setAs(new AsNumber(65001L)).build());
         final List<Segments> asPath = Lists.newArrayList();
         asPath.add(new SegmentsBuilder().setCSegment(
-                new AListCaseBuilder().setAList(new AListBuilder().setAsSequence(asnums).build()).build()).build());
+            new AListCaseBuilder().setAList(new AListBuilder().setAsSequence(asnums).build()).build()).build());
 
         final Ipv6NextHopCase nextHop = new Ipv6NextHopCaseBuilder().setIpv6NextHop(
-                new Ipv6NextHopBuilder().setGlobal(new Ipv6Address("2001:db8::1")).setLinkLocal(new Ipv6Address("fe80::c001:bff:fe7e:0")).build()).build();
+            new Ipv6NextHopBuilder().setGlobal(new Ipv6Address("2001:db8::1")).setLinkLocal(new Ipv6Address("fe80::c001:bff:fe7e:0")).build()).build();
 
         final List<ClusterIdentifier> clusters = Lists.newArrayList(new ClusterIdentifier(new Ipv4Address("1.2.3.4")),
-                new ClusterIdentifier(new Ipv4Address("5.6.7.8")));
+            new ClusterIdentifier(new Ipv4Address("5.6.7.8")));
 
         // check path attributes
 
-        final PathAttributes attrs = message.getPathAttributes();
+        final Attributes attrs = message.getAttributes();
 
-        final PathAttributesBuilder paBuilder = new PathAttributesBuilder();
+        final AttributesBuilder paBuilder = new AttributesBuilder();
 
         paBuilder.setOrigin(new OriginBuilder().setValue(BgpOrigin.Igp).build());
         assertEquals(paBuilder.getOrigin(), attrs.getOrigin());
@@ -390,15 +359,15 @@ public class BGPParserTest {
         mpBuilder.setSafi(UnicastSubsequentAddressFamily.class);
         mpBuilder.setCNextHop(nextHop);
         mpBuilder.setAdvertizedRoutes(new AdvertizedRoutesBuilder().setDestinationType(
-                new DestinationIpv6CaseBuilder().setDestinationIpv6(new DestinationIpv6Builder().setIpv6Prefixes(prefs).build()).build()).build());
-
-        paBuilder.addAugmentation(PathAttributes1.class, new PathAttributes1Builder().setMpReachNlri(mpBuilder.build()).build());
-        assertEquals(paBuilder.getAugmentation(PathAttributes1.class).getMpReachNlri(),
-                attrs.getAugmentation(PathAttributes1.class).getMpReachNlri());
+            new DestinationIpv6CaseBuilder().setDestinationIpv6(new DestinationIpv6Builder().setIpv6Prefixes(prefs).build()).build()).build());
 
+        paBuilder.addAugmentation(Attributes1.class, new Attributes1Builder().setMpReachNlri(mpBuilder.build()).build());
+        assertEquals(paBuilder.getAugmentation(Attributes1.class).getMpReachNlri(),
+            attrs.getAugmentation(Attributes1.class).getMpReachNlri());
+        paBuilder.setUnrecognizedAttributes(Collections.<UnrecognizedAttributes> emptyList());
         // check API message
 
-        builder.setPathAttributes(paBuilder.build());
+        builder.setAttributes(paBuilder.build());
         assertEquals(builder.build(), message);
 
         final ByteBuf buffer = Unpooled.buffer();
@@ -467,19 +436,19 @@ public class BGPParserTest {
         final List<AsSequence> asnums = Lists.newArrayList(new AsSequenceBuilder().setAs(new AsNumber(30L)).build());
         final List<Segments> asPath = Lists.newArrayList();
         asPath.add(new SegmentsBuilder().setCSegment(
-                new AListCaseBuilder().setAList(new AListBuilder().setAsSequence(asnums).build()).build()).build());
+            new AListCaseBuilder().setAList(new AListBuilder().setAsSequence(asnums).build()).build()).build());
         asPath.add(new SegmentsBuilder().setCSegment(
-                new ASetCaseBuilder().setASet(new ASetBuilder().setAsSet(Lists.newArrayList(new AsNumber(10L), new AsNumber(20L))).build()).build()).build());
+            new ASetCaseBuilder().setASet(new ASetBuilder().setAsSet(Lists.newArrayList(new AsNumber(10L), new AsNumber(20L))).build()).build()).build());
 
         final Aggregator aggregator = new AggregatorBuilder().setAsNumber(new AsNumber((long) 30)).setNetworkAddress(
-                new Ipv4Address("10.0.0.9")).build();
+            new Ipv4Address("10.0.0.9")).build();
         final Ipv4NextHopCase nextHop = new Ipv4NextHopCaseBuilder().setIpv4NextHop(
-                new Ipv4NextHopBuilder().setGlobal(new Ipv4Address("10.0.0.9")).build()).build();
+            new Ipv4NextHopBuilder().setGlobal(new Ipv4Address("10.0.0.9")).build()).build();
 
         // check path attributes
-        final PathAttributes attrs = message.getPathAttributes();
+        final Attributes attrs = message.getAttributes();
 
-        final PathAttributesBuilder paBuilder = new PathAttributesBuilder();
+        final AttributesBuilder paBuilder = new AttributesBuilder();
 
         paBuilder.setOrigin(new OriginBuilder().setValue(BgpOrigin.Incomplete).build());
         assertEquals(paBuilder.getOrigin(), attrs.getOrigin());
@@ -495,8 +464,8 @@ public class BGPParserTest {
 
         paBuilder.setAggregator(aggregator);
         assertEquals(paBuilder.getAggregator(), attrs.getAggregator());
-
-        builder.setPathAttributes(paBuilder.build());
+        paBuilder.setUnrecognizedAttributes(Collections.<UnrecognizedAttributes> emptyList());
+        builder.setAttributes(paBuilder.build());
 
         assertEquals(builder.build(), message);
 
@@ -566,25 +535,23 @@ public class BGPParserTest {
 
         // attributes
         final Ipv4NextHopCase nextHop = new Ipv4NextHopCaseBuilder().setIpv4NextHop(
-                new Ipv4NextHopBuilder().setGlobal(new Ipv4Address("3.3.3.3")).build()).build();
+            new Ipv4NextHopBuilder().setGlobal(new Ipv4Address("3.3.3.3")).build()).build();
 
         final List<ExtendedCommunities> comms = Lists.newArrayList();
-        comms.add(new ExtendedCommunitiesBuilder().setCommType((short) 1).setExtendedCommunity(
-                new Inet4SpecificExtendedCommunityCaseBuilder().setInet4SpecificExtendedCommunity(
-                        new Inet4SpecificExtendedCommunityBuilder().setTransitive(false).setGlobalAdministrator(
-                                new Ipv4Address("192.168.1.0")).setLocalAdministrator(new byte[] { 0x12, 0x34 }).build()).build()).build());
-
-        final List<Segments> asPath = Lists.newArrayList();
+        comms.add(new ExtendedCommunitiesBuilder().setCommType((short) 1).setCommSubType((short) 4).setExtendedCommunity(
+            new Inet4SpecificExtendedCommunityCaseBuilder().setInet4SpecificExtendedCommunity(
+                new Inet4SpecificExtendedCommunityBuilder().setTransitive(false).setGlobalAdministrator(
+                    new Ipv4Address("192.168.1.0")).setLocalAdministrator(new byte[] { 0x12, 0x34 }).build()).build()).build());
 
         // check path attributes
-        final PathAttributes attrs = message.getPathAttributes();
+        final Attributes attrs = message.getAttributes();
 
-        final PathAttributesBuilder paBuilder = new PathAttributesBuilder();
+        final AttributesBuilder paBuilder = new AttributesBuilder();
 
         paBuilder.setOrigin(new OriginBuilder().setValue(BgpOrigin.Egp).build());
         assertEquals(paBuilder.getOrigin(), attrs.getOrigin());
 
-        paBuilder.setAsPath(new AsPathBuilder().setSegments(asPath).build());
+        paBuilder.setAsPath(new AsPathBuilder().setSegments(Collections.<Segments> emptyList()).build());
         assertEquals(paBuilder.getAsPath(), attrs.getAsPath());
 
         paBuilder.setCNextHop(nextHop);
@@ -599,8 +566,9 @@ public class BGPParserTest {
         paBuilder.setExtendedCommunities(comms);
         assertEquals(paBuilder.getExtendedCommunities(), attrs.getExtendedCommunities());
 
+        paBuilder.setUnrecognizedAttributes(Collections.<UnrecognizedAttributes> emptyList());
         // check API message
-        builder.setPathAttributes(paBuilder.build());
+        builder.setAttributes(paBuilder.build());
         assertEquals(builder.build(), message);
 
         final ByteBuf buffer = Unpooled.buffer();
@@ -629,7 +597,7 @@ public class BGPParserTest {
 
         // check API message
         final Update expectedMessage = new UpdateBuilder().setWithdrawnRoutes(
-                new WithdrawnRoutesBuilder().setWithdrawnRoutes(prefs).build()).build();
+            new WithdrawnRoutesBuilder().setWithdrawnRoutes(prefs).build()).build();
 
         assertEquals(expectedMessage.getWithdrawnRoutes(), message.getWithdrawnRoutes());
 
@@ -680,8 +648,8 @@ public class BGPParserTest {
         final int messageLength = ByteArray.bytesToInt(ByteArray.subByte(inputBytes.get(6), MessageUtil.MARKER_LENGTH, LENGTH_FIELD_LENGTH));
         final Update message = BGPParserTest.updateParser.parseMessageBody(Unpooled.copiedBuffer(body), messageLength);
 
-        final Class<? extends AddressFamily> afi = message.getPathAttributes().getAugmentation(PathAttributes2.class).getMpUnreachNlri().getAfi();
-        final Class<? extends SubsequentAddressFamily> safi = message.getPathAttributes().getAugmentation(PathAttributes2.class).getMpUnreachNlri().getSafi();
+        final Class<? extends AddressFamily> afi = message.getAttributes().getAugmentation(Attributes2.class).getMpUnreachNlri().getAfi();
+        final Class<? extends SubsequentAddressFamily> safi = message.getAttributes().getAugmentation(Attributes2.class).getMpUnreachNlri().getSafi();
 
         assertEquals(Ipv6AddressFamily.class, afi);
         assertEquals(UnicastSubsequentAddressFamily.class, safi);
@@ -692,528 +660,33 @@ public class BGPParserTest {
     }
 
     /*
-     * End of Rib for LS consists of empty MP_UNREACH_NLRI, with AFI 16388 and SAFI 71
+     * End of Rib for Ipv6 consists of empty MP_UNREACH_NLRI, with AFI 2 and SAFI 1
      *
      * ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff <- marker
-     * 00 1d <- length (29) - including header
+     * 00 1e <- length (29) - including header
      * 02 <- message type
      * 00 00 <- withdrawn routes length
-     * 00 06 <- total path attribute length
-     * 80 <- attribute flags
-     * 0f <- attribute type (15 - MP_UNREACH_NLRI)
-     * 03 <- attribute length
-     * 40 04 <- value (AFI 16388: LS)
-     * 47 <- value (SAFI 71)
-     */
-    @Test
-    public void testEORLS() throws Exception {
-        final byte[] body = ByteArray.cutBytes(inputBytes.get(7), MessageUtil.COMMON_HEADER_LENGTH);
-        final int messageLength = ByteArray.bytesToInt(ByteArray.subByte(inputBytes.get(7), MessageUtil.MARKER_LENGTH, LENGTH_FIELD_LENGTH));
-        final Update message = BGPParserTest.updateParser.parseMessageBody(Unpooled.copiedBuffer(body), messageLength);
-
-        final Class<? extends AddressFamily> afi = message.getPathAttributes().getAugmentation(PathAttributes2.class).getMpUnreachNlri().getAfi();
-        final Class<? extends SubsequentAddressFamily> safi = message.getPathAttributes().getAugmentation(PathAttributes2.class).getMpUnreachNlri().getSafi();
-
-        assertEquals(LinkstateAddressFamily.class, afi);
-        assertEquals(LinkstateSubsequentAddressFamily.class, safi);
-
-        final ByteBuf buffer = Unpooled.buffer();
-        BGPParserTest.updateParser.serializeMessage(message, buffer);
-        assertArrayEquals(inputBytes.get(7), ByteArray.readAllBytes(buffer));
-    }
-
-    /*
-     * Tests BGP Link Ipv4
-     *
-     * 00 00 <- withdrawn routes length
-     * 01 48 <- total path attribute length (328)
+     * 00 07 <- total path attribute length
      * 90 <- attribute flags
-        0e <- attribute type code (MP reach)
-        01 2c <- attribute extended length (300)
-        40 04 <- AFI (16388 - Linkstate)
-        47 <- SAFI (71 - Linkstate)
-        04 <- next hop length
-        19 19 19 01 <- nexthop (25.25.25.1)
-        00 <- reserved
-
-        00 02 <- NLRI type (2 - linkNLRI)
-        00 5d <- NLRI length (93)
-        03 <- ProtocolID - OSPF
-        00 00 00 00 00 00 00 01 <- identifier
-
-        01 00 <- local node descriptor type (256)
-        00 24 <- length (36)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 08 <- length
-        03 03 03 04 0b 0b 0b 03 <- OSPF Router Id
-
-        01 01 <- remote node descriptor type (257)
-        00 20 <- length (32)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 04 <- length
-        03 03 03 04 <- OSPF Router Id
-
-        01 03 <- link descriptor type (IPv4 interface address - 259)
-        00 04 <- length (4)
-        0b 0b 0b 03 <- value (11.11.11.3)
-
-        00 02 <- NLRI type (2 - linkNLRI)
-        00 5d <- NLRI length (93)
-        03 <- ProtocolID - OSPF
-        00 00 00 00 00 00 00 01 <- identifier
-
-        01 00 <- local node descriptor type (256)
-        00 24 <- length (36)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 08 <- length
-        03 03 03 04 0b 0b 0b 03 <- OSPF Router Id
-
-        01 01 <- remote node descriptor type (257)
-        00 20 <- length (32)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 04 <- length
-        01 01 01 02 <- OSPF Router Id
-
-        01 03 <- link descriptor type (IPv4 interface address - 259)
-        00 04 <- length
-        0b 0b 0b 01 <- value (11.11.11.1)
-
-        00 02 <- NLRI type (2 - linkNLRI)
-        00 5d <- NLRI length (93)
-        03 <- ProtocolID - OSPF
-        00 00 00 00 00 00 00 01 <- identifier
-
-        01 00 <- local node descriptor type (256)
-        00 20 <- length (32)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 04 <- length
-        01 01 01 02 <- OSPF Router Id
-
-        01 01 <- remote node descriptor type (257)
-        00 24 <- length (36)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 08 <- length
-        03 03 03 04 0b 0b 0b 03 <- OSPF Router Id
-
-        01 03 <- link descriptor type (IPv4 interface address - 259)
-        00 04 <- length
-        0b 0b 0b 01 <- value (11.11.11.1)
-
-        40 <- attribute flags
-        01 <- attribute type (Origin)
-        01 <- attribute length
-        00 <- value (IGP)
-        40 <- attribute flags
-        02 <- attribute type (AS Path)
-        00 <- length
-        40 <- attribute flags
-        05 <- attribute type (local pref)
-        04 <- length
-        00 00 00 64 <- value
-        c0 <- attribute flags
-        63 <- attribute type (Link STATE - 99)
-        07 <- length
-        04 47 <- link attribute (1095 - Metric)
-        00 03 <- length
-        00 00 01 <- value
-     */
-    @Test
-    public void testBGPLink() throws Exception {
-        final byte[] body = ByteArray.cutBytes(inputBytes.get(8), MessageUtil.COMMON_HEADER_LENGTH);
-        final int messageLength = ByteArray.bytesToInt(ByteArray.subByte(inputBytes.get(8), MessageUtil.MARKER_LENGTH, LENGTH_FIELD_LENGTH));
-        final Update message = BGPParserTest.updateParser.parseMessageBody(Unpooled.copiedBuffer(body), messageLength);
-
-        final UpdateBuilder builder = new UpdateBuilder();
-
-        // check fields
-
-        assertNull(message.getWithdrawnRoutes());
-
-        final Ipv4NextHopCase nextHop = new Ipv4NextHopCaseBuilder().setIpv4NextHop(
-                new Ipv4NextHopBuilder().setGlobal(new Ipv4Address("25.25.25.1")).build()).build();
-
-        final List<Segments> asPath = Lists.newArrayList();
-
-        final LocalNodeDescriptorsBuilder lndBuilder = new LocalNodeDescriptorsBuilder().setAsNumber(new AsNumber((long) 100)).setDomainId(
-                new DomainIdentifier(0x19191901L)).setAreaId(new AreaIdentifier(0L));
-
-        final RemoteNodeDescriptorsBuilder rndBuilder = new RemoteNodeDescriptorsBuilder().setAsNumber(new AsNumber((long) 100)).setDomainId(
-                new DomainIdentifier(0x19191901L)).setAreaId(new AreaIdentifier(0L));
-
-        final CLinkstateDestinationBuilder clBuilder = new CLinkstateDestinationBuilder();
-        clBuilder.setIdentifier(new Identifier(BigInteger.ONE));
-        clBuilder.setNlriType(NlriType.Link);
-        clBuilder.setProtocolId(ProtocolId.Ospf);
-
-        final PathAttributes1Builder lsBuilder = new PathAttributes1Builder();
-        final MpReachNlriBuilder mpBuilder = new MpReachNlriBuilder();
-        mpBuilder.setAfi(LinkstateAddressFamily.class);
-        mpBuilder.setSafi(LinkstateSubsequentAddressFamily.class);
-        mpBuilder.setCNextHop(nextHop);
-
-        final List<CLinkstateDestination> linkstates = Lists.newArrayList();
-        clBuilder.setLocalNodeDescriptors(lndBuilder.setCRouterIdentifier(
-                new OspfPseudonodeCaseBuilder().setOspfPseudonode(
-                        new OspfPseudonodeBuilder().setOspfRouterId(0x03030304L).setLanInterface(new OspfInterfaceIdentifier(0x0b0b0b03L)).build()).build()).build());
-        clBuilder.setRemoteNodeDescriptors(rndBuilder.setCRouterIdentifier(
-                new OspfNodeCaseBuilder().setOspfNode(new OspfNodeBuilder().setOspfRouterId(0x03030304L).build()).build()).build());
-        clBuilder.setLinkDescriptors(new LinkDescriptorsBuilder().setIpv4InterfaceAddress(
-                new Ipv4InterfaceIdentifier(new Ipv4Address("11.11.11.3"))).build());
-        linkstates.add(clBuilder.build());
-
-        clBuilder.setLocalNodeDescriptors(lndBuilder.setCRouterIdentifier(
-                new OspfPseudonodeCaseBuilder().setOspfPseudonode(
-                        new OspfPseudonodeBuilder().setOspfRouterId(0x03030304L).setLanInterface(new OspfInterfaceIdentifier(0x0b0b0b03L)).build()).build()).build());
-        clBuilder.setRemoteNodeDescriptors(rndBuilder.setCRouterIdentifier(
-                new OspfNodeCaseBuilder().setOspfNode(new OspfNodeBuilder().setOspfRouterId(0x01010102L).build()).build()).build());
-        clBuilder.setLinkDescriptors(new LinkDescriptorsBuilder().setIpv4InterfaceAddress(
-                new Ipv4InterfaceIdentifier(new Ipv4Address("11.11.11.1"))).build());
-        linkstates.add(clBuilder.build());
-
-        clBuilder.setLocalNodeDescriptors(lndBuilder.setCRouterIdentifier(
-                new OspfNodeCaseBuilder().setOspfNode(new OspfNodeBuilder().setOspfRouterId(0x01010102L).build()).build()).build());
-        clBuilder.setRemoteNodeDescriptors(rndBuilder.setCRouterIdentifier(
-                new OspfPseudonodeCaseBuilder().setOspfPseudonode(
-                        new OspfPseudonodeBuilder().setOspfRouterId(0x03030304L).setLanInterface(new OspfInterfaceIdentifier(0x0b0b0b03L)).build()).build()).build());
-        clBuilder.setLinkDescriptors(new LinkDescriptorsBuilder().setIpv4InterfaceAddress(
-                new Ipv4InterfaceIdentifier(new Ipv4Address("11.11.11.1"))).build());
-        linkstates.add(clBuilder.build());
-
-        lsBuilder.setMpReachNlri(mpBuilder.build());
-
-        // check path attributes
-        final PathAttributes attrs = message.getPathAttributes();
-
-        final PathAttributesBuilder paBuilder = new PathAttributesBuilder();
-
-        paBuilder.setOrigin(new OriginBuilder().setValue(BgpOrigin.Igp).build());
-        assertEquals(paBuilder.getOrigin(), attrs.getOrigin());
-
-        paBuilder.setAsPath(new AsPathBuilder().setSegments(asPath).build());
-        assertEquals(paBuilder.getAsPath(), attrs.getAsPath());
-
-        paBuilder.setLocalPref(new LocalPrefBuilder().setPref(100L).build());
-        assertEquals(paBuilder.getLocalPref(), attrs.getLocalPref());
-
-        final MpReachNlri mp = attrs.getAugmentation(PathAttributes1.class).getMpReachNlri();
-        assertEquals(mpBuilder.getAfi(), mp.getAfi());
-        assertEquals(mpBuilder.getSafi(), mp.getSafi());
-        assertEquals(mpBuilder.getCNextHop(), mp.getCNextHop());
-
-        final DestinationLinkstateBuilder dBuilder = new DestinationLinkstateBuilder();
-        dBuilder.setCLinkstateDestination(linkstates);
-
-        mpBuilder.setAdvertizedRoutes(new AdvertizedRoutesBuilder().setDestinationType(
-                new DestinationLinkstateCaseBuilder().setDestinationLinkstate(dBuilder.build()).build()).build());
-        lsBuilder.setMpReachNlri(mpBuilder.build());
-
-        paBuilder.addAugmentation(PathAttributes1.class, lsBuilder.build());
-
-        final org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.PathAttributes1Builder lsAttrBuilder = new org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.PathAttributes1Builder();
-
-        lsAttrBuilder.setLinkstatePathAttribute(new LinkstatePathAttributeBuilder().setLinkStateAttribute(
-                new LinkAttributesCaseBuilder().setLinkAttributes(new LinkAttributesBuilder().setMetric(new Metric(1L)).build()).build()).build());
-        paBuilder.addAugmentation(
-                org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.PathAttributes1.class,
-                lsAttrBuilder.build());
-
-        assertEquals(
-                lsAttrBuilder.build().getLinkstatePathAttribute(),
-                attrs.getAugmentation(
-                        org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.linkstate.rev131125.PathAttributes1.class).getLinkstatePathAttribute());
-
-        final List<CLinkstateDestination> dests = ((DestinationLinkstateCase) mp.getAdvertizedRoutes().getDestinationType()).getDestinationLinkstate().getCLinkstateDestination();
-
-        assertEquals(linkstates.size(), dests.size());
-
-        assertEquals(linkstates, dests);
-        // check API message
-        builder.setPathAttributes(paBuilder.build());
-        assertEquals(builder.build(), message);
-
-        final ByteBuf buffer = Unpooled.buffer();
-        BGPParserTest.updateParser.serializeMessage(message, buffer);
-        assertArrayEquals(inputBytes.get(8), ByteArray.readAllBytes(buffer));
-    }
-
-    /*
-     * TEST BGP Node
-     *
-     *  00 00 <- withdrawn routes length
-        00 b1 <- total path attribute length (177)
-        80 <- attribute flags
-        0e <- attribute type code (MP reach)
-        a0 <- attribute length (160)
-        40 04 <- AFI (16388 - Linkstate)
-        47 <- SAFI (71 - Linkstate)
-        04 <- next hop length
-        19 19 19 01 - nexthop (25.25.25.1)
-        00 <- reserved
-
-        00 01 <- NLRI type (1 - nodeNLRI)
-        00 31 <- NLRI length (49)
-        03 <- ProtocolID - OSPF
-        00 00 00 00 00 00 00 01 <- identifier
-        01 00 <- local node descriptor type (256)
-        00 24 <- length (36)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 08 <- length
-        03 03 03 04 0b 0b 0b 03 <- OSPF Router Id
-
-        00 01 <- NLRI type (1 - nodeNLRI)
-        00 2d <- NLRI length (45)
-        03 <- ProtocolID - OSPF
-        00 00 00 00 00 00 00 01 <- identifier
-        01 00 <- local node descriptor type (256)
-        00 20 <- length (32)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 04 <- length
-        03 03 03 04 <- OSPF Router Id
-
-        00 01 <- NLRI type (1 - nodeNLRI)
-        00 2d <- NLRI length (45)
-        03 <- ProtocolID - OSPF
-        00 00 00 00 00 00 00 01 <- identifier
-        01 00 <- local node descriptor type (256)
-        00 20 <- length (32)
-        02 00 <- node descriptor type (member AS - 512)
-        00 04 <- length
-        00 00 00 64 <- value (100)
-        02 01 <- node descriptor type (bgpId - 513)
-        00 04 <- length
-        19 19 19 01 <- bgpId (25.25.25.1)
-        02 02 <- node descriptor type (areaId - 514)
-        00 04 <- length
-        00 00 00 00 <- value
-        02 03 <- node descriptor type (routeId - 515)
-        00 04 <- length
-        01 01 01 02  <- OSPF Router Id
-
-        40 <- attribute flags
-        01 <- attribute type (Origin)
-        01 <- attribute length
-        00 <- value (IGP)
-        40 <- attribute flags
-        02 <- attribute type (AS Path)
-        00 <- length
-        40 <- attribute flags
-        05 <- attribute type (local pref)
-        04 <- length
-        00 00 00 64 <- value
+     * 0f <- attribute type (15 - MP_UNREACH_NLRI)
+     * 00 03 <- attribute length
+     * 00 02 <- value (AFI 2: IPv6)
+     * 01 <- value (SAFI 1)
      */
     @Test
-    public void testBGPNode() throws Exception {
-        final byte[] body = ByteArray.cutBytes(inputBytes.get(9), MessageUtil.COMMON_HEADER_LENGTH);
-        final int messageLength = ByteArray.bytesToInt(ByteArray.subByte(inputBytes.get(9), MessageUtil.MARKER_LENGTH, LENGTH_FIELD_LENGTH));
+    public void testEORIpv6exLength() throws Exception {
+        final byte[] body = ByteArray.cutBytes(inputBytes.get(6), MessageUtil.COMMON_HEADER_LENGTH);
+        final int messageLength = ByteArray.bytesToInt(ByteArray.subByte(inputBytes.get(6), MessageUtil.MARKER_LENGTH, LENGTH_FIELD_LENGTH));
         final Update message = BGPParserTest.updateParser.parseMessageBody(Unpooled.copiedBuffer(body), messageLength);
 
-        final UpdateBuilder builder = new UpdateBuilder();
-
-        // check fields
-
-        assertNull(message.getWithdrawnRoutes());
-
-        // attributes
-
-        final Ipv4NextHopCase nextHop = new Ipv4NextHopCaseBuilder().setIpv4NextHop(
-                new Ipv4NextHopBuilder().setGlobal(new Ipv4Address("25.25.25.1")).build()).build();
-
-        final LocalNodeDescriptorsBuilder lndBuilder = new LocalNodeDescriptorsBuilder().setAsNumber(new AsNumber((long) 100)).setDomainId(
-                new DomainIdentifier(0x19191901L)).setAreaId(new AreaIdentifier(0L));
-
-        final CLinkstateDestinationBuilder clBuilder = new CLinkstateDestinationBuilder();
-        clBuilder.setIdentifier(new Identifier(BigInteger.ONE));
-        clBuilder.setNlriType(NlriType.Node);
-        clBuilder.setProtocolId(ProtocolId.Ospf);
-
-        final List<CLinkstateDestination> linkstates = Lists.newArrayList();
-        clBuilder.setLocalNodeDescriptors(lndBuilder.setCRouterIdentifier(
-                new OspfPseudonodeCaseBuilder().setOspfPseudonode(
-                        new OspfPseudonodeBuilder().setOspfRouterId(0x03030304L).setLanInterface(new OspfInterfaceIdentifier(0x0b0b0b03L)).build()).build()).build());
-        linkstates.add(clBuilder.build());
-
-        clBuilder.setLocalNodeDescriptors(lndBuilder.setCRouterIdentifier(
-                new OspfNodeCaseBuilder().setOspfNode(new OspfNodeBuilder().setOspfRouterId(0x03030304L).build()).build()).build());
-        linkstates.add(clBuilder.build());
-
-        clBuilder.setLocalNodeDescriptors(lndBuilder.setCRouterIdentifier(
-                new OspfNodeCaseBuilder().setOspfNode(new OspfNodeBuilder().setOspfRouterId(0x01010102L).build()).build()).build());
-        linkstates.add(clBuilder.build());
-
-        final PathAttributes1Builder lsBuilder = new PathAttributes1Builder();
-        final MpReachNlriBuilder mpBuilder = new MpReachNlriBuilder();
-        mpBuilder.setAfi(LinkstateAddressFamily.class);
-        mpBuilder.setSafi(LinkstateSubsequentAddressFamily.class);
-        mpBuilder.setCNextHop(nextHop);
-
-        final DestinationLinkstateBuilder dBuilder = new DestinationLinkstateBuilder();
-        dBuilder.setCLinkstateDestination(linkstates);
-
-        mpBuilder.setAdvertizedRoutes(new AdvertizedRoutesBuilder().setDestinationType(
-                new DestinationLinkstateCaseBuilder().setDestinationLinkstate(dBuilder.build()).build()).build());
-        lsBuilder.setMpReachNlri(mpBuilder.build());
-
-        final List<Segments> asPath = Lists.newArrayList();
-
-        // check path attributes
-        final PathAttributes attrs = message.getPathAttributes();
-
-        final PathAttributesBuilder paBuilder = new PathAttributesBuilder();
-
-        paBuilder.setOrigin(new OriginBuilder().setValue(BgpOrigin.Igp).build());
-        assertEquals(paBuilder.getOrigin(), attrs.getOrigin());
-
-        paBuilder.setAsPath(new AsPathBuilder().setSegments(asPath).build());
-        assertEquals(paBuilder.getAsPath(), attrs.getAsPath());
-
-        paBuilder.setLocalPref(new LocalPrefBuilder().setPref(100L).build());
-        assertEquals(paBuilder.getLocalPref(), attrs.getLocalPref());
-
-        paBuilder.addAugmentation(PathAttributes1.class, lsBuilder.build());
-
-        final MpReachNlri mp = attrs.getAugmentation(PathAttributes1.class).getMpReachNlri();
-        assertEquals(mpBuilder.getAfi(), mp.getAfi());
-        assertEquals(mpBuilder.getSafi(), mp.getSafi());
-        assertEquals(mpBuilder.getCNextHop(), mp.getCNextHop());
-
-        final List<CLinkstateDestination> dests = ((DestinationLinkstateCase) mp.getAdvertizedRoutes().getDestinationType()).getDestinationLinkstate().getCLinkstateDestination();
+        final Class<? extends AddressFamily> afi = message.getAttributes().getAugmentation(Attributes2.class).getMpUnreachNlri().getAfi();
+        final Class<? extends SubsequentAddressFamily> safi = message.getAttributes().getAugmentation(Attributes2.class).getMpUnreachNlri().getSafi();
 
-        assertEquals(linkstates.size(), dests.size());
-
-        assertEquals(linkstates, dests);
-
-        // check API message
-        builder.setPathAttributes(paBuilder.build());
-        assertEquals(builder.build(), message);
+        assertEquals(Ipv6AddressFamily.class, afi);
+        assertEquals(UnicastSubsequentAddressFamily.class, safi);
 
         final ByteBuf buffer = Unpooled.buffer();
         BGPParserTest.updateParser.serializeMessage(message, buffer);
-        assertArrayEquals(inputBytes.get(9), ByteArray.readAllBytes(buffer));
-    }
-
-    /*
-     * ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff <- marker
-     * 00 3d <- length (61) - including header
-     * 01 <- message type
-     * 04 <- BGP version
-     * 00 64 <- My AS Number (AS TRANS in this case)
-     * 00 b4 <- Hold Time
-     * 00 00 00 00 <- BGP Identifier
-     * 20 <- Optional Parameters Length
-     * 02 <- opt. param. type (capabilities)
-     * 06 <- length
-     * 01 <- capability code (MP Extensions for BGP4)
-     * 04 <- length
-     * 00 01 00 01 <- AFI 1, SAFI 1
-     * 02 <- opt. param. type (capabilities)
-     * 06 <- length
-     * 01 <- capability code (MP Extensions for BGP4)
-     * 04 <- length
-     * 00 02 00 01 <- AFI 2, SAFI 1
-     * 02 <- opt. param. type (capabilities)
-     * 06 <- length
-     * 01 <- capability code (MP Extensions for BGP4)
-     * 04 <- length
-     * 40 04 00 47 <- AFI 16388, SAFI 71
-     * 02 <- opt. param. type (capabilities)
-     * 06 <- length
-     * 41 <- capability code (AS4 octet support)
-     * 04 <- length
-     * 00 00 00 64 <- AS number
-     */
-    @Test
-    public void testOpenMessage() throws Exception {
-        final MessageRegistry msgReg = ServiceLoaderBGPExtensionProviderContext.getSingletonInstance().getMessageRegistry();
-        final Notification o = msgReg.parseMessage(Unpooled.copiedBuffer(inputBytes.get(13)));
-        final Open open = (Open) o;
-        final Set<BgpTableType> types = Sets.newHashSet();
-        for (final BgpParameters param : open.getBgpParameters()) {
-            final CParameters p = param.getCParameters();
-            if (p instanceof MultiprotocolCase) {
-                final BgpTableType type = new BgpTableTypeImpl(((MultiprotocolCase) p).getMultiprotocolCapability().getAfi(), ((MultiprotocolCase) p).getMultiprotocolCapability().getSafi());
-                types.add(type);
-            }
-        }
-        final Set<BgpTableType> expected = Sets.newHashSet();
-        expected.add(new BgpTableTypeImpl(Ipv4AddressFamily.class, UnicastSubsequentAddressFamily.class));
-        expected.add(new BgpTableTypeImpl(Ipv6AddressFamily.class, UnicastSubsequentAddressFamily.class));
-        expected.add(new BgpTableTypeImpl(LinkstateAddressFamily.class, LinkstateSubsequentAddressFamily.class));
-        assertEquals(expected, types);
-
-        final ByteBuf buffer = Unpooled.buffer();
-        msgReg.serializeMessage(o, buffer);
-        assertArrayEquals(inputBytes.get(13), ByteArray.readAllBytes(buffer));
+        assertArrayEquals(inputBytes.get(6), ByteArray.readAllBytes(buffer));
     }
 }