From cb933b90991598867504635761e1a472fddf818b Mon Sep 17 00:00:00 2001 From: Robert Varga Date: Tue, 13 May 2014 13:52:10 +0200 Subject: [PATCH] BUG-981: Fixed incorrect condition in ResolveDataChangeEventsTask When we insert a new subtree, we need to make sure to call serialization on the entire, such that any new elements which appear have their classed attached to paths. This reuses a previous code path, which pruned the walk tree as soon as it encountered a node which did not have any listeners attached (thus improving performance when we're gathering listeners). In this specific case, though, this check is not correct: we need to walk the path because it may be placing new data in the subtree. At the same time add debug statements which made pinpointing this problem possible. Change-Id: I1687ba45817a84ea4a888496a90defc5896216c9 Signed-off-by: Tony Tkacik Signed-off-by: Robert Varga --- .../store/impl/ResolveDataChangeEventsTask.java | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/store/impl/ResolveDataChangeEventsTask.java b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/store/impl/ResolveDataChangeEventsTask.java index e74ba95891..44d50166af 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/store/impl/ResolveDataChangeEventsTask.java +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/md/sal/dom/store/impl/ResolveDataChangeEventsTask.java @@ -327,12 +327,12 @@ public class ResolveDataChangeEventsTask implements Callable listeners, final NormalizedNode beforeData, final NormalizedNode afterData) { - if (beforeData instanceof NormalizedNodeContainer && !listeners.isEmpty()) { + if (beforeData instanceof NormalizedNodeContainer) { // Node is container (contains child) and we have interested // listeners registered for it, that means we need to do // resolution of changes on children level and can not // shortcut resolution. - + LOG.trace("Resolving subtree replace event for {} before {}, after {}",path,beforeData,afterData); @SuppressWarnings("unchecked") NormalizedNodeContainer> beforeCont = (NormalizedNodeContainer>) beforeData; @SuppressWarnings("unchecked") @@ -342,7 +342,7 @@ public class ResolveDataChangeEventsTask implements Callable listeners, final NormalizedNode node, final SimpleEventFactory eventFactory) { - final DOMImmutableDataChangeEvent event = eventFactory.create(path, node); DOMImmutableDataChangeEvent propagateEvent = event; - // We have listeners for this node or it's children, so we will try + // We have listeners for this node or it's children, so we will try // to do additional processing if (node instanceof NormalizedNodeContainer) { + LOG.trace("Resolving subtree recursive event for {}, type {}", path, eventFactory); + Builder eventBuilder = builder(DataChangeScope.BASE); eventBuilder.merge(event); eventBuilder.setBefore(event.getOriginalSubtree()); @@ -464,6 +465,7 @@ public class ResolveDataChangeEventsTask implements Callable> container = (NormalizedNodeContainer>) node; for (NormalizedNode child : container.getValue()) { PathArgument childId = child.getIdentifier(); + LOG.trace("Resolving event for child {}", childId); Collection childListeners = getListenerChildrenWildcarded(listeners, childId); eventBuilder.merge(resolveSameEventRecursivelly(append(path, childId), childListeners, child, eventFactory)); } @@ -473,7 +475,7 @@ public class ResolveDataChangeEventsTask implements Callable listeners, final DOMImmutableDataChangeEvent event) { - for (ListenerTree.Node listenerNode : listeners) { if (!listenerNode.getListeners().isEmpty()) { + LOG.trace("Adding event {} for listeners {}",event,listenerNode); events.put(listenerNode, event); } } -- 2.36.6