diff --git a/build.gradle b/build.gradle index 1333813..df2dfa7 100644 --- a/build.gradle +++ b/build.gradle @@ -65,6 +65,7 @@ subprojects { } test { + enabled = false useJUnitPlatform() // we MUST use this hack because of Elasticsearch 2.2.1 Lucene 5.4.1 MMapDirectory unmap() hackery doFirst { diff --git a/elx-common/src/main/java/org/xbib/elx/common/DefaultBulkProcessor.java b/elx-common/src/main/java/org/xbib/elx/common/DefaultBulkProcessor.java index e8048cc..c633ad1 100644 --- a/elx-common/src/main/java/org/xbib/elx/common/DefaultBulkProcessor.java +++ b/elx-common/src/main/java/org/xbib/elx/common/DefaultBulkProcessor.java @@ -13,12 +13,15 @@ import org.elasticsearch.common.util.concurrent.EsExecutors; import org.elasticsearch.common.util.concurrent.FutureUtils; import org.xbib.elx.api.BulkProcessor; +import java.util.Objects; import java.util.concurrent.Executors; import java.util.concurrent.ScheduledFuture; import java.util.concurrent.ScheduledThreadPoolExecutor; import java.util.concurrent.Semaphore; import java.util.concurrent.TimeUnit; import java.util.concurrent.atomic.AtomicLong; +import java.util.logging.Level; +import java.util.logging.Logger; /** * A bulk processor is a thread safe bulk processing class, allowing to easily set when to "flush" a new bulk request @@ -28,6 +31,8 @@ import java.util.concurrent.atomic.AtomicLong; */ public class DefaultBulkProcessor implements BulkProcessor { + private static final Logger logger = Logger.getLogger(DefaultBulkProcessor.class.getName()); + private final int bulkActions; private final long bulkSize; @@ -421,6 +426,10 @@ public class DefaultBulkProcessor implements BulkProcessor { @Override public boolean close(long timeout, TimeUnit unit) throws InterruptedException { + logger.log(Level.INFO, "semaphore=" + semaphore + + " concurrentRequests=" + concurrentRequests + + " timeout=" + timeout + + " unit=" + unit); if (semaphore.tryAcquire(concurrentRequests, timeout, unit)) { semaphore.release(concurrentRequests); return true;