X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=bgp%2Frib-spi%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fprotocol%2Fbgp%2Frib%2Fspi%2FAbstractRIBSupportTest.java;h=6ed27806e689d1e178360f2dfdbca7d295069d17;hb=7ab844cee4971ee5b0a26ef8c193300e77bb499d;hp=48a20ea7cb04d13c01f33796b6bf53f40148d6a2;hpb=414764dd2cb237f4c6296643b4606d9d4d671a4f;p=bgpcep.git diff --git a/bgp/rib-spi/src/test/java/org/opendaylight/protocol/bgp/rib/spi/AbstractRIBSupportTest.java b/bgp/rib-spi/src/test/java/org/opendaylight/protocol/bgp/rib/spi/AbstractRIBSupportTest.java index 48a20ea7cb..6ed27806e6 100644 --- a/bgp/rib-spi/src/test/java/org/opendaylight/protocol/bgp/rib/spi/AbstractRIBSupportTest.java +++ b/bgp/rib-spi/src/test/java/org/opendaylight/protocol/bgp/rib/spi/AbstractRIBSupportTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved. + * Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, @@ -7,110 +7,190 @@ */ package org.opendaylight.protocol.bgp.rib.spi; -import static org.junit.Assert.assertEquals; - -import com.google.common.collect.ImmutableCollection; - -import org.junit.Test; +import static org.mockito.ArgumentMatchers.any; +import static org.mockito.Mockito.doAnswer; +import static org.mockito.MockitoAnnotations.initMocks; + +import com.google.common.base.Preconditions; +import com.google.common.collect.Iterables; +import java.util.ArrayList; +import java.util.Collection; +import java.util.List; +import java.util.Map; +import org.junit.Before; import org.mockito.Mock; -import org.opendaylight.controller.md.sal.dom.api.DOMDataWriteTransaction; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv4.prefixes.DestinationIpv4; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.inet.rev150305.ipv4.prefixes.destination.ipv4.Ipv4Prefixes; -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.message.rev130919.update.Nlri; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.destination.DestinationType; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.update.path.attributes.mp.reach.nlri.AdvertizedRoutes; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev130919.update.path.attributes.mp.unreach.nlri.WithdrawnRoutes; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev130925.rib.tables.Routes; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev130925.route.Attributes; +import org.opendaylight.mdsal.binding.dom.adapter.AdapterContext; +import org.opendaylight.mdsal.binding.dom.adapter.test.AbstractConcurrentDataBrokerTest; +import org.opendaylight.mdsal.binding.dom.adapter.test.AbstractDataBrokerTestCustomizer; +import org.opendaylight.mdsal.binding.spec.reflect.BindingReflections; +import org.opendaylight.mdsal.common.api.LogicalDatastoreType; +import org.opendaylight.mdsal.dom.api.DOMDataTreeWriteTransaction; +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.Update; +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.multiprotocol.rev180329.AttributesReach; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev180329.AttributesUnreach; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev180329.destination.DestinationType; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev180329.update.attributes.MpReachNlri; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev180329.update.attributes.MpReachNlriBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev180329.update.attributes.MpUnreachNlri; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev180329.update.attributes.MpUnreachNlriBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev180329.update.attributes.mp.reach.nlri.AdvertizedRoutesBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.multiprotocol.rev180329.update.attributes.mp.unreach.nlri.WithdrawnRoutesBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329.BgpRib; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329.RibId; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329.Route; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329.bgp.rib.Rib; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329.bgp.rib.RibKey; +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.TablesBuilder; +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.rib.rev180329.rib.tables.Routes; +import org.opendaylight.yangtools.yang.binding.ChildOf; +import org.opendaylight.yangtools.yang.binding.ChoiceIn; import org.opendaylight.yangtools.yang.binding.DataObject; +import org.opendaylight.yangtools.yang.binding.Identifiable; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.opendaylight.yangtools.yang.common.QName; +import org.opendaylight.yangtools.yang.common.Uint32; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier; +import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifierWithPredicates; import org.opendaylight.yangtools.yang.data.api.schema.ChoiceNode; import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode; -import org.opendaylight.yangtools.yang.data.impl.schema.builder.impl.ImmutableChoiceNodeBuilder; -import org.opendaylight.yangtools.yang.data.impl.schema.builder.impl.ImmutableContainerNodeBuilder; +import org.opendaylight.yangtools.yang.data.api.schema.MapEntryNode; +import org.opendaylight.yangtools.yang.data.api.schema.MapNode; +import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; + +public abstract class AbstractRIBSupportTest, + S extends ChildOf, + R extends Route & ChildOf & Identifiable> extends AbstractConcurrentDataBrokerTest { + protected static final PathId PATH_ID = new PathId(Uint32.ONE); + protected static final Attributes ATTRIBUTES = new AttributesBuilder().build(); + private static final InstanceIdentifier RIB = InstanceIdentifier.builder(BgpRib.class) + .child(Rib.class, new RibKey(new RibId("rib"))).child(LocRib.class).build(); + private static final InstanceIdentifier ATTRIBUTES_IID = InstanceIdentifier.create(Update.class) + .child(Attributes.class); + private static final InstanceIdentifier MP_UNREACH_IID = ATTRIBUTES_IID + .augmentation(AttributesUnreach.class).child(MpUnreachNlri.class); + private static final InstanceIdentifier MP_REACH_IID = ATTRIBUTES_IID + .augmentation(AttributesReach.class).child(MpReachNlri.class); + @Mock + protected DOMDataTreeWriteTransaction tx; + protected List> deletedRoutes; + protected List, DataObject>> insertedRoutes; -public class AbstractRIBSupportTest { + protected AdapterContext adapter; + private AbstractRIBSupport abstractRIBSupport; - private final ContainerNode ipv4p = ImmutableContainerNodeBuilder.create().withNodeIdentifier(new NodeIdentifier(Ipv4Prefixes.QNAME)).build(); - private final ContainerNode destination = ImmutableContainerNodeBuilder.create().withNodeIdentifier(new NodeIdentifier(DestinationIpv4.QNAME)).addChild(this.ipv4p).build(); - private final ChoiceNode choiceNode = ImmutableChoiceNodeBuilder.create().withNodeIdentifier(new NodeIdentifier(DestinationType.QNAME)).addChild(this.destination).build(); + protected final void setUpTestCustomizer(final AbstractRIBSupport ribSupport) throws Exception { + this.abstractRIBSupport = ribSupport; + } - static ContainerNode dest; + @Before + public void setUp() throws Exception { + initMocks(this); + doAnswer(invocation -> { + final Object[] args = invocation.getArguments(); + AbstractRIBSupportTest.this.insertedRoutes.add(adapter.currentSerializer() + .fromNormalizedNode((YangInstanceIdentifier) args[1], (NormalizedNode) args[2])); + return args[1]; + }).when(this.tx).put(any(LogicalDatastoreType.class), any(YangInstanceIdentifier.class), + any(NormalizedNode.class)); + + doAnswer(invocation -> { + final Object[] args = invocation.getArguments(); + AbstractRIBSupportTest.this.deletedRoutes.add((InstanceIdentifier) + adapter.currentSerializer().fromYangInstanceIdentifier((YangInstanceIdentifier) args[1])); + return args[1]; + }).when(this.tx).delete(any(LogicalDatastoreType.class), any(YangInstanceIdentifier.class)); + this.deletedRoutes = new ArrayList<>(); + this.insertedRoutes = new ArrayList<>(); + } - private final RIBSupport testSupport = new AbstractRIBSupport(Ipv4Routes.QNAME) { + @Override + protected final AbstractDataBrokerTestCustomizer createDataBrokerTestCustomizer() { + final AbstractDataBrokerTestCustomizer customizer = super.createDataBrokerTestCustomizer(); + this.adapter = customizer.getAdapterContext(); + return customizer; + } - @Override - public ChoiceNode emptyRoutes() { - return null; - } + protected final ContainerNode createNlriWithDrawnRoute(final DestinationType destUnreach) { + final MpUnreachNlri mpReach = new MpUnreachNlriBuilder().setWithdrawnRoutes(new WithdrawnRoutesBuilder() + .setDestinationType(destUnreach).build()).build(); + final Map.Entry> result = this.adapter.currentSerializer() + .toNormalizedNode(MP_UNREACH_IID, mpReach); + return (ContainerNode) result.getValue(); + } - @Override - public ImmutableCollection> cacheableAttributeObjects() { - return null; - } + protected final ContainerNode createNlriAdvertiseRoute(final DestinationType destReach) { + final MpReachNlri mpReach = new MpReachNlriBuilder().setAdvertizedRoutes(new AdvertizedRoutesBuilder() + .setDestinationType(destReach).build()).build(); + final Map.Entry> result = this.adapter.currentSerializer() + .toNormalizedNode(MP_REACH_IID, mpReach); + return (ContainerNode) result.getValue(); + } - @Override - public ImmutableCollection> cacheableNlriObjects() { - return null; - } + protected final ContainerNode createAttributes() { + return (ContainerNode) this.adapter.currentSerializer().toNormalizedNode(ATTRIBUTES_IID, ATTRIBUTES).getValue(); + } - @Override - protected NodeIdentifier destinationContainerIdentifier() { - return new NodeIdentifier(DestinationIpv4.QNAME); - } + protected final MapEntryNode createEmptyTable() { + final Tables tables = new TablesBuilder().withKey(getTablesKey()) + .setAttributes(new org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.bgp.rib.rev180329 + .rib.tables.AttributesBuilder().build()).build(); + return (MapEntryNode) this.adapter.currentSerializer().toNormalizedNode(tablesIId(), tables).getValue(); + } - @Override - protected void deleteDestinationRoutes(final DOMDataWriteTransaction tx, final YangInstanceIdentifier tablePath, - final ContainerNode destination) { - AbstractRIBSupportTest.dest = destination; - } + protected final ChoiceNode createRoutes(final Routes routes) { + final Tables tables = new TablesBuilder().withKey(getTablesKey()).setRoutes(routes).build(); + return (ChoiceNode) ((MapEntryNode) this.adapter.currentSerializer().toNormalizedNode(tablesIId(), tables) + .getValue()).getChild(new NodeIdentifier(BindingReflections.findQName(Routes.class))).get(); + } - @Override - protected void putDestinationRoutes(final DOMDataWriteTransaction tx, final YangInstanceIdentifier tablePath, - final ContainerNode destination, final ContainerNode attributes) { - AbstractRIBSupportTest.dest = destination; - } - }; + protected final Collection createRoutes(final S routes) { + Preconditions.checkArgument(routes.implementedInterface() + .equals(this.abstractRIBSupport.routesContainerClass())); + final InstanceIdentifier routesIId = routesIId(); + final Map.Entry> normalizedNode = this.adapter.currentSerializer() + .toNormalizedNode(routesIId, routes); + final ContainerNode container = (ContainerNode) normalizedNode.getValue(); + final NodeIdentifier routeNid = new NodeIdentifier(getRouteListQname()); + return ((MapNode) container.getChild(routeNid).get()).getValue(); + } - @Mock - private DOMDataWriteTransaction tx; + private TablesKey getTablesKey() { + return new TablesKey(this.abstractRIBSupport.getAfi(), this.abstractRIBSupport.getSafi()); + } - @Test - public void testRouteAttributesIdentifier() { - assertEquals(new NodeIdentifier(QName.create(Ipv4Routes.QNAME, Attributes.QNAME.getLocalName())), this.testSupport.routeAttributesIdentifier()); + private InstanceIdentifier tablesIId() { + return RIB.child(Tables.class, getTablesKey()); } - @Test - public void testChangedRoutes() { - // TODO: + private InstanceIdentifier routesIId() { + final InstanceIdentifier tables = tablesIId(); + return tables.child(this.abstractRIBSupport.routesCaseClass(), this.abstractRIBSupport.routesContainerClass()); } + protected final YangInstanceIdentifier getTablePath() { + final InstanceIdentifier tables = tablesIId(); + return this.adapter.currentSerializer().toYangInstanceIdentifier(tables); + } - @Test - public void testRoutePath() { - final YangInstanceIdentifier routePath = YangInstanceIdentifier.of(Routes.QNAME); - final NodeIdentifier routeId = new NodeIdentifier(Ipv4Route.QNAME); - final String result = "/(urn:opendaylight:params:xml:ns:yang:bgp-rib?revision=2013-09-25)routes/(urn:opendaylight:params:xml:ns:yang:bgp-inet?revision=2015-03-05)ipv4-routes/ipv4-route"; - assertEquals(result, this.testSupport.routePath(routePath, routeId).toString()); + protected final YangInstanceIdentifier getRoutePath() { + final InstanceIdentifier routesIId = routesIId(); + return this.adapter.currentSerializer().toYangInstanceIdentifier(routesIId).node(getRouteListQname()); } - @Test - public void testDeleteRoutes() { - final ContainerNode advertised = ImmutableContainerNodeBuilder.create().addChild(this.choiceNode).withNodeIdentifier(new NodeIdentifier(WithdrawnRoutes.QNAME)).build(); - final ContainerNode nlri = ImmutableContainerNodeBuilder.create().addChild(advertised).withNodeIdentifier(new NodeIdentifier(Nlri.QNAME)).build(); - this.testSupport.deleteRoutes(null, null, nlri); - assertEquals(dest, this.destination); + private QName getRouteListQname() { + return BindingReflections.findQName(this.abstractRIBSupport.routesListClass()) + .bindTo(BindingReflections.getQNameModule(this.abstractRIBSupport.routesCaseClass())); } - @Test - public void testPutRoutes() { - final ContainerNode advertised = ImmutableContainerNodeBuilder.create().addChild(this.choiceNode).withNodeIdentifier(new NodeIdentifier(AdvertizedRoutes.QNAME)).build(); - final ContainerNode nlri = ImmutableContainerNodeBuilder.create().addChild(advertised).withNodeIdentifier(new NodeIdentifier(Nlri.QNAME)).build(); - this.testSupport.putRoutes(null, null, nlri, null); - assertEquals(dest, this.destination); + protected final NodeIdentifierWithPredicates createRouteNIWP(final S routes) { + final Collection map = createRoutes(routes); + return Iterables.getOnlyElement(map).getIdentifier(); } }