Rename DOMDataTreeCommitCohortRegistry to CommitCohortExtension 48/109848/5
authorRobert Varga <robert.varga@pantheon.tech>
Thu, 18 Jan 2024 19:27:33 +0000 (20:27 +0100)
committerRobert Varga <robert.varga@pantheon.tech>
Thu, 18 Jan 2024 20:43:12 +0000 (21:43 +0100)
This is a well-known extension, co-locate it with DOMDataBroker, so it
is near at hand.

JIRA: MDSAL-841
Change-Id: Idf71920640e4c9dc1a8e76d8bf3d4a7ac7b5fd40
Signed-off-by: Robert Varga <robert.varga@pantheon.tech>
binding/mdsal-binding-dom-adapter/src/main/java/org/opendaylight/mdsal/binding/dom/adapter/BindingDOMDataTreeCommitCohortRegistryAdapter.java
binding/mdsal-binding-dom-adapter/src/test/java/org/opendaylight/mdsal/binding/dom/adapter/BindingDOMDataTreeCommitCohortRegistryAdapterTest.java
dom/mdsal-dom-api/src/main/java/org/opendaylight/mdsal/dom/api/DOMDataBroker.java
dom/mdsal-dom-api/src/main/java/org/opendaylight/mdsal/dom/api/DOMDataTreeCommitCohort.java
dom/mdsal-dom-api/src/main/java/org/opendaylight/mdsal/dom/api/DOMDataTreeCommitCohortRegistry.java [deleted file]
dom/mdsal-dom-spi/src/main/java/org/opendaylight/mdsal/dom/spi/AbstractDOMDataBroker.java

index c31e30463fadee3ec271da875593afeb4ff505c7..2c25a6c9f0a545260dd0b1ae80ebcefc4312b904 100644 (file)
@@ -10,16 +10,15 @@ package org.opendaylight.mdsal.binding.dom.adapter;
 import org.opendaylight.mdsal.binding.api.DataTreeCommitCohort;
 import org.opendaylight.mdsal.binding.api.DataTreeCommitCohortRegistry;
 import org.opendaylight.mdsal.binding.api.DataTreeIdentifier;
-import org.opendaylight.mdsal.dom.api.DOMDataTreeCommitCohortRegistry;
+import org.opendaylight.mdsal.dom.api.DOMDataBroker.CommitCohortExtension;
 import org.opendaylight.yangtools.concepts.Registration;
 import org.opendaylight.yangtools.yang.binding.Augmentation;
 import org.opendaylight.yangtools.yang.binding.DataObject;
 
 final class BindingDOMDataTreeCommitCohortRegistryAdapter
-        extends AbstractBindingAdapter<DOMDataTreeCommitCohortRegistry> implements DataTreeCommitCohortRegistry {
-    BindingDOMDataTreeCommitCohortRegistryAdapter(final AdapterContext codec,
-            final DOMDataTreeCommitCohortRegistry registry) {
-        super(codec, registry);
+        extends AbstractBindingAdapter<CommitCohortExtension> implements DataTreeCommitCohortRegistry {
+    BindingDOMDataTreeCommitCohortRegistryAdapter(final AdapterContext codec, final CommitCohortExtension extension) {
+        super(codec, extension);
     }
 
     @Override
index 02824349d08bc6b83ce8f3a4c3ace68e8ef378da..a07bb76542922d43a8197592161867281a4e0989 100644 (file)
@@ -20,7 +20,7 @@ import org.opendaylight.mdsal.binding.api.DataTreeCommitCohort;
 import org.opendaylight.mdsal.binding.api.DataTreeIdentifier;
 import org.opendaylight.mdsal.binding.dom.adapter.test.util.BindingBrokerTestFactory;
 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
-import org.opendaylight.mdsal.dom.api.DOMDataTreeCommitCohortRegistry;
+import org.opendaylight.mdsal.dom.api.DOMDataBroker.CommitCohortExtension;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.mdsal.test.binding.rev140701.Top;
 import org.opendaylight.yangtools.concepts.Registration;
 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
@@ -28,7 +28,7 @@ import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
 @ExtendWith(MockitoExtension.class)
 public class BindingDOMDataTreeCommitCohortRegistryAdapterTest {
     @Mock
-    private DOMDataTreeCommitCohortRegistry cohortRegistry;
+    private CommitCohortExtension cohortExtension;
     @Mock
     private Registration cohortRegistration;
     @Mock
@@ -41,10 +41,10 @@ public class BindingDOMDataTreeCommitCohortRegistryAdapterTest {
         final var bindingTestContext = bindingBrokerTestFactory.getTestContext();
         bindingTestContext.start();
 
-        doReturn(cohortRegistration).when(cohortRegistry).registerCommitCohort(any(), any());
+        doReturn(cohortRegistration).when(cohortExtension).registerCommitCohort(any(), any());
         doNothing().when(cohortRegistration).close();
         final var registryAdapter = new BindingDOMDataTreeCommitCohortRegistryAdapter(bindingTestContext.getCodec(),
-            cohortRegistry);
+            cohortExtension);
 
         final var dataTreeIdentifier = DataTreeIdentifier.of(LogicalDatastoreType.CONFIGURATION,
                 InstanceIdentifier.create(Top.class));
index a81b1a5bcf249c684b996af98073ad3a730625d3..6654fbdab5bd3fd46df5784281325e4c191b4759 100644 (file)
@@ -7,7 +7,8 @@
  */
 package org.opendaylight.mdsal.dom.api;
 
-import org.eclipse.jdt.annotation.NonNull;
+import org.eclipse.jdt.annotation.NonNullByDefault;
+import org.opendaylight.yangtools.concepts.Registration;
 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
 
 /**
@@ -41,6 +42,7 @@ import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
  * <b>Implementation Note:</b> This interface is not intended to be implemented by users of MD-SAL,
  * but only to be consumed by them.
  */
+@NonNullByDefault
 public interface DOMDataBroker extends DOMService<DOMDataBroker, DOMDataBroker.Extension>, DOMTransactionFactory {
     /**
      * Type capture of a {@link DOMService.Extension} applicable to {@link DOMDataBroker} implementations.
@@ -55,7 +57,7 @@ public interface DOMDataBroker extends DOMService<DOMDataBroker, DOMDataBroker.E
      *
      * @return A new transaction chain.
      */
-    @NonNull DOMTransactionChain createTransactionChain();
+    DOMTransactionChain createTransactionChain();
 
     /**
      * Create a new transaction chain. The chain will be initialized to read from its backing datastore, with
@@ -73,5 +75,22 @@ public interface DOMDataBroker extends DOMService<DOMDataBroker, DOMDataBroker.E
      *
      * @return A new transaction chain.
      */
-    @NonNull DOMTransactionChain createMergingTransactionChain();
+    DOMTransactionChain createMergingTransactionChain();
+
+    /**
+     * Optional support for allowing a {@link DOMDataTreeCommitCohort} to participate in the process of committing
+     * {@link DOMDataTreeWriteTransaction}s.
+     */
+    interface CommitCohortExtension extends Extension {
+        /**
+         * Register commit cohort which will participate in three-phase commit protocols of
+         * {@link DOMDataTreeWriteTransaction} in data broker associated with this instance of extension.
+         *
+         * @param path Subtree path on which commit cohort operates.
+         * @param cohort A {@link DOMDataTreeCommitCohort}
+         * @return A {@link Registration}
+         * @throws NullPointerException if any argument is {@code null}
+         */
+        Registration registerCommitCohort(DOMDataTreeIdentifier path, DOMDataTreeCommitCohort cohort);
+    }
 }
index cbe61124886a12cda4b506384e5042c30c7ae822..b7f202f88a8950eab33e3af9cf00a702e151d379 100644 (file)
@@ -15,52 +15,50 @@ import java.util.Collection;
 import org.eclipse.jdt.annotation.NonNull;
 import org.opendaylight.mdsal.common.api.DataValidationFailedException;
 import org.opendaylight.mdsal.common.api.PostCanCommitStep;
+import org.opendaylight.mdsal.common.api.PostPreCommitStep;
+import org.opendaylight.mdsal.dom.api.DOMDataBroker.CommitCohortExtension;
 import org.opendaylight.yangtools.util.concurrent.ExceptionMapper;
 import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext;
 
 /**
- * Commit cohort participating in commit of data modification, which can validate data tree
- * modifications, with option to reject supplied modification, and with callbacks describing state
- * of commit.
+ * Commit cohort participating in commit of data modification, which can validate data tree modifications, with option
+ * to reject supplied modification, and with callbacks describing state of commit.
  *
  * <h2>Performance implications</h2>
- * {@link DOMDataTreeCommitCohort}s are hooked up into commit of data tree changes and MAY
- * negatively affect performance of data broker / store.
- * Implementations of this interface are discouraged, unless you really need ability to veto data
- * tree changes, or to provide external state change in sync with visibility of committed data.
+ * {@link DOMDataTreeCommitCohort}s are hooked up into commit of data tree changes and MAY negatively affect performance
+ * of data broker / store. Implementations of this interface are discouraged, unless you really need ability to veto
+ * data tree changes, or to provide external state change in sync with visibility of committed data.
  *
  * <h2>Implementation requirements</h2>
- * <h3>Correctness assumptions</h3> Implementation SHOULD use only the {@link DOMDataTreeCandidate} instances and
- * provided {@link EffectiveModelContext} for validation purposes.
- * Use of any other external mutable state is discouraged, implementation MUST NOT use any
- * transaction related APIs on same data broker / data store instance during invocation of
- * callbacks, except ones provided as argument. Note that this MAY BE enforced by some
- * implementations of {@link DOMDataBroker} or DOMDataCommitCoordinator
- * Note that this may be enforced by some implementations of {@link DOMDataTreeCommitCohortRegistry}
- * and such calls may fail.
- * <h3>Correct model usage</h3> If implementation is performing YANG-model driven validation
- * implementation SHOULD use provided schema context.
- * Any other instance of {@link EffectiveModelContext} obtained by other means, may not be valid for the
- * associated DOMDataTreeCandidates and it may lead to incorrect validation or processing of provided
- * data.
- * <h3>DataTreeCandidate assumptions</h3> Implementation SHOULD NOT make any assumptions on a
- * {@link DOMDataTreeCandidate} being successfully committed until associated
- * {@link PostCanCommitStep#preCommit()} and
- * {@link org.opendaylight.mdsal.common.api.PostPreCommitStep#commit()} callback was invoked.
+ * <h3>Correctness assumptions</h3>
+ * Implementation SHOULD use only the {@link DOMDataTreeCandidate} instances and provided {@link EffectiveModelContext}
+ * for validation purposes.
+ *
+ * <p>
+ * Use of any other external mutable state is discouraged, implementation MUST NOT use any transaction related APIs on
+ * the same data broker / data store instance during invocation of callbacks, except ones provided as argument. Note
+ * that this MAY BE enforced by some implementations of {@link DOMDataBroker} or {@link CommitCohortExtension},
+ * potentially enforced through the extension and such calls may fail.
+ *
+ * <h3>Correct model usage</h3>
+ * If implementation is performing YANG-model driven validation implementation SHOULD use provided schema context. Any
+ * other instance of {@link EffectiveModelContext} obtained by other means, may not be valid for the associated
+ * {@link DOMDataTreeCandidate}s and it may lead to incorrect validation or processing of provided data.
+ *
+ * <h3>DataTreeCandidate assumptions</h3>
+ * Implementation SHOULD NOT make any assumptions on a {@link DOMDataTreeCandidate} being successfully committed until
+ * the associated {@link PostCanCommitStep#preCommit()} and {@link PostPreCommitStep#commit()} callback was invoked.
+ *
  * <h2>Usage patterns</h2>
  * <h3>Data Tree Validator</h3>
- * Validator is implementation, which only validates {@link DOMDataTreeCandidate} instances and does not
- * retain any state derived from edited data - does not care if a {@link DOMDataTreeCandidate} was
- * rejected afterwards or transaction was cancelled.
- * Implementation may opt-out from receiving {@code preCommit()}, {@code commit()}, {@code abort()}
- * callbacks by returning {@link PostCanCommitStep#NOOP}.
- *
- * @author Tony Tkacik
+ * Validator is implementation, which only validates {@link DOMDataTreeCandidate} instances and does not retain any
+ * state derived from edited data - does not care if a {@link DOMDataTreeCandidate} was rejected afterwards or
+ * the transaction was cancelled. Implementation may opt-out from receiving {@code preCommit()}, {@code commit()},
+ * {@code abort()} callbacks by returning {@link PostCanCommitStep#NOOP}.
  */
 // TODO: Provide example and describe more usage patterns
 @Beta
 public interface DOMDataTreeCommitCohort {
-
     /**
      * Validates the supplied data tree modifications and associates the cohort-specific steps with data broker
      * transaction.
@@ -73,7 +71,7 @@ public interface DOMDataTreeCommitCohort {
      * Note the implementations are expected to do validation and processing asynchronous. Implementations SHOULD do
      * processing fast, and are discouraged from blocking on any external resources. Implementation MUST NOT access
      * any data transaction related APIs during invocation of the callback. Note that this may be enforced by some
-     * implementations of {@link DOMDataTreeCommitCohortRegistry} and such calls may fail.
+     * implementations of {@link CommitCohortExtension} and such calls may fail.
      *
      * <p>
      * Implementation MAY opt-out from implementing other steps by returning
diff --git a/dom/mdsal-dom-api/src/main/java/org/opendaylight/mdsal/dom/api/DOMDataTreeCommitCohortRegistry.java b/dom/mdsal-dom-api/src/main/java/org/opendaylight/mdsal/dom/api/DOMDataTreeCommitCohortRegistry.java
deleted file mode 100644 (file)
index 90f9251..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (c) 2015 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,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.mdsal.dom.api;
-
-import org.eclipse.jdt.annotation.NonNullByDefault;
-import org.opendaylight.yangtools.concepts.Registration;
-
-/**
- * Commit Cohort registry for {@link DOMDataTreeWriteTransaction}. See {@link DOMDataTreeCommitCohort} for more details.
- */
-@NonNullByDefault
-public interface DOMDataTreeCommitCohortRegistry extends DOMDataBroker.Extension {
-    /**
-     * Register commit cohort which will participate in three-phase commit protocols of
-     * {@link DOMDataTreeWriteTransaction} in data broker associated with this instance of extension.
-     *
-     * @param path Subtree path on which commit cohort operates.
-     * @param cohort Commit cohort
-     * @return A {@link Registration}
-     * @throws NullPointerException if any argument is {@code null}
-     */
-    Registration registerCommitCohort(DOMDataTreeIdentifier path, DOMDataTreeCommitCohort cohort);
-}
\ No newline at end of file
index a06d63febeddfe408c39892e7aec3cacbcb11c60..92144cd0688ecdb8fcf2eae82a3cb26b86a3846f 100644 (file)
@@ -15,7 +15,6 @@ import java.util.concurrent.atomic.AtomicLong;
 import org.eclipse.jdt.annotation.NonNull;
 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
 import org.opendaylight.mdsal.dom.api.DOMDataTreeChangeService;
-import org.opendaylight.mdsal.dom.api.DOMDataTreeCommitCohortRegistry;
 import org.opendaylight.mdsal.dom.api.DOMTransactionChain;
 import org.opendaylight.mdsal.dom.spi.store.DOMStore;
 import org.opendaylight.mdsal.dom.spi.store.DOMStoreTransactionChain;
@@ -44,11 +43,11 @@ public abstract class AbstractDOMDataBroker extends AbstractDOMForwardedTransact
                 throw new IllegalStateException("Publisher for " + dsType + " data store is not available");
             });
         }
-        if (isSupported(datastores, DOMDataTreeCommitCohortRegistry.class)) {
-            builder.add((DOMDataTreeCommitCohortRegistry) (path, cohort) -> {
+        if (isSupported(datastores, CommitCohortExtension.class)) {
+            builder.add((CommitCohortExtension) (path, cohort) -> {
                 final var dsType = path.datastore();
-                if (getTxFactories().get(dsType) instanceof DOMDataTreeCommitCohortRegistry registry) {
-                    return registry.registerCommitCohort(path, cohort);
+                if (getTxFactories().get(dsType) instanceof CommitCohortExtension extension) {
+                    return extension.registerCommitCohort(path, cohort);
                 }
                 throw new IllegalStateException("Cohort registry for " + dsType + " data store is not available");
             });