test: ensure that no percolate request are executed when stopping a node

This commit is contained in:
Martijn van Groningen 2016-01-13 15:45:13 +01:00
parent b7cb04cbf4
commit a7a45cd941
1 changed files with 24 additions and 5 deletions

View File

@ -38,6 +38,8 @@ import org.elasticsearch.test.ESIntegTestCase.Scope;
import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicReference; import java.util.concurrent.atomic.AtomicReference;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
import java.util.function.Predicate; import java.util.function.Predicate;
import static org.elasticsearch.action.percolate.PercolateSourceBuilder.docBuilder; import static org.elasticsearch.action.percolate.PercolateSourceBuilder.docBuilder;
@ -249,6 +251,7 @@ public class RecoveryPercolatorIT extends ESIntegTestCase {
.setSource(document) .setSource(document)
.get(); .get();
final Lock lock = new ReentrantLock();
final AtomicBoolean run = new AtomicBoolean(true); final AtomicBoolean run = new AtomicBoolean(true);
final AtomicReference<Throwable> error = new AtomicReference<>(); final AtomicReference<Throwable> error = new AtomicReference<>();
Runnable r = () -> { Runnable r = () -> {
@ -261,7 +264,13 @@ public class RecoveryPercolatorIT extends ESIntegTestCase {
} else { } else {
percolateBuilder.setGetRequest(Requests.getRequest("test").type("type").id("1")); percolateBuilder.setGetRequest(Requests.getRequest("test").type("type").id("1"));
} }
PercolateResponse response = percolateBuilder.get(); PercolateResponse response;
try {
lock.lock();
response = percolateBuilder.get();
} finally {
lock.unlock();
}
assertNoFailures(response); assertNoFailures(response);
assertThat(response.getSuccessfulShards(), equalTo(response.getTotalShards())); assertThat(response.getSuccessfulShards(), equalTo(response.getTotalShards()));
assertThat(response.getCount(), equalTo((long) numQueries)); assertThat(response.getCount(), equalTo((long) numQueries));
@ -279,7 +288,12 @@ public class RecoveryPercolatorIT extends ESIntegTestCase {
try { try {
// 1 index, 2 primaries, 2 replicas per primary // 1 index, 2 primaries, 2 replicas per primary
for (int i = 0; i < 4; i++) { for (int i = 0; i < 4; i++) {
try {
lock.lock();
internalCluster().stopRandomNode(nodePredicate); internalCluster().stopRandomNode(nodePredicate);
} finally {
lock.unlock();
}
client.admin().cluster().prepareHealth("test") client.admin().cluster().prepareHealth("test")
.setWaitForEvents(Priority.LANGUID) .setWaitForEvents(Priority.LANGUID)
.setTimeout(TimeValue.timeValueMinutes(2)) .setTimeout(TimeValue.timeValueMinutes(2))
@ -287,7 +301,12 @@ public class RecoveryPercolatorIT extends ESIntegTestCase {
.setWaitForActiveShards(4) // 2 nodes, so 4 shards (2 primaries, 2 replicas) .setWaitForActiveShards(4) // 2 nodes, so 4 shards (2 primaries, 2 replicas)
.get(); .get();
assertThat(error.get(), nullValue()); assertThat(error.get(), nullValue());
try {
lock.lock();
internalCluster().stopRandomNode(nodePredicate); internalCluster().stopRandomNode(nodePredicate);
} finally {
lock.unlock();
}
client.admin().cluster().prepareHealth("test") client.admin().cluster().prepareHealth("test")
.setWaitForEvents(Priority.LANGUID) .setWaitForEvents(Priority.LANGUID)
.setTimeout(TimeValue.timeValueMinutes(2)) .setTimeout(TimeValue.timeValueMinutes(2))
@ -295,7 +314,7 @@ public class RecoveryPercolatorIT extends ESIntegTestCase {
.setWaitForActiveShards(2) // 1 node, so 2 shards (2 primaries, 0 replicas) .setWaitForActiveShards(2) // 1 node, so 2 shards (2 primaries, 0 replicas)
.get(); .get();
assertThat(error.get(), nullValue()); assertThat(error.get(), nullValue());
internalCluster().startNode(); internalCluster().startNode(settingsBuilder().put("node.stay", false));
client.admin().cluster().prepareHealth("test") client.admin().cluster().prepareHealth("test")
.setWaitForEvents(Priority.LANGUID) .setWaitForEvents(Priority.LANGUID)
.setTimeout(TimeValue.timeValueMinutes(2)) .setTimeout(TimeValue.timeValueMinutes(2))
@ -303,7 +322,7 @@ public class RecoveryPercolatorIT extends ESIntegTestCase {
.setWaitForActiveShards(4) // 2 nodes, so 4 shards (2 primaries, 2 replicas) .setWaitForActiveShards(4) // 2 nodes, so 4 shards (2 primaries, 2 replicas)
.get(); .get();
assertThat(error.get(), nullValue()); assertThat(error.get(), nullValue());
internalCluster().startNode(); internalCluster().startNode(settingsBuilder().put("node.stay", false));
client.admin().cluster().prepareHealth("test") client.admin().cluster().prepareHealth("test")
.setWaitForEvents(Priority.LANGUID) .setWaitForEvents(Priority.LANGUID)
.setTimeout(TimeValue.timeValueMinutes(2)) .setTimeout(TimeValue.timeValueMinutes(2))