package org.opendaylight.netvirt.elan.internal;
import com.google.common.util.concurrent.ListenableFuture;
-import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
-public class InterfaceRemoveWorkerOnElanInterface implements Callable<List<ListenableFuture<Void>>> {
+public class InterfaceRemoveWorkerOnElanInterface implements Callable<List<? extends ListenableFuture<?>>> {
private static final Logger LOG = LoggerFactory.getLogger(InterfaceRemoveWorkerOnElanInterface.class);
@Override
@SuppressWarnings("checkstyle:IllegalCatch")
public List<ListenableFuture<Void>> call() {
- List<ListenableFuture<Void>> futures = new ArrayList<>();
try {
- futures.addAll(dataChangeListener.removeEntriesForElanInterface(elanInfo, interfaceInfo, interfaceName,
- isLastElanInterface));
+ return dataChangeListener.removeEntriesForElanInterface(elanInfo, interfaceInfo, interfaceName,
+ isLastElanInterface);
} catch (RuntimeException e) {
- LOG.error("Error while processing for interface {} and elan {}", interfaceName, elanInfo, e);
- ElanUtils.addToListenableFutureIfTxException(e, futures);
+ return ElanUtils.returnFailedListenableFutureIfTransactionCommitFailedExceptionCauseOrElseThrow(e);
}
- return futures;
}
}