X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=bgp%2Ftopology-provider%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fbgpcep%2Fbgp%2Ftopology%2Fprovider%2FIpv4ReachabilityTopologyBuilderTest.java;h=98b30ac64d1af24e86d2f6d0a8ba5ef6e7a3a88b;hb=3860d202e14ae693d515cf40f4795fd086a5d75d;hp=c3c2d41a1c034376e85ef44243587152d548ea2b;hpb=af2702513e96ccb4bf6b63b15d4a6364cc0bb3d2;p=bgpcep.git diff --git a/bgp/topology-provider/src/test/java/org/opendaylight/bgpcep/bgp/topology/provider/Ipv4ReachabilityTopologyBuilderTest.java b/bgp/topology-provider/src/test/java/org/opendaylight/bgpcep/bgp/topology/provider/Ipv4ReachabilityTopologyBuilderTest.java index c3c2d41a1c..98b30ac64d 100644 --- a/bgp/topology-provider/src/test/java/org/opendaylight/bgpcep/bgp/topology/provider/Ipv4ReachabilityTopologyBuilderTest.java +++ b/bgp/topology-provider/src/test/java/org/opendaylight/bgpcep/bgp/topology/provider/Ipv4ReachabilityTopologyBuilderTest.java @@ -9,35 +9,44 @@ package org.opendaylight.bgpcep.bgp.topology.provider; import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertTrue; +import static org.junit.Assert.assertNotNull; +import static org.junit.Assert.assertNull; +import static org.opendaylight.protocol.util.CheckUtil.checkNotPresentOperational; +import static org.opendaylight.protocol.util.CheckUtil.readDataOperational; -import com.google.common.base.Optional; +import java.util.concurrent.ExecutionException; +import org.junit.Before; import org.junit.Test; -import org.opendaylight.controller.md.sal.binding.api.DataBroker; -import org.opendaylight.controller.md.sal.binding.api.WriteTransaction; -import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; -import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException; -import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv4Address; -import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv4Prefix; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv4.routes.Ipv4Routes; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv4.routes.ipv4.routes.Ipv4Route; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv4.routes.ipv4.routes.Ipv4RouteBuilder; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv4.routes.ipv4.routes.Ipv4RouteKey; -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.rib.rev130925.rib.Tables; -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.UnicastSubsequentAddressFamily; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev130919.next.hop.c.next.hop.Ipv4NextHopCaseBuilder; -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.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.Topology; +import org.opendaylight.mdsal.binding.api.WriteTransaction; +import org.opendaylight.mdsal.common.api.LogicalDatastoreType; +import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv4AddressNoZone; +import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv4Prefix; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev180329.bgp.rib.rib.loc.rib.tables.routes.Ipv4RoutesCase; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev180329.ipv4.routes.Ipv4Routes; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev180329.ipv4.routes.ipv4.routes.Ipv4Route; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev180329.ipv4.routes.ipv4.routes.Ipv4RouteBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev180329.ipv4.routes.ipv4.routes.Ipv4RouteKey; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev200120.PathId; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev200120.path.attributes.Attributes; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev200120.path.attributes.AttributesBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.message.rev200120.path.attributes.attributes.OriginBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329.bgp.rib.rib.LocRib; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329.rib.Tables; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329.rib.TablesKey; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev200120.BgpOrigin; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev200120.Ipv4AddressFamily; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev200120.UnicastSubsequentAddressFamily; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev200120.next.hop.c.next.hop.Ipv4NextHopCaseBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.types.rev200120.next.hop.c.next.hop.ipv4.next.hop._case.Ipv4NextHopBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.odl.bgp.topology.types.rev160524.TopologyTypes1; import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.Node; import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.nt.l3.unicast.igp.topology.rev131021.Node1; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; +import org.opendaylight.yangtools.yang.common.Uint32; public class Ipv4ReachabilityTopologyBuilderTest extends AbstractTopologyBuilderTest { + static final Uint32 PATH_ID = Uint32.ONE; private static final String ROUTE_IP4PREFIX = "127.1.0.0/32"; private static final String NEXT_HOP = "127.1.0.1"; private static final String NEW_NEXT_HOP = "127.1.0.2"; @@ -45,57 +54,73 @@ public class Ipv4ReachabilityTopologyBuilderTest extends AbstractTopologyBuilder private Ipv4ReachabilityTopologyBuilder ipv4TopoBuilder; private InstanceIdentifier ipv4RouteIID; + @Before @Override - protected void setupWithDataBroker(final DataBroker dataBroker) { - super.setupWithDataBroker(dataBroker); - this.ipv4TopoBuilder = new Ipv4ReachabilityTopologyBuilder(dataBroker, LOC_RIB_REF, TEST_TOPOLOGY_ID); - this.ipv4TopoBuilder.start(dataBroker, Ipv4AddressFamily.class, UnicastSubsequentAddressFamily.class); - final InstanceIdentifier path = this.ipv4TopoBuilder.tableInstanceIdentifier(Ipv4AddressFamily.class, UnicastSubsequentAddressFamily.class); - this.ipv4RouteIID = path.builder().child((Class)Ipv4Routes.class).child(Ipv4Route.class, new Ipv4RouteKey(new Ipv4Prefix(ROUTE_IP4PREFIX))).build(); + public void setUp() { + super.setUp(); + this.ipv4TopoBuilder = new Ipv4ReachabilityTopologyBuilder(getDataBroker(), LOC_RIB_REF, TEST_TOPOLOGY_ID); + this.ipv4TopoBuilder.start(); + final InstanceIdentifier path = LOC_RIB_REF.getInstanceIdentifier().builder().child(LocRib.class) + .child(Tables.class, new TablesKey(Ipv4AddressFamily.class, UnicastSubsequentAddressFamily.class)).build(); + + this.ipv4RouteIID = path.builder().child(Ipv4RoutesCase.class, Ipv4Routes.class) + .child(Ipv4Route.class, new Ipv4RouteKey(new PathId(PATH_ID), ROUTE_IP4PREFIX)).build(); } @Test - public void testIpv4ReachabilityTopologyBuilder() throws TransactionCommitFailedException { + public void testIpv4ReachabilityTopologyBuilder() throws InterruptedException, ExecutionException { // create route updateIpv4Route(createIpv4Route(NEXT_HOP)); - final Optional topologyMaybe = getTopology(this.ipv4TopoBuilder.getInstanceIdentifier()); - assertTrue(topologyMaybe.isPresent()); - final Topology topology = topologyMaybe.get(); - assertEquals(1, topology.getNode().size()); - final Node node = topology.getNode().get(0); - assertEquals(NEXT_HOP, node.getNodeId().getValue()); - assertEquals(ROUTE_IP4PREFIX, node.getAugmentation(Node1.class).getIgpNodeAttributes().getPrefix().get(0).getPrefix().getIpv4Prefix().getValue()); + + readDataOperational(getDataBroker(), this.ipv4TopoBuilder.getInstanceIdentifier(), topology -> { + final TopologyTypes1 topologyTypes = topology.getTopologyTypes().augmentation(TopologyTypes1.class); + assertNotNull(topologyTypes); + assertNotNull(topologyTypes.getBgpIpv4ReachabilityTopology()); + assertEquals(1, topology.nonnullNode().size()); + final Node node = topology.nonnullNode().values().iterator().next(); + assertEquals(NEXT_HOP, node.getNodeId().getValue()); + assertEquals(ROUTE_IP4PREFIX, node.augmentation(Node1.class).getIgpNodeAttributes().nonnullPrefix().values() + .iterator().next().getPrefix().getIpv4Prefix().getValue()); + return topology; + }); // update route updateIpv4Route(createIpv4Route(NEW_NEXT_HOP)); - final Topology topologyUpdated = getTopology(this.ipv4TopoBuilder.getInstanceIdentifier()).get(); - assertEquals(1, topologyUpdated.getNode().size()); - final Node nodeUpdated = topologyUpdated.getNode().get(0); - assertEquals(NEW_NEXT_HOP, nodeUpdated.getNodeId().getValue()); - assertEquals(ROUTE_IP4PREFIX, nodeUpdated.getAugmentation(Node1.class).getIgpNodeAttributes().getPrefix().get(0).getPrefix().getIpv4Prefix().getValue()); + readDataOperational(getDataBroker(), this.ipv4TopoBuilder.getInstanceIdentifier(), topology -> { + assertEquals(1, topology.nonnullNode().size()); + final Node nodeUpdated = topology.nonnullNode().values().iterator().next(); + assertEquals(NEW_NEXT_HOP, nodeUpdated.getNodeId().getValue()); + assertEquals(ROUTE_IP4PREFIX, nodeUpdated.augmentation(Node1.class).getIgpNodeAttributes() + .nonnullPrefix().values().iterator().next().getPrefix().getIpv4Prefix().getValue()); + return topology; + }); // delete route final WriteTransaction wTx = getDataBroker().newWriteOnlyTransaction(); wTx.delete(LogicalDatastoreType.OPERATIONAL, this.ipv4RouteIID); - wTx.submit(); - final Topology topologyDeleted = getTopology(this.ipv4TopoBuilder.getInstanceIdentifier()).get(); - assertEquals(0, topologyDeleted.getNode().size()); + wTx.commit(); + readDataOperational(getDataBroker(), this.ipv4TopoBuilder.getInstanceIdentifier(), topology -> { + assertNull(topology.getNode()); + return topology; + }); this.ipv4TopoBuilder.close(); - assertFalse(getTopology(this.ipv4TopoBuilder.getInstanceIdentifier()).isPresent()); + checkNotPresentOperational(getDataBroker(), this.ipv4TopoBuilder.getInstanceIdentifier()); } private void updateIpv4Route(final Ipv4Route data) { final WriteTransaction wTx = getDataBroker().newWriteOnlyTransaction(); - wTx.put(LogicalDatastoreType.OPERATIONAL, this.ipv4RouteIID, data, true); - wTx.submit(); + wTx.mergeParentStructurePut(LogicalDatastoreType.OPERATIONAL, this.ipv4RouteIID, data); + wTx.commit(); } - private Ipv4Route createIpv4Route(final String nextHop) { + private static Ipv4Route createIpv4Route(final String nextHop) { final Attributes attribute = new AttributesBuilder() - .setCNextHop(new Ipv4NextHopCaseBuilder().setIpv4NextHop(new Ipv4NextHopBuilder().setGlobal(new Ipv4Address(nextHop)).build()).build()) - .build(); - return new Ipv4RouteBuilder().setKey(new Ipv4RouteKey(new Ipv4Prefix(ROUTE_IP4PREFIX))).setPrefix(new Ipv4Prefix(ROUTE_IP4PREFIX)).setAttributes(attribute).build(); + .setOrigin(new OriginBuilder().setValue(BgpOrigin.Igp).build()) + .setCNextHop(new Ipv4NextHopCaseBuilder().setIpv4NextHop(new Ipv4NextHopBuilder() + .setGlobal(new Ipv4AddressNoZone(nextHop)).build()).build()).build(); + return new Ipv4RouteBuilder().withKey(new Ipv4RouteKey(new PathId(PATH_ID), ROUTE_IP4PREFIX)) + .setPrefix(new Ipv4Prefix(ROUTE_IP4PREFIX)).setAttributes(attribute).build(); } }