From 11380c5b8bc0d9831ed182ed758a74f66278df78 Mon Sep 17 00:00:00 2001 From: Robert Varga Date: Sun, 14 Dec 2014 19:32:13 +0100 Subject: [PATCH] BUG-2510: handle RPC route removal DOM to Binding forwarding ignored removals of RPC implementations. Add that case back. Change-Id: I7af1d8b43b9b229cc9a696cfdfc61146f960b374 Signed-off-by: Robert Varga --- .../dom/DomToBindingRpcForwardingManager.java | 26 +++++++++++-------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/sal/binding/impl/connect/dom/DomToBindingRpcForwardingManager.java b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/sal/binding/impl/connect/dom/DomToBindingRpcForwardingManager.java index 63d4b71210..b6bc488c20 100644 --- a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/sal/binding/impl/connect/dom/DomToBindingRpcForwardingManager.java +++ b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/sal/binding/impl/connect/dom/DomToBindingRpcForwardingManager.java @@ -1,9 +1,10 @@ package org.opendaylight.controller.sal.binding.impl.connect.dom; +import com.google.common.base.Optional; import java.util.Map; +import java.util.Map.Entry; import java.util.Set; import java.util.WeakHashMap; - import org.opendaylight.controller.md.sal.common.api.routing.RouteChange; import org.opendaylight.controller.md.sal.common.api.routing.RouteChangeListener; import org.opendaylight.controller.sal.binding.api.RpcProviderRegistry; @@ -18,8 +19,6 @@ import org.opendaylight.yangtools.yang.binding.RpcService; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.data.impl.codec.BindingIndependentMappingService; -import com.google.common.base.Optional; - /** * Manager responsible for instantiating forwarders responsible for * forwarding of RPC invocations from DOM Broker to Binding Aware Broker @@ -69,16 +68,21 @@ class DomToBindingRpcForwardingManager implements @Override public void onRouteChange(final RouteChange> change) { - for (Map.Entry>> entry : change.getAnnouncements().entrySet()) { - bindingRoutesAdded(entry); + // Process removals first + for (Entry>> entry : change.getRemovals().entrySet()) { + final Class context = entry.getKey().getRoutingContext(); + if (context != null) { + final Class service = entry.getKey().getRpcService(); + getRpcForwarder(service, context).removePaths(context, service, entry.getValue()); + } } - } - private void bindingRoutesAdded(final Map.Entry>> entry) { - Class context = entry.getKey().getRoutingContext(); - Class service = entry.getKey().getRpcService(); - if (context != null) { - getRpcForwarder(service, context).registerPaths(context, service, entry.getValue()); + for (Entry>> entry : change.getAnnouncements().entrySet()) { + final Class context = entry.getKey().getRoutingContext(); + if (context != null) { + final Class service = entry.getKey().getRpcService(); + getRpcForwarder(service, context).registerPaths(context, service, entry.getValue()); + } } } -- 2.36.6