X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatabroker%2Factors%2Fdds%2FAbstractClientHandle.java;h=d10627dcf93e065df03c5f5130da50303d9ecc79;hb=99f80f27bee37bb23e345420bf14bb7bb4793c28;hp=90971b31cece3b7718e830b6a59014405d0d8a7b;hpb=d502ae8e1529b69af55a59c3e664a02457c05ec6;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/actors/dds/AbstractClientHandle.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/actors/dds/AbstractClientHandle.java index 90971b31ce..d10627dcf9 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/actors/dds/AbstractClientHandle.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/actors/dds/AbstractClientHandle.java @@ -12,9 +12,10 @@ import static java.util.Objects.requireNonNull; import com.google.common.annotations.Beta; import com.google.common.base.MoreObjects; -import java.util.Collection; +import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.atomic.AtomicReferenceFieldUpdater; +import java.util.stream.Stream; import org.eclipse.jdt.annotation.NonNull; import org.eclipse.jdt.annotation.Nullable; import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier; @@ -55,6 +56,7 @@ public abstract class AbstractClientHandle e } @Override + // Non-final for mocking public TransactionIdentifier getIdentifier() { return transactionId; } @@ -64,6 +66,7 @@ public abstract class AbstractClientHandle e * * @return True if this transaction became closed during this call */ + // Non-final for mocking public boolean abort() { if (commonAbort()) { parent.onTransactionAbort(this); @@ -74,12 +77,13 @@ public abstract class AbstractClientHandle e } private boolean commonAbort() { - final Collection toClose = ensureClosed(); + final Map toClose = ensureClosed(); if (toClose == null) { return false; } - toClose.forEach(AbstractProxyTransaction::abort); + toClose.values().forEach(AbstractProxyTransaction::abort); + parent.onTransactionShardsBound(transactionId, toClose.keySet()); return true; } @@ -93,21 +97,27 @@ public abstract class AbstractClientHandle e * Make sure this snapshot is closed. If it became closed as the effect of this call, return a collection of * {@link AbstractProxyTransaction} handles which need to be closed, too. * - * @return null if this snapshot has already been closed, otherwise a collection of proxies, which need to be + * @return null if this snapshot has already been closed, otherwise a State with of proxies, which need to be * closed, too. */ - final @Nullable Collection ensureClosed() { + final @Nullable Map ensureClosed() { // volatile read and a conditional CAS. This ends up being better in the typical case when we are invoked more // than once (see ClientBackedTransaction) than performing a STATE_UPDATER.getAndSet(). final State local = state; - return local != null && STATE_UPDATER.compareAndSet(this, local, null) ? local.values() : null; + return local != null && STATE_UPDATER.compareAndSet(this, local, null) ? local : null; } final T ensureProxy(final YangInstanceIdentifier path) { - final State local = getState(); - final Long shard = parent.resolveShardForPath(path); + return ensureProxy(getState(), parent.resolveShardForPath(path)); + } + + private T ensureProxy(final State localState, final Long shard) { + return localState.computeIfAbsent(shard, this::createProxy); + } - return local.computeIfAbsent(shard, this::createProxy); + final Stream ensureAllProxies() { + final var local = getState(); + return parent.resolveAllShards().map(shard -> ensureProxy(local, shard)); } final AbstractClientHistory parent() {