import java.util.Map.Entry;
import java.util.concurrent.Future;
+import org.opendaylight.controller.md.statistics.manager.MultipartMessageManager.StatsRequestType;
import org.opendaylight.controller.sal.binding.api.data.DataModificationTransaction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.transaction.rev131103.TransactionAware;
import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.transaction.rev131103.TransactionId;
import com.google.common.base.Preconditions;
import com.google.common.util.concurrent.Futures;
import com.google.common.util.concurrent.JdkFutureAdapters;
-import com.google.common.util.concurrent.ListenableFuture;
abstract class AbstractStatsTracker<I, K> {
private static final Function<RpcResult<? extends TransactionAware>, TransactionId> FUNCTION =
return context.getNodeIdentifier();
}
- protected static final <T extends TransactionAware> ListenableFuture<TransactionId> requestHelper(Future<RpcResult<T>> future) {
- return Futures.transform(JdkFutureAdapters.listenInPoolThread(future), FUNCTION);
+ protected final <T extends TransactionAware> void requestHelper(Future<RpcResult<T>> future, StatsRequestType type) {
+ context.registerTransaction(Futures.transform(JdkFutureAdapters.listenInPoolThread(future), FUNCTION), type);
+ }
+
+ protected final DataModificationTransaction startTransaction() {
+ return context.startDataModification();
}
protected abstract void cleanupSingleStat(DataModificationTransaction trans, K item);
public final synchronized void updateStats(List<I> list) {
final Long expiryTime = System.nanoTime() + lifetimeNanos;
- final DataModificationTransaction trans = context.startDataModification();
+ final DataModificationTransaction trans = startTransaction();
for (final I item : list) {
trackedItems.put(updateSingleStat(trans, item), expiryTime);