[TEST] randomly introduced a client node within test cluster
The default number of clients nodes is randomized between 0 and 1, applied to all cluster scopes (global, suite and test). Can be changed through the newly added `@ClusterScope#numClientNodes`. In our tests we currently refer to nodes in a generic way. All the tests that either stop or start nodes rely on the fact that those nodes hold data though. Made that clearer as that becomes more important when introducing other types of nodes within the test cluster. Reflected this by adapting and renaming the following methods in `TestCluster`: - ensureAtLeastNumNodes to ensureAtLeastNumDataNodes - ensureAtMostNumNodes to ensureAtMostNumDataNodes - stopRandomNode to stopRandomDataNode and the following ones in `ElasticsearchIntegrationTest`: - allowNodes to allowDataNodes - dataNodes to numDataNodes. - @ClusterScope#numNodes to numDataNodes - @ClusterScope#minNumNodes to minNumDataNodes - @ClusterScope#maxNumNodes to maxNumDataNodes Added facilities to be able to deal with data nodes specifically, like for instance retrieve a client to a data node, or retrieve an instance of a class through guice only from data nodes. Adapted existing tests to successfully run although there's a node client around. Fixed _cat/allocation REST tests to make disk.total, disk.avail and disk.percent optional as client nodes won't return that info. Closes #5949
This commit is contained in:
parent
17a5575757
commit
a414e4f2f3
|
@ -25,13 +25,13 @@
|
||||||
- match:
|
- match:
|
||||||
$body: >
|
$body: >
|
||||||
/^
|
/^
|
||||||
( 0 \s+
|
( 0 \s+
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
\d+(\.\d+)?[kmgt]?b \s+
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
(\d+(\.\d+)?[kmgt]b)? \s+ #no value from client nodes
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
(\d+(\.\d+)?[kmgt]b)? \s+ #no value from client nodes
|
||||||
\d+ \s+
|
(\d+)? \s+ #no value from client nodes
|
||||||
[-\w.]+ \s+
|
[-\w.]+ \s+
|
||||||
\d+(\.\d+){3} \s+
|
\d+(\.\d+){3} \s+
|
||||||
\w.*
|
\w.*
|
||||||
\n
|
\n
|
||||||
)+
|
)+
|
||||||
|
@ -55,19 +55,19 @@
|
||||||
- match:
|
- match:
|
||||||
$body: >
|
$body: >
|
||||||
/^
|
/^
|
||||||
( \d+ \s+
|
( \d+ \s+
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
\d+(\.\d+)?[kmgt]?b \s+
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
(\d+(\.\d+)?[kmgt]b)? \s+ #no value from client nodes
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
(\d+(\.\d+)?[kmgt]b)? \s+ #no value from client nodes
|
||||||
\d+ \s+
|
(\d+)? \s+ #no value from client nodes
|
||||||
[-\w.]+ \s+
|
[-\w.]+ \s+
|
||||||
\d+(\.\d+){3} \s+
|
\d+(\.\d+){3} \s+
|
||||||
\w.*
|
\w.*
|
||||||
\n
|
\n
|
||||||
)+
|
)+
|
||||||
(
|
(
|
||||||
\d+ \s+
|
\d+ \s+
|
||||||
UNASSIGNED \s+
|
UNASSIGNED \s+
|
||||||
\n
|
\n
|
||||||
)?
|
)?
|
||||||
$/
|
$/
|
||||||
|
@ -82,13 +82,13 @@
|
||||||
- match:
|
- match:
|
||||||
$body: >
|
$body: >
|
||||||
/^
|
/^
|
||||||
( 0 \s+
|
( 0 \s+
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
\d+(\.\d+)?[kmgt]?b \s+
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
(\d+(\.\d+)?[kmgt]b)? \s+ #no value from client nodes
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
(\d+(\.\d+)?[kmgt]b)? \s+ #no value from client nodes
|
||||||
\d+ \s+
|
(\d+)? \s+ #no value from client nodes
|
||||||
[-\w.]+ \s+
|
[-\w.]+ \s+
|
||||||
\d+(\.\d+){3} \s+
|
\d+(\.\d+){3} \s+
|
||||||
\w.*
|
\w.*
|
||||||
\n
|
\n
|
||||||
)
|
)
|
||||||
|
@ -112,23 +112,23 @@
|
||||||
- match:
|
- match:
|
||||||
|
|
||||||
$body: >
|
$body: >
|
||||||
/^ shards \s+
|
/^ shards \s+
|
||||||
disk.used \s+
|
disk.used \s+
|
||||||
disk.avail \s+
|
disk.avail \s+
|
||||||
disk.total \s+
|
disk.total \s+
|
||||||
disk.percent \s+
|
disk.percent \s+
|
||||||
host \s+
|
host \s+
|
||||||
ip \s+
|
ip \s+
|
||||||
node \s+
|
node \s+
|
||||||
\n
|
\n
|
||||||
|
|
||||||
( \s+0 \s+
|
( \s+0 \s+
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
\d+(\.\d+)?[kmgt]?b \s+
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
(\d+(\.\d+)?[kmgt]b)? \s+ #no value from client nodes
|
||||||
\d+(\.\d+)?[kmgt]b \s+
|
(\d+(\.\d+)?[kmgt]b)? \s+ #no value from client nodes
|
||||||
\d+ \s+
|
(\d+)? \s+ #no value from client nodes
|
||||||
[-\w.]+ \s+
|
[-\w.]+ \s+
|
||||||
\d+(\.\d+){3} \s+
|
\d+(\.\d+){3} \s+
|
||||||
\w.*
|
\w.*
|
||||||
\n
|
\n
|
||||||
)+
|
)+
|
||||||
|
@ -144,7 +144,7 @@
|
||||||
- match:
|
- match:
|
||||||
$body: >
|
$body: >
|
||||||
/^
|
/^
|
||||||
( \d+ \s+
|
( \d* \s+
|
||||||
\w.*
|
\w.*
|
||||||
\n
|
\n
|
||||||
)+
|
)+
|
||||||
|
@ -162,7 +162,7 @@
|
||||||
node \s+
|
node \s+
|
||||||
\n
|
\n
|
||||||
(
|
(
|
||||||
\s+\d+ \s+
|
\s+\d* \s+
|
||||||
\w.*
|
\w.*
|
||||||
\n
|
\n
|
||||||
)+
|
)+
|
||||||
|
@ -182,9 +182,9 @@
|
||||||
/^
|
/^
|
||||||
( 0 \s+
|
( 0 \s+
|
||||||
\d+ \s+
|
\d+ \s+
|
||||||
\d+ \s+
|
\d* \s+ #no value from client nodes
|
||||||
\d+ \s+
|
\d* \s+ #no value from client nodes
|
||||||
\d+ \s+
|
\d* \s+ #no value from client nodes
|
||||||
[-\w.]+ \s+
|
[-\w.]+ \s+
|
||||||
\d+(\.\d+){3} \s+
|
\d+(\.\d+){3} \s+
|
||||||
\w.*
|
\w.*
|
||||||
|
|
|
@ -31,9 +31,10 @@ import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
import org.hamcrest.Matchers;
|
import org.hamcrest.Matchers;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.SUITE, numNodes = 1)
|
@ClusterScope(scope = Scope.SUITE, numDataNodes = 1, numClientNodes = 0)
|
||||||
public class ClusterStatsTests extends ElasticsearchIntegrationTest {
|
public class ClusterStatsTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
private void assertCounts(ClusterStatsNodes.Counts counts, int total, int masterOnly, int dataOnly, int masterData, int client) {
|
private void assertCounts(ClusterStatsNodes.Counts counts, int total, int masterOnly, int dataOnly, int masterData, int client) {
|
||||||
|
@ -126,8 +127,8 @@ public class ClusterStatsTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testValuesSmokeScreen() {
|
public void testValuesSmokeScreen() {
|
||||||
cluster().ensureAtMostNumNodes(5);
|
cluster().ensureAtMostNumDataNodes(5);
|
||||||
cluster().ensureAtLeastNumNodes(1);
|
cluster().ensureAtLeastNumDataNodes(1);
|
||||||
SigarService sigarService = cluster().getInstance(SigarService.class);
|
SigarService sigarService = cluster().getInstance(SigarService.class);
|
||||||
index("test1", "type", "1", "f", "f");
|
index("test1", "type", "1", "f", "f");
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -25,12 +25,13 @@ import com.google.common.base.Predicate;
|
||||||
import org.elasticsearch.action.admin.indices.mapping.get.GetMappingsRequest;
|
import org.elasticsearch.action.admin.indices.mapping.get.GetMappingsRequest;
|
||||||
import org.elasticsearch.action.admin.indices.mapping.get.GetMappingsResponse;
|
import org.elasticsearch.action.admin.indices.mapping.get.GetMappingsResponse;
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
||||||
import static org.hamcrest.Matchers.*;
|
|
||||||
import static org.elasticsearch.common.io.Streams.copyToStringFromClasspath;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
@ElasticsearchIntegrationTest.ClusterScope(scope= ElasticsearchIntegrationTest.Scope.SUITE, numNodes=1)
|
import static org.elasticsearch.common.io.Streams.copyToStringFromClasspath;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
|
@ClusterScope(scope= Scope.SUITE, numDataNodes =1)
|
||||||
public class BulkIntegrationTests extends ElasticsearchIntegrationTest{
|
public class BulkIntegrationTests extends ElasticsearchIntegrationTest{
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -25,7 +25,9 @@ import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
import org.hamcrest.Matchers;
|
import org.hamcrest.Matchers;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0, transportClientRatio = 1.0)
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
|
|
||||||
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0, transportClientRatio = 1.0)
|
||||||
public class TransportClientTests extends ElasticsearchIntegrationTest {
|
public class TransportClientTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -44,12 +44,13 @@ import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class ClusterServiceTests extends ElasticsearchIntegrationTest {
|
public class ClusterServiceTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -36,9 +36,10 @@ import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import static org.elasticsearch.client.Requests.clusterHealthRequest;
|
import static org.elasticsearch.client.Requests.clusterHealthRequest;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes =0)
|
||||||
public class MinimumMasterNodesTests extends ElasticsearchIntegrationTest {
|
public class MinimumMasterNodesTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -276,7 +277,7 @@ public class MinimumMasterNodesTests extends ElasticsearchIntegrationTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("--> stopping a node");
|
logger.info("--> stopping a node");
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
logger.info("--> verifying min master node has effect");
|
logger.info("--> verifying min master node has effect");
|
||||||
assertNoMasterBlockOnAllNodes();
|
assertNoMasterBlockOnAllNodes();
|
||||||
|
|
||||||
|
|
|
@ -35,12 +35,13 @@ import org.junit.Test;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.greaterThan;
|
import static org.hamcrest.Matchers.greaterThan;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =0)
|
||||||
public class NoMasterNodeTests extends ElasticsearchIntegrationTest {
|
public class NoMasterNodeTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -61,7 +62,7 @@ public class NoMasterNodeTests extends ElasticsearchIntegrationTest {
|
||||||
cluster().startNode(settings);
|
cluster().startNode(settings);
|
||||||
createIndex("test");
|
createIndex("test");
|
||||||
client().admin().cluster().prepareHealth("test").setWaitForGreenStatus().execute().actionGet();
|
client().admin().cluster().prepareHealth("test").setWaitForGreenStatus().execute().actionGet();
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
assertThat(awaitBusy(new Predicate<Object>() {
|
assertThat(awaitBusy(new Predicate<Object>() {
|
||||||
public boolean apply(Object o) {
|
public boolean apply(Object o) {
|
||||||
ClusterState state = client().admin().cluster().prepareState().setLocal(true).execute().actionGet().getState();
|
ClusterState state = client().admin().cluster().prepareState().setLocal(true).execute().actionGet().getState();
|
||||||
|
|
|
@ -30,12 +30,13 @@ import org.junit.Test;
|
||||||
import static org.elasticsearch.client.Requests.createIndexRequest;
|
import static org.elasticsearch.client.Requests.createIndexRequest;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
import static org.elasticsearch.common.unit.TimeValue.timeValueSeconds;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =0)
|
||||||
public class SimpleDataNodesTests extends ElasticsearchIntegrationTest {
|
public class SimpleDataNodesTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -27,13 +27,14 @@ import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class SpecificMasterNodesTests extends ElasticsearchIntegrationTest {
|
public class SpecificMasterNodesTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
protected final ImmutableSettings.Builder settingsBuilder() {
|
protected final ImmutableSettings.Builder settingsBuilder() {
|
||||||
|
|
|
@ -29,11 +29,12 @@ import org.junit.Test;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =0)
|
||||||
public class UpdateSettingsValidationTests extends ElasticsearchIntegrationTest {
|
public class UpdateSettingsValidationTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -57,7 +57,7 @@ public class AckClusterUpdateSettingsTests extends ElasticsearchIntegrationTest
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected int minimumNumberOfShards() {
|
protected int minimumNumberOfShards() {
|
||||||
return immutableCluster().size();
|
return immutableCluster().numDataNodes();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -106,7 +106,7 @@ public class AckClusterUpdateSettingsTests extends ElasticsearchIntegrationTest
|
||||||
public void testClusterUpdateSettingsNoAcknowledgement() {
|
public void testClusterUpdateSettingsNoAcknowledgement() {
|
||||||
client().admin().indices().prepareCreate("test")
|
client().admin().indices().prepareCreate("test")
|
||||||
.setSettings(settingsBuilder()
|
.setSettings(settingsBuilder()
|
||||||
.put("number_of_shards", between(immutableCluster().dataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
.put("number_of_shards", between(immutableCluster().numDataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
||||||
.put("number_of_replicas", 0)).get();
|
.put("number_of_replicas", 0)).get();
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
|
|
||||||
|
|
|
@ -179,7 +179,7 @@ public class AckTests extends ElasticsearchIntegrationTest {
|
||||||
public void testClusterRerouteAcknowledgement() throws InterruptedException {
|
public void testClusterRerouteAcknowledgement() throws InterruptedException {
|
||||||
assertAcked(prepareCreate("test").setSettings(ImmutableSettings.builder()
|
assertAcked(prepareCreate("test").setSettings(ImmutableSettings.builder()
|
||||||
.put(indexSettings())
|
.put(indexSettings())
|
||||||
.put(SETTING_NUMBER_OF_SHARDS, between(immutableCluster().dataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
.put(SETTING_NUMBER_OF_SHARDS, between(immutableCluster().numDataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
||||||
.put(SETTING_NUMBER_OF_REPLICAS, 0)
|
.put(SETTING_NUMBER_OF_REPLICAS, 0)
|
||||||
));
|
));
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
|
@ -214,7 +214,7 @@ public class AckTests extends ElasticsearchIntegrationTest {
|
||||||
public void testClusterRerouteNoAcknowledgement() throws InterruptedException {
|
public void testClusterRerouteNoAcknowledgement() throws InterruptedException {
|
||||||
client().admin().indices().prepareCreate("test")
|
client().admin().indices().prepareCreate("test")
|
||||||
.setSettings(settingsBuilder()
|
.setSettings(settingsBuilder()
|
||||||
.put(SETTING_NUMBER_OF_SHARDS, between(immutableCluster().dataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
.put(SETTING_NUMBER_OF_SHARDS, between(immutableCluster().numDataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
||||||
.put(SETTING_NUMBER_OF_REPLICAS, 0)).get();
|
.put(SETTING_NUMBER_OF_REPLICAS, 0)).get();
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
|
|
||||||
|
@ -228,7 +228,7 @@ public class AckTests extends ElasticsearchIntegrationTest {
|
||||||
public void testClusterRerouteAcknowledgementDryRun() throws InterruptedException {
|
public void testClusterRerouteAcknowledgementDryRun() throws InterruptedException {
|
||||||
client().admin().indices().prepareCreate("test")
|
client().admin().indices().prepareCreate("test")
|
||||||
.setSettings(settingsBuilder()
|
.setSettings(settingsBuilder()
|
||||||
.put(SETTING_NUMBER_OF_SHARDS, between(immutableCluster().dataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
.put(SETTING_NUMBER_OF_SHARDS, between(immutableCluster().numDataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
||||||
.put(SETTING_NUMBER_OF_REPLICAS, 0)).get();
|
.put(SETTING_NUMBER_OF_REPLICAS, 0)).get();
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
|
|
||||||
|
@ -261,7 +261,7 @@ public class AckTests extends ElasticsearchIntegrationTest {
|
||||||
public void testClusterRerouteNoAcknowledgementDryRun() throws InterruptedException {
|
public void testClusterRerouteNoAcknowledgementDryRun() throws InterruptedException {
|
||||||
client().admin().indices().prepareCreate("test")
|
client().admin().indices().prepareCreate("test")
|
||||||
.setSettings(settingsBuilder()
|
.setSettings(settingsBuilder()
|
||||||
.put(SETTING_NUMBER_OF_SHARDS, between(immutableCluster().dataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
.put(SETTING_NUMBER_OF_SHARDS, between(immutableCluster().numDataNodes(), DEFAULT_MAX_NUM_SHARDS))
|
||||||
.put(SETTING_NUMBER_OF_REPLICAS, 0)).get();
|
.put(SETTING_NUMBER_OF_REPLICAS, 0)).get();
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
|
|
||||||
|
|
|
@ -45,7 +45,7 @@ import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numDataNodes =0)
|
||||||
public class AwarenessAllocationTests extends ElasticsearchIntegrationTest {
|
public class AwarenessAllocationTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
private final ESLogger logger = Loggers.getLogger(AwarenessAllocationTests.class);
|
private final ESLogger logger = Loggers.getLogger(AwarenessAllocationTests.class);
|
||||||
|
|
|
@ -47,11 +47,12 @@ import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class ClusterRerouteTests extends ElasticsearchIntegrationTest {
|
public class ClusterRerouteTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
private final ESLogger logger = Loggers.getLogger(ClusterRerouteTests.class);
|
private final ESLogger logger = Loggers.getLogger(ClusterRerouteTests.class);
|
||||||
|
|
|
@ -34,9 +34,10 @@ import org.junit.Test;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =0)
|
||||||
public class FilteringAllocationTests extends ElasticsearchIntegrationTest {
|
public class FilteringAllocationTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
private final ESLogger logger = Loggers.getLogger(FilteringAllocationTests.class);
|
private final ESLogger logger = Loggers.getLogger(FilteringAllocationTests.class);
|
||||||
|
|
|
@ -29,12 +29,12 @@ import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.instanceOf;
|
import static org.hamcrest.Matchers.instanceOf;
|
||||||
|
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =0)
|
||||||
public class ShardsAllocatorModuleTests extends ElasticsearchIntegrationTest {
|
public class ShardsAllocatorModuleTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
|
|
||||||
public void testLoadDefaultShardsAllocator() {
|
public void testLoadDefaultShardsAllocator() {
|
||||||
assertAllocatorInstance(ImmutableSettings.Builder.EMPTY_SETTINGS, BalancedShardsAllocator.class);
|
assertAllocatorInstance(ImmutableSettings.Builder.EMPTY_SETTINGS, BalancedShardsAllocator.class);
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@ public class ShardsAllocatorModuleTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
private void assertAllocatorInstance(Settings settings, Class<? extends ShardsAllocator> clazz) {
|
private void assertAllocatorInstance(Settings settings, Class<? extends ShardsAllocator> clazz) {
|
||||||
while (immutableCluster().size() != 0) {
|
while (immutableCluster().size() != 0) {
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
}
|
}
|
||||||
cluster().startNode(settings);
|
cluster().startNode(settings);
|
||||||
ShardsAllocator instance = cluster().getInstance(ShardsAllocator.class);
|
ShardsAllocator instance = cluster().getInstance(ShardsAllocator.class);
|
||||||
|
|
|
@ -28,11 +28,12 @@ import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.SUITE, numNodes=2)
|
@ClusterScope(scope= Scope.SUITE, numDataNodes =2)
|
||||||
public class ClusterSearchShardsTests extends ElasticsearchIntegrationTest {
|
public class ClusterSearchShardsTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -44,7 +44,7 @@ import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= Scope.SUITE, numNodes=0)
|
@ClusterScope(scope= Scope.SUITE, numDataNodes =0)
|
||||||
public class DiscoveryWithNetworkFailuresTests extends ElasticsearchIntegrationTest {
|
public class DiscoveryWithNetworkFailuresTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -19,7 +19,9 @@
|
||||||
|
|
||||||
package org.elasticsearch.discovery;
|
package org.elasticsearch.discovery;
|
||||||
|
|
||||||
|
import org.elasticsearch.client.Client;
|
||||||
import org.elasticsearch.cluster.ClusterState;
|
import org.elasticsearch.cluster.ClusterState;
|
||||||
|
import org.elasticsearch.cluster.node.DiscoveryNode;
|
||||||
import org.elasticsearch.common.settings.ImmutableSettings;
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
||||||
|
@ -29,7 +31,7 @@ import org.junit.Test;
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
@ClusterScope(scope=Scope.TEST, numNodes=2)
|
@ClusterScope(scope=Scope.TEST, numDataNodes =2)
|
||||||
public class ZenUnicastDiscoveryTests extends ElasticsearchIntegrationTest {
|
public class ZenUnicastDiscoveryTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -43,10 +45,16 @@ public class ZenUnicastDiscoveryTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUnicastDiscovery() {
|
public void testUnicastDiscovery() {
|
||||||
ClusterState state = client().admin().cluster().prepareState().execute().actionGet().getState();
|
for (Client client : clients()) {
|
||||||
assertThat(state.nodes().size(), equalTo(2));
|
ClusterState state = client.admin().cluster().prepareState().execute().actionGet().getState();
|
||||||
|
//client nodes might be added randomly
|
||||||
state = client().admin().cluster().prepareState().execute().actionGet().getState();
|
int dataNodes = 0;
|
||||||
assertThat(state.nodes().size(), equalTo(2));
|
for (DiscoveryNode discoveryNode : state.nodes()) {
|
||||||
|
if (discoveryNode.isDataNode()) {
|
||||||
|
dataNodes++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
assertThat(dataNodes, equalTo(2));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,7 @@ import java.util.List;
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
@ClusterScope(scope=Scope.TEST, numNodes=0)
|
@ClusterScope(scope=Scope.TEST, numDataNodes =0)
|
||||||
public class ZenUnicastDiscoveryTestsMinimumMasterNodes extends ElasticsearchIntegrationTest {
|
public class ZenUnicastDiscoveryTestsMinimumMasterNodes extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
|
|
||||||
package org.elasticsearch.discovery;
|
package org.elasticsearch.discovery;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
|
||||||
import org.elasticsearch.action.admin.cluster.health.ClusterHealthResponse;
|
import org.elasticsearch.action.admin.cluster.health.ClusterHealthResponse;
|
||||||
import org.elasticsearch.cluster.ClusterState;
|
import org.elasticsearch.cluster.ClusterState;
|
||||||
import org.elasticsearch.cluster.node.DiscoveryNode;
|
import org.elasticsearch.cluster.node.DiscoveryNode;
|
||||||
|
@ -31,13 +30,16 @@ import org.junit.Test;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.apache.lucene.util.LuceneTestCase.Slow;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.Scope;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@LuceneTestCase.Slow
|
@Slow
|
||||||
@ElasticsearchIntegrationTest.ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class ZenUnicastDiscoveryTestsSpecificNodes extends ElasticsearchIntegrationTest {
|
public class ZenUnicastDiscoveryTestsSpecificNodes extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -354,7 +354,7 @@ public class BulkTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
int replica = randomInt(2);
|
int replica = randomInt(2);
|
||||||
|
|
||||||
cluster().ensureAtLeastNumNodes(1 + replica);
|
cluster().ensureAtLeastNumDataNodes(1 + replica);
|
||||||
|
|
||||||
assertAcked(prepareCreate("test").setSettings(
|
assertAcked(prepareCreate("test").setSettings(
|
||||||
ImmutableSettings.builder()
|
ImmutableSettings.builder()
|
||||||
|
|
|
@ -43,13 +43,14 @@ import org.junit.Test;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.nullValue;
|
import static org.hamcrest.Matchers.nullValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =0)
|
||||||
@Slow
|
@Slow
|
||||||
public class LocalGatewayIndexStateTests extends ElasticsearchIntegrationTest {
|
public class LocalGatewayIndexStateTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
|
|
|
@ -37,6 +37,7 @@ import static org.elasticsearch.client.Requests.clusterHealthRequest;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertNoFailures;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertNoFailures;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
@ -44,7 +45,7 @@ import static org.hamcrest.Matchers.*;
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(numNodes=0, scope= ElasticsearchIntegrationTest.Scope.TEST)
|
@ClusterScope(numDataNodes =0, scope= Scope.TEST)
|
||||||
public class QuorumLocalGatewayTests extends ElasticsearchIntegrationTest {
|
public class QuorumLocalGatewayTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -43,6 +43,7 @@ import static org.elasticsearch.cluster.metadata.IndexMetaData.SETTING_NUMBER_OF
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.termQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.termQuery;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
@ -50,7 +51,7 @@ import static org.hamcrest.Matchers.*;
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(numNodes = 0, scope = ElasticsearchIntegrationTest.Scope.TEST)
|
@ClusterScope(numDataNodes = 0, scope = Scope.TEST)
|
||||||
@Slow
|
@Slow
|
||||||
public class SimpleRecoveryLocalGatewayTests extends ElasticsearchIntegrationTest {
|
public class SimpleRecoveryLocalGatewayTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
|
|
|
@ -31,13 +31,14 @@ import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.hasItem;
|
import static org.hamcrest.Matchers.hasItem;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class RecoverAfterNodesTests extends ElasticsearchIntegrationTest {
|
public class RecoverAfterNodesTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
private final static TimeValue BLOCK_WAIT_TIMEOUT = TimeValue.timeValueSeconds(1);
|
private final static TimeValue BLOCK_WAIT_TIMEOUT = TimeValue.timeValueSeconds(1);
|
||||||
|
|
|
@ -18,15 +18,11 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.index.engine.internal;
|
package org.elasticsearch.index.engine.internal;
|
||||||
|
|
||||||
import com.carrotsearch.randomizedtesting.annotations.Nightly;
|
|
||||||
import com.carrotsearch.randomizedtesting.annotations.Seed;
|
|
||||||
import com.google.common.base.Predicate;
|
import com.google.common.base.Predicate;
|
||||||
import org.apache.lucene.index.LogByteSizeMergePolicy;
|
import org.apache.lucene.index.LogByteSizeMergePolicy;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
|
||||||
import org.elasticsearch.action.admin.indices.stats.IndicesStatsResponse;
|
import org.elasticsearch.action.admin.indices.stats.IndicesStatsResponse;
|
||||||
import org.elasticsearch.action.bulk.BulkRequestBuilder;
|
import org.elasticsearch.action.bulk.BulkRequestBuilder;
|
||||||
import org.elasticsearch.action.bulk.BulkResponse;
|
import org.elasticsearch.action.bulk.BulkResponse;
|
||||||
import org.elasticsearch.action.index.IndexRequestBuilder;
|
|
||||||
import org.elasticsearch.client.Requests;
|
import org.elasticsearch.client.Requests;
|
||||||
import org.elasticsearch.cluster.metadata.IndexMetaData;
|
import org.elasticsearch.cluster.metadata.IndexMetaData;
|
||||||
import org.elasticsearch.common.settings.ImmutableSettings;
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
|
@ -36,21 +32,22 @@ import org.hamcrest.Matchers;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.concurrent.ExecutionException;
|
import java.util.concurrent.ExecutionException;
|
||||||
|
|
||||||
|
import static org.apache.lucene.util.LuceneTestCase.Slow;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.Scope;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertNoFailures;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertNoFailures;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ElasticsearchIntegrationTest.ClusterScope(numNodes = 1, scope = ElasticsearchIntegrationTest.Scope.SUITE)
|
@ClusterScope(numDataNodes = 1, scope = Scope.SUITE)
|
||||||
public class InternalEngineMergeTests extends ElasticsearchIntegrationTest {
|
public class InternalEngineMergeTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@LuceneTestCase.Slow
|
@Slow
|
||||||
public void testMergesHappening() throws InterruptedException, IOException, ExecutionException {
|
public void testMergesHappening() throws InterruptedException, IOException, ExecutionException {
|
||||||
final int numOfShards = randomIntBetween(1,5);
|
final int numOfShards = randomIntBetween(1,5);
|
||||||
// some settings to keep num segments low
|
// some settings to keep num segments low
|
||||||
|
|
|
@ -56,7 +56,7 @@ public class SuggestStatsTests extends ElasticsearchIntegrationTest {
|
||||||
public void testSimpleStats() throws Exception {
|
public void testSimpleStats() throws Exception {
|
||||||
// clear all stats first
|
// clear all stats first
|
||||||
client().admin().indices().prepareStats().clear().execute().actionGet();
|
client().admin().indices().prepareStats().clear().execute().actionGet();
|
||||||
final int numNodes = immutableCluster().dataNodes();
|
final int numNodes = immutableCluster().numDataNodes();
|
||||||
assertThat(numNodes, greaterThanOrEqualTo(2));
|
assertThat(numNodes, greaterThanOrEqualTo(2));
|
||||||
final int shardsIdx1 = randomIntBetween(1, 10); // we make sure each node gets at least a single shard...
|
final int shardsIdx1 = randomIntBetween(1, 10); // we make sure each node gets at least a single shard...
|
||||||
final int shardsIdx2 = Math.max(numNodes - shardsIdx1, randomIntBetween(1, 10));
|
final int shardsIdx2 = Math.max(numNodes - shardsIdx1, randomIntBetween(1, 10));
|
||||||
|
@ -149,7 +149,7 @@ public class SuggestStatsTests extends ElasticsearchIntegrationTest {
|
||||||
private Set<String> nodeIdsWithIndex(String... indices) {
|
private Set<String> nodeIdsWithIndex(String... indices) {
|
||||||
ClusterState state = client().admin().cluster().prepareState().execute().actionGet().getState();
|
ClusterState state = client().admin().cluster().prepareState().execute().actionGet().getState();
|
||||||
GroupShardsIterator allAssignedShardsGrouped = state.routingTable().allAssignedShardsGrouped(indices, true);
|
GroupShardsIterator allAssignedShardsGrouped = state.routingTable().allAssignedShardsGrouped(indices, true);
|
||||||
Set<String> nodes = new HashSet<String>();
|
Set<String> nodes = new HashSet<>();
|
||||||
for (ShardIterator shardIterator : allAssignedShardsGrouped) {
|
for (ShardIterator shardIterator : allAssignedShardsGrouped) {
|
||||||
for (ShardRouting routing : shardIterator.asUnordered()) {
|
for (ShardRouting routing : shardIterator.asUnordered()) {
|
||||||
if (routing.active()) {
|
if (routing.active()) {
|
||||||
|
|
|
@ -46,13 +46,14 @@ import static org.elasticsearch.cluster.metadata.IndexMetaData.SETTING_NUMBER_OF
|
||||||
import static org.elasticsearch.cluster.metadata.IndexMetaData.SETTING_NUMBER_OF_SHARDS;
|
import static org.elasticsearch.cluster.metadata.IndexMetaData.SETTING_NUMBER_OF_SHARDS;
|
||||||
import static org.elasticsearch.cluster.routing.ShardRoutingState.*;
|
import static org.elasticsearch.cluster.routing.ShardRoutingState.*;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class IndexLifecycleActionTests extends ElasticsearchIntegrationTest {
|
public class IndexLifecycleActionTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Slow
|
@Slow
|
||||||
|
|
|
@ -43,7 +43,7 @@ import static org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
import static org.elasticsearch.test.ElasticsearchIntegrationTest.Scope;
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.Scope;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
|
|
||||||
@ClusterScope(scope = Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class IndicesLifecycleListenerTests extends ElasticsearchIntegrationTest {
|
public class IndicesLifecycleListenerTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -28,12 +28,13 @@ import org.junit.Test;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.notNullValue;
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes=0)
|
||||||
public class HunspellServiceTests extends ElasticsearchIntegrationTest {
|
public class HunspellServiceTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -33,11 +33,12 @@ import org.junit.Test;
|
||||||
|
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.filteredQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.filteredQuery;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.SUITE, numNodes=1)
|
@ClusterScope(scope= Scope.SUITE, numDataNodes =1, numClientNodes = 0)
|
||||||
public class CacheTests extends ElasticsearchIntegrationTest {
|
public class CacheTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -34,11 +34,12 @@ import java.lang.ref.WeakReference;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.nullValue;
|
import static org.hamcrest.Matchers.nullValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=1)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =1)
|
||||||
public class IndicesLeaksTests extends ElasticsearchIntegrationTest {
|
public class IndicesLeaksTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -19,19 +19,19 @@
|
||||||
|
|
||||||
package org.elasticsearch.indices.mapping;
|
package org.elasticsearch.indices.mapping;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
|
||||||
import org.elasticsearch.common.settings.ImmutableSettings;
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
|
|
||||||
|
import static org.apache.lucene.util.LuceneTestCase.Slow;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.Scope;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@LuceneTestCase.Slow
|
@Slow
|
||||||
@ElasticsearchIntegrationTest.ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class DedicatedMasterGetFieldMappingTests extends SimpleGetFieldMappingsTests {
|
public class DedicatedMasterGetFieldMappingTests extends SimpleGetFieldMappingsTests {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
|
|
|
@ -38,6 +38,7 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.greaterThan;
|
import static org.hamcrest.Matchers.greaterThan;
|
||||||
|
@ -45,7 +46,7 @@ import static org.hamcrest.Matchers.greaterThan;
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class IndexRecoveryTests extends ElasticsearchIntegrationTest {
|
public class IndexRecoveryTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
private static final String INDEX_NAME = "test-idx-1";
|
private static final String INDEX_NAME = "test-idx-1";
|
||||||
|
|
|
@ -119,7 +119,7 @@ public class UpdateNumberOfReplicasTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testAutoExpandNumberOfReplicas0ToData() {
|
public void testAutoExpandNumberOfReplicas0ToData() {
|
||||||
cluster().ensureAtMostNumNodes(2);
|
cluster().ensureAtMostNumDataNodes(2);
|
||||||
logger.info("--> creating index test with auto expand replicas");
|
logger.info("--> creating index test with auto expand replicas");
|
||||||
assertAcked(prepareCreate("test", 2, settingsBuilder().put("auto_expand_replicas", "0-all")));
|
assertAcked(prepareCreate("test", 2, settingsBuilder().put("auto_expand_replicas", "0-all")));
|
||||||
|
|
||||||
|
@ -147,7 +147,7 @@ public class UpdateNumberOfReplicasTests extends ElasticsearchIntegrationTest {
|
||||||
assertThat(clusterHealth.getIndices().get("test").getActiveShards(), equalTo(numShards.numPrimaries * 3));
|
assertThat(clusterHealth.getIndices().get("test").getActiveShards(), equalTo(numShards.numPrimaries * 3));
|
||||||
|
|
||||||
logger.info("--> closing one node");
|
logger.info("--> closing one node");
|
||||||
cluster().ensureAtMostNumNodes(2);
|
cluster().ensureAtMostNumDataNodes(2);
|
||||||
allowNodes("test", 2);
|
allowNodes("test", 2);
|
||||||
|
|
||||||
logger.info("--> running cluster health");
|
logger.info("--> running cluster health");
|
||||||
|
@ -160,7 +160,7 @@ public class UpdateNumberOfReplicasTests extends ElasticsearchIntegrationTest {
|
||||||
assertThat(clusterHealth.getIndices().get("test").getActiveShards(), equalTo(numShards.numPrimaries * 2));
|
assertThat(clusterHealth.getIndices().get("test").getActiveShards(), equalTo(numShards.numPrimaries * 2));
|
||||||
|
|
||||||
logger.info("--> closing another node");
|
logger.info("--> closing another node");
|
||||||
cluster().ensureAtMostNumNodes(1);
|
cluster().ensureAtMostNumDataNodes(1);
|
||||||
allowNodes("test", 1);
|
allowNodes("test", 1);
|
||||||
|
|
||||||
logger.info("--> running cluster health");
|
logger.info("--> running cluster health");
|
||||||
|
@ -176,7 +176,7 @@ public class UpdateNumberOfReplicasTests extends ElasticsearchIntegrationTest {
|
||||||
@Test
|
@Test
|
||||||
public void testAutoExpandNumberReplicas1ToData() {
|
public void testAutoExpandNumberReplicas1ToData() {
|
||||||
logger.info("--> creating index test with auto expand replicas");
|
logger.info("--> creating index test with auto expand replicas");
|
||||||
cluster().ensureAtMostNumNodes(2);
|
cluster().ensureAtMostNumDataNodes(2);
|
||||||
assertAcked(prepareCreate("test", 2, settingsBuilder().put("auto_expand_replicas", "1-all")));
|
assertAcked(prepareCreate("test", 2, settingsBuilder().put("auto_expand_replicas", "1-all")));
|
||||||
|
|
||||||
NumShards numShards = getNumShards("test");
|
NumShards numShards = getNumShards("test");
|
||||||
|
@ -203,7 +203,7 @@ public class UpdateNumberOfReplicasTests extends ElasticsearchIntegrationTest {
|
||||||
assertThat(clusterHealth.getIndices().get("test").getActiveShards(), equalTo(numShards.numPrimaries * 3));
|
assertThat(clusterHealth.getIndices().get("test").getActiveShards(), equalTo(numShards.numPrimaries * 3));
|
||||||
|
|
||||||
logger.info("--> closing one node");
|
logger.info("--> closing one node");
|
||||||
cluster().ensureAtMostNumNodes(2);
|
cluster().ensureAtMostNumDataNodes(2);
|
||||||
allowNodes("test", 2);
|
allowNodes("test", 2);
|
||||||
|
|
||||||
logger.info("--> running cluster health");
|
logger.info("--> running cluster health");
|
||||||
|
@ -216,7 +216,7 @@ public class UpdateNumberOfReplicasTests extends ElasticsearchIntegrationTest {
|
||||||
assertThat(clusterHealth.getIndices().get("test").getActiveShards(), equalTo(numShards.numPrimaries * 2));
|
assertThat(clusterHealth.getIndices().get("test").getActiveShards(), equalTo(numShards.numPrimaries * 2));
|
||||||
|
|
||||||
logger.info("--> closing another node");
|
logger.info("--> closing another node");
|
||||||
cluster().ensureAtMostNumNodes(1);
|
cluster().ensureAtMostNumDataNodes(1);
|
||||||
allowNodes("test", 1);
|
allowNodes("test", 1);
|
||||||
|
|
||||||
logger.info("--> running cluster health");
|
logger.info("--> running cluster health");
|
||||||
|
|
|
@ -30,11 +30,12 @@ import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
import org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.notNullValue;
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=2)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =2)
|
||||||
public class CloseIndexDisableCloseAllTests extends ElasticsearchIntegrationTest {
|
public class CloseIndexDisableCloseAllTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -39,10 +39,11 @@ import java.util.Random;
|
||||||
|
|
||||||
import static org.elasticsearch.cluster.metadata.IndexMetaData.SETTING_NUMBER_OF_REPLICAS;
|
import static org.elasticsearch.cluster.metadata.IndexMetaData.SETTING_NUMBER_OF_REPLICAS;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.SUITE, numNodes = 2)
|
@ClusterScope(scope = Scope.SUITE, numDataNodes = 2)
|
||||||
public class SimpleIndexStatsTests extends ElasticsearchIntegrationTest {
|
public class SimpleIndexStatsTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -34,12 +34,13 @@ import java.io.File;
|
||||||
import static org.elasticsearch.client.Requests.clusterHealthRequest;
|
import static org.elasticsearch.client.Requests.clusterHealthRequest;
|
||||||
import static org.elasticsearch.client.Requests.createIndexRequest;
|
import static org.elasticsearch.client.Requests.createIndexRequest;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =0)
|
||||||
public class IndicesStoreTests extends ElasticsearchIntegrationTest {
|
public class IndicesStoreTests extends ElasticsearchIntegrationTest {
|
||||||
private static final Settings SETTINGS = settingsBuilder().put("gateway.type", "local").build();
|
private static final Settings SETTINGS = settingsBuilder().put("gateway.type", "local").build();
|
||||||
|
|
||||||
|
|
|
@ -33,10 +33,11 @@ import java.io.File;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=1)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =1)
|
||||||
public class IndexTemplateFileLoadingTests extends ElasticsearchIntegrationTest {
|
public class IndexTemplateFileLoadingTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -33,12 +33,13 @@ import org.hamcrest.Matchers;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(numNodes=0, scope= ElasticsearchIntegrationTest.Scope.TEST)
|
@ClusterScope(numDataNodes =0, scope= Scope.TEST)
|
||||||
public class LocalGatewayIndicesWarmerTests extends ElasticsearchIntegrationTest {
|
public class LocalGatewayIndicesWarmerTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
private final ESLogger logger = Loggers.getLogger(LocalGatewayIndicesWarmerTests.class);
|
private final ESLogger logger = Loggers.getLogger(LocalGatewayIndicesWarmerTests.class);
|
||||||
|
|
|
@ -48,12 +48,13 @@ import static com.google.common.base.Predicates.isNull;
|
||||||
import static org.elasticsearch.client.Requests.clusterHealthRequest;
|
import static org.elasticsearch.client.Requests.clusterHealthRequest;
|
||||||
import static org.elasticsearch.client.Requests.nodesInfoRequest;
|
import static org.elasticsearch.client.Requests.nodesInfoRequest;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=0)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =0)
|
||||||
public class SimpleNodesInfoTests extends ElasticsearchIntegrationTest {
|
public class SimpleNodesInfoTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
static final class Fields {
|
static final class Fields {
|
||||||
|
|
|
@ -55,7 +55,7 @@ import static org.elasticsearch.test.ElasticsearchIntegrationTest.Scope;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.*;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.*;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
@ClusterScope(scope = Scope.TEST, numNodes = 1)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 1)
|
||||||
public class RecoveryPercolatorTests extends ElasticsearchIntegrationTest {
|
public class RecoveryPercolatorTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -185,8 +185,8 @@ public class RecoveryPercolatorTests extends ElasticsearchIntegrationTest {
|
||||||
@Slow
|
@Slow
|
||||||
@TestLogging("index.percolator:TRACE,percolator:TRACE")
|
@TestLogging("index.percolator:TRACE,percolator:TRACE")
|
||||||
public void testLoadingPercolateQueriesDuringCloseAndOpen() throws Exception {
|
public void testLoadingPercolateQueriesDuringCloseAndOpen() throws Exception {
|
||||||
cluster().ensureAtLeastNumNodes(2);
|
cluster().ensureAtLeastNumDataNodes(2);
|
||||||
cluster().ensureAtMostNumNodes(2);
|
cluster().ensureAtMostNumDataNodes(2);
|
||||||
|
|
||||||
assertAcked(client().admin().indices().prepareCreate("test")
|
assertAcked(client().admin().indices().prepareCreate("test")
|
||||||
.setSettings(settingsBuilder().put(IndexMetaData.SETTING_NUMBER_OF_SHARDS, 2)
|
.setSettings(settingsBuilder().put(IndexMetaData.SETTING_NUMBER_OF_SHARDS, 2)
|
||||||
|
@ -249,8 +249,8 @@ public class RecoveryPercolatorTests extends ElasticsearchIntegrationTest {
|
||||||
// We only start and stop nodes 2 and 3, so all requests should succeed and never be partial.
|
// We only start and stop nodes 2 and 3, so all requests should succeed and never be partial.
|
||||||
private void percolatorRecovery(final boolean multiPercolate) throws Exception {
|
private void percolatorRecovery(final boolean multiPercolate) throws Exception {
|
||||||
logger.info("--> ensuring exactly 2 nodes");
|
logger.info("--> ensuring exactly 2 nodes");
|
||||||
cluster().ensureAtLeastNumNodes(2);
|
cluster().ensureAtLeastNumDataNodes(2);
|
||||||
cluster().ensureAtMostNumNodes(2);
|
cluster().ensureAtMostNumDataNodes(2);
|
||||||
logger.info("--> Adding 3th node");
|
logger.info("--> Adding 3th node");
|
||||||
cluster().startNode(settingsBuilder().put("node.stay", true));
|
cluster().startNode(settingsBuilder().put("node.stay", true));
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
|
|
|
@ -46,11 +46,12 @@ import java.io.IOException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.CoreMatchers.is;
|
import static org.hamcrest.CoreMatchers.is;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.notNullValue;
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
|
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0, transportClientRatio = 0.0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0, transportClientRatio = 0.0)
|
||||||
public class PluginManagerTests extends ElasticsearchIntegrationTest {
|
public class PluginManagerTests extends ElasticsearchIntegrationTest {
|
||||||
private static final Settings SETTINGS = ImmutableSettings.settingsBuilder()
|
private static final Settings SETTINGS = ImmutableSettings.settingsBuilder()
|
||||||
.put("discovery.zen.ping.multicast.enabled", false)
|
.put("discovery.zen.ping.multicast.enabled", false)
|
||||||
|
|
|
@ -32,12 +32,13 @@ import org.junit.Test;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test a rest action that sets special response headers
|
* Test a rest action that sets special response headers
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.SUITE, numNodes = 1)
|
@ClusterScope(scope = Scope.SUITE, numDataNodes = 1)
|
||||||
public class ResponseHeaderPluginTests extends ElasticsearchIntegrationTest {
|
public class ResponseHeaderPluginTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -64,7 +65,7 @@ public class ResponseHeaderPluginTests extends ElasticsearchIntegrationTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
private HttpClient httpClient() {
|
private HttpClient httpClient() {
|
||||||
HttpServerTransport httpServerTransport = cluster().getInstance(HttpServerTransport.class);
|
HttpServerTransport httpServerTransport = cluster().getDataNodeInstance(HttpServerTransport.class);
|
||||||
return new HttpClient(httpServerTransport.boundAddress().publishAddress());
|
return new HttpClient(httpServerTransport.boundAddress().publishAddress());
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -31,13 +31,14 @@ import java.io.File;
|
||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* We want to test site plugins
|
* We want to test site plugins
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.SUITE, numNodes = 1)
|
@ClusterScope(scope = Scope.SUITE, numDataNodes = 1)
|
||||||
public class SitePluginTests extends ElasticsearchIntegrationTest {
|
public class SitePluginTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
|
|
||||||
|
@ -55,20 +56,20 @@ public class SitePluginTests extends ElasticsearchIntegrationTest {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public HttpClient httpClient(String id) {
|
public HttpClient httpClient() {
|
||||||
HttpServerTransport httpServerTransport = cluster().getInstance(HttpServerTransport.class);
|
HttpServerTransport httpServerTransport = cluster().getDataNodeInstance(HttpServerTransport.class);
|
||||||
return new HttpClient(httpServerTransport.boundAddress().publishAddress());
|
return new HttpClient(httpServerTransport.boundAddress().publishAddress());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testRedirectSitePlugin() throws Exception {
|
public void testRedirectSitePlugin() throws Exception {
|
||||||
// We use an HTTP Client to test redirection
|
// We use an HTTP Client to test redirection
|
||||||
HttpClientResponse response = httpClient("test").request("/_plugin/dummy");
|
HttpClientResponse response = httpClient().request("/_plugin/dummy");
|
||||||
assertThat(response.errorCode(), equalTo(RestStatus.MOVED_PERMANENTLY.getStatus()));
|
assertThat(response.errorCode(), equalTo(RestStatus.MOVED_PERMANENTLY.getStatus()));
|
||||||
assertThat(response.response(), containsString("/_plugin/dummy/"));
|
assertThat(response.response(), containsString("/_plugin/dummy/"));
|
||||||
|
|
||||||
// We test the real URL
|
// We test the real URL
|
||||||
response = httpClient("test").request("/_plugin/dummy/");
|
response = httpClient().request("/_plugin/dummy/");
|
||||||
assertThat(response.errorCode(), equalTo(RestStatus.OK.getStatus()));
|
assertThat(response.errorCode(), equalTo(RestStatus.OK.getStatus()));
|
||||||
assertThat(response.response(), containsString("<title>Dummy Site Plugin</title>"));
|
assertThat(response.response(), containsString("<title>Dummy Site Plugin</title>"));
|
||||||
}
|
}
|
||||||
|
@ -78,7 +79,7 @@ public class SitePluginTests extends ElasticsearchIntegrationTest {
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testAnyPage() throws Exception {
|
public void testAnyPage() throws Exception {
|
||||||
HttpClientResponse response = httpClient("test").request("/_plugin/dummy/index.html");
|
HttpClientResponse response = httpClient().request("/_plugin/dummy/index.html");
|
||||||
assertThat(response.errorCode(), equalTo(RestStatus.OK.getStatus()));
|
assertThat(response.errorCode(), equalTo(RestStatus.OK.getStatus()));
|
||||||
assertThat(response.response(), containsString("<title>Dummy Site Plugin</title>"));
|
assertThat(response.response(), containsString("<title>Dummy Site Plugin</title>"));
|
||||||
}
|
}
|
||||||
|
@ -89,14 +90,14 @@ public class SitePluginTests extends ElasticsearchIntegrationTest {
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testWelcomePageInSubDirs() throws Exception {
|
public void testWelcomePageInSubDirs() throws Exception {
|
||||||
HttpClientResponse response = httpClient("test").request("/_plugin/subdir/dir/");
|
HttpClientResponse response = httpClient().request("/_plugin/subdir/dir/");
|
||||||
assertThat(response.errorCode(), equalTo(RestStatus.OK.getStatus()));
|
assertThat(response.errorCode(), equalTo(RestStatus.OK.getStatus()));
|
||||||
assertThat(response.response(), containsString("<title>Dummy Site Plugin (subdir)</title>"));
|
assertThat(response.response(), containsString("<title>Dummy Site Plugin (subdir)</title>"));
|
||||||
|
|
||||||
response = httpClient("test").request("/_plugin/subdir/dir_without_index/");
|
response = httpClient().request("/_plugin/subdir/dir_without_index/");
|
||||||
assertThat(response.errorCode(), equalTo(RestStatus.FORBIDDEN.getStatus()));
|
assertThat(response.errorCode(), equalTo(RestStatus.FORBIDDEN.getStatus()));
|
||||||
|
|
||||||
response = httpClient("test").request("/_plugin/subdir/dir_without_index/page.html");
|
response = httpClient().request("/_plugin/subdir/dir_without_index/page.html");
|
||||||
assertThat(response.errorCode(), equalTo(RestStatus.OK.getStatus()));
|
assertThat(response.errorCode(), equalTo(RestStatus.OK.getStatus()));
|
||||||
assertThat(response.response(), containsString("<title>Dummy Site Plugin (page)</title>"));
|
assertThat(response.response(), containsString("<title>Dummy Site Plugin (page)</title>"));
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,12 +30,13 @@ import org.elasticsearch.test.junit.annotations.TestLogging;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertHitCount;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0, transportClientRatio = 0.0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0, transportClientRatio = 0.0)
|
||||||
public class FullRollingRestartTests extends ElasticsearchIntegrationTest {
|
public class FullRollingRestartTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
protected void assertTimeout(ClusterHealthRequestBuilder requestBuilder) {
|
protected void assertTimeout(ClusterHealthRequestBuilder requestBuilder) {
|
||||||
|
@ -89,14 +90,14 @@ public class FullRollingRestartTests extends ElasticsearchIntegrationTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
// now start shutting nodes down
|
// now start shutting nodes down
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
// make sure the cluster state is green, and all has been recovered
|
// make sure the cluster state is green, and all has been recovered
|
||||||
assertTimeout(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForGreenStatus().setWaitForRelocatingShards(0).setWaitForNodes("4"));
|
assertTimeout(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForGreenStatus().setWaitForRelocatingShards(0).setWaitForNodes("4"));
|
||||||
|
|
||||||
// going down to 3 nodes. note that the min_master_node may not be in effect when we shutdown the 4th
|
// going down to 3 nodes. note that the min_master_node may not be in effect when we shutdown the 4th
|
||||||
// node, but that's OK as it is set to 3 before.
|
// node, but that's OK as it is set to 3 before.
|
||||||
setMinimumMasterNodes(2);
|
setMinimumMasterNodes(2);
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
// make sure the cluster state is green, and all has been recovered
|
// make sure the cluster state is green, and all has been recovered
|
||||||
assertTimeout(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForGreenStatus().setWaitForRelocatingShards(0).setWaitForNodes("3"));
|
assertTimeout(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForGreenStatus().setWaitForRelocatingShards(0).setWaitForNodes("3"));
|
||||||
|
|
||||||
|
@ -106,13 +107,13 @@ public class FullRollingRestartTests extends ElasticsearchIntegrationTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
// closing the 3rd node
|
// closing the 3rd node
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
// make sure the cluster state is green, and all has been recovered
|
// make sure the cluster state is green, and all has been recovered
|
||||||
assertTimeout(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForGreenStatus().setWaitForRelocatingShards(0).setWaitForNodes("2"));
|
assertTimeout(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForGreenStatus().setWaitForRelocatingShards(0).setWaitForNodes("2"));
|
||||||
|
|
||||||
// closing the 2nd node
|
// closing the 2nd node
|
||||||
setMinimumMasterNodes(1);
|
setMinimumMasterNodes(1);
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
|
|
||||||
// make sure the cluster state is green, and all has been recovered
|
// make sure the cluster state is green, and all has been recovered
|
||||||
assertTimeout(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForYellowStatus().setWaitForRelocatingShards(0).setWaitForNodes("1"));
|
assertTimeout(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForYellowStatus().setWaitForRelocatingShards(0).setWaitForNodes("1"));
|
||||||
|
|
|
@ -40,11 +40,12 @@ import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class RelocationTests extends ElasticsearchIntegrationTest {
|
public class RelocationTests extends ElasticsearchIntegrationTest {
|
||||||
private final TimeValue ACCEPTABLE_RELOCATION_TIME = new TimeValue(5, TimeUnit.MINUTES);
|
private final TimeValue ACCEPTABLE_RELOCATION_TIME = new TimeValue(5, TimeUnit.MINUTES);
|
||||||
|
|
||||||
|
|
|
@ -32,9 +32,10 @@ import java.util.Map;
|
||||||
import java.util.concurrent.ExecutionException;
|
import java.util.concurrent.ExecutionException;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
|
||||||
@ClusterScope(scope = ElasticsearchIntegrationTest.Scope.SUITE, numNodes = 3)
|
@ClusterScope(scope = Scope.SUITE, numDataNodes = 3)
|
||||||
public class ScriptFieldTests extends ElasticsearchIntegrationTest {
|
public class ScriptFieldTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -68,7 +68,7 @@ public class SearchWhileCreatingIndexTests extends ElasticsearchIntegrationTest
|
||||||
// TODO: add a smarter choice based on actual consistency (when that is randomized)
|
// TODO: add a smarter choice based on actual consistency (when that is randomized)
|
||||||
int shardsNo = numberOfReplicas + 1;
|
int shardsNo = numberOfReplicas + 1;
|
||||||
int neededNodes = shardsNo <= 2 ? 1 : shardsNo / 2 + 1;
|
int neededNodes = shardsNo <= 2 ? 1 : shardsNo / 2 + 1;
|
||||||
cluster().ensureAtLeastNumNodes(randomIntBetween(neededNodes, shardsNo));
|
cluster().ensureAtLeastNumDataNodes(randomIntBetween(neededNodes, shardsNo));
|
||||||
for (int i = 0; i < 20; i++) {
|
for (int i = 0; i < 20; i++) {
|
||||||
logger.info("running iteration {}", i);
|
logger.info("running iteration {}", i);
|
||||||
if (createIndex) {
|
if (createIndex) {
|
||||||
|
@ -99,7 +99,7 @@ public class SearchWhileCreatingIndexTests extends ElasticsearchIntegrationTest
|
||||||
}
|
}
|
||||||
assertHitCount(searchResponse, 1);
|
assertHitCount(searchResponse, 1);
|
||||||
status = client().admin().cluster().prepareHealth("test").get().getStatus();
|
status = client().admin().cluster().prepareHealth("test").get().getStatus();
|
||||||
cluster().ensureAtLeastNumNodes(numberOfReplicas + 1);
|
cluster().ensureAtLeastNumDataNodes(numberOfReplicas + 1);
|
||||||
}
|
}
|
||||||
immutableCluster().wipeIndices("test");
|
immutableCluster().wipeIndices("test");
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,7 +50,7 @@ import static org.hamcrest.Matchers.equalTo;
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = Scope.SUITE, numNodes = 1)
|
@ClusterScope(scope = Scope.SUITE, numDataNodes = 1)
|
||||||
public class FunctionScorePluginTests extends ElasticsearchIntegrationTest {
|
public class FunctionScorePluginTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -40,7 +40,7 @@ import static org.hamcrest.Matchers.equalTo;
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope = Scope.SUITE, numNodes = 1)
|
@ClusterScope(scope = Scope.SUITE, numDataNodes = 1)
|
||||||
public class CustomHighlighterSearchTests extends ElasticsearchIntegrationTest {
|
public class CustomHighlighterSearchTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -38,15 +38,15 @@ public class SearchPreferenceTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test // see #2896
|
@Test // see #2896
|
||||||
public void testStopOneNodePreferenceWithRedState() throws InterruptedException {
|
public void testStopOneNodePreferenceWithRedState() throws InterruptedException {
|
||||||
assertAcked(prepareCreate("test").setSettings(settingsBuilder().put("index.number_of_shards", immutableCluster().dataNodes()+2).put("index.number_of_replicas", 0)));
|
assertAcked(prepareCreate("test").setSettings(settingsBuilder().put("index.number_of_shards", immutableCluster().numDataNodes()+2).put("index.number_of_replicas", 0)));
|
||||||
ensureGreen();
|
ensureGreen();
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
client().prepareIndex("test", "type1", ""+i).setSource("field1", "value1").execute().actionGet();
|
client().prepareIndex("test", "type1", ""+i).setSource("field1", "value1").execute().actionGet();
|
||||||
}
|
}
|
||||||
refresh();
|
refresh();
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
client().admin().cluster().prepareHealth().setWaitForStatus(ClusterHealthStatus.RED).execute().actionGet();
|
client().admin().cluster().prepareHealth().setWaitForStatus(ClusterHealthStatus.RED).execute().actionGet();
|
||||||
String[] preferences = new String[] {"_primary", "_local", "_primary_first", "_only_local", "_prefer_node:somenode", "_prefer_node:server2"};
|
String[] preferences = new String[] {"_primary", "_local", "_primary_first", "_prefer_node:somenode", "_prefer_node:server2"};
|
||||||
for (String pref : preferences) {
|
for (String pref : preferences) {
|
||||||
SearchResponse searchResponse = client().prepareSearch().setSearchType(SearchType.COUNT).setPreference(pref).execute().actionGet();
|
SearchResponse searchResponse = client().prepareSearch().setSearchType(SearchType.COUNT).setPreference(pref).execute().actionGet();
|
||||||
assertThat(RestStatus.OK, equalTo(searchResponse.status()));
|
assertThat(RestStatus.OK, equalTo(searchResponse.status()));
|
||||||
|
@ -55,6 +55,14 @@ public class SearchPreferenceTests extends ElasticsearchIntegrationTest {
|
||||||
assertThat(RestStatus.OK, equalTo(searchResponse.status()));
|
assertThat(RestStatus.OK, equalTo(searchResponse.status()));
|
||||||
assertThat(pref, searchResponse.getFailedShards(), greaterThanOrEqualTo(0));
|
assertThat(pref, searchResponse.getFailedShards(), greaterThanOrEqualTo(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//_only_local is a stricter preference, we need to send the request to a data node
|
||||||
|
SearchResponse searchResponse = dataNodeClient().prepareSearch().setSearchType(SearchType.COUNT).setPreference("_only_local").execute().actionGet();
|
||||||
|
assertThat(RestStatus.OK, equalTo(searchResponse.status()));
|
||||||
|
assertThat("_only_local", searchResponse.getFailedShards(), greaterThanOrEqualTo(0));
|
||||||
|
searchResponse = dataNodeClient().prepareSearch().setPreference("_only_local").execute().actionGet();
|
||||||
|
assertThat(RestStatus.OK, equalTo(searchResponse.status()));
|
||||||
|
assertThat("_only_local", searchResponse.getFailedShards(), greaterThanOrEqualTo(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -57,7 +57,7 @@ public class SearchStatsTests extends ElasticsearchIntegrationTest {
|
||||||
public void testSimpleStats() throws Exception {
|
public void testSimpleStats() throws Exception {
|
||||||
// clear all stats first
|
// clear all stats first
|
||||||
client().admin().indices().prepareStats().clear().execute().actionGet();
|
client().admin().indices().prepareStats().clear().execute().actionGet();
|
||||||
final int numNodes = immutableCluster().dataNodes();
|
final int numNodes = immutableCluster().numDataNodes();
|
||||||
assertThat(numNodes, greaterThanOrEqualTo(2));
|
assertThat(numNodes, greaterThanOrEqualTo(2));
|
||||||
final int shardsIdx1 = randomIntBetween(1, 10); // we make sure each node gets at least a single shard...
|
final int shardsIdx1 = randomIntBetween(1, 10); // we make sure each node gets at least a single shard...
|
||||||
final int shardsIdx2 = Math.max(numNodes - shardsIdx1, randomIntBetween(1, 10));
|
final int shardsIdx2 = Math.max(numNodes - shardsIdx1, randomIntBetween(1, 10));
|
||||||
|
|
|
@ -32,13 +32,14 @@ import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.hasSize;
|
import static org.hamcrest.Matchers.hasSize;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.SUITE, numNodes=1)
|
@ClusterScope(scope= Scope.SUITE, numDataNodes =1)
|
||||||
public class CustomSuggesterSearchTests extends ElasticsearchIntegrationTest {
|
public class CustomSuggesterSearchTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -41,7 +41,7 @@ public abstract class AbstractSnapshotTests extends ElasticsearchIntegrationTest
|
||||||
|
|
||||||
public static long getFailureCount(String repository) {
|
public static long getFailureCount(String repository) {
|
||||||
long failureCount = 0;
|
long failureCount = 0;
|
||||||
for (RepositoriesService repositoriesService : cluster().getInstances(RepositoriesService.class)) {
|
for (RepositoriesService repositoriesService : cluster().getDataNodeInstances(RepositoriesService.class)) {
|
||||||
MockRepository mockRepository = (MockRepository) repositoriesService.repository(repository);
|
MockRepository mockRepository = (MockRepository) repositoriesService.repository(repository);
|
||||||
failureCount += mockRepository.getFailureCount();
|
failureCount += mockRepository.getFailureCount();
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,8 +28,6 @@ import org.elasticsearch.common.Priority;
|
||||||
import org.elasticsearch.common.settings.ImmutableSettings;
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.snapshots.mockstore.MockRepositoryModule;
|
import org.elasticsearch.snapshots.mockstore.MockRepositoryModule;
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
|
||||||
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
|
||||||
import org.elasticsearch.test.junit.annotations.TestLogging;
|
import org.elasticsearch.test.junit.annotations.TestLogging;
|
||||||
import org.elasticsearch.test.store.MockDirectoryHelper;
|
import org.elasticsearch.test.store.MockDirectoryHelper;
|
||||||
import org.elasticsearch.threadpool.ThreadPool;
|
import org.elasticsearch.threadpool.ThreadPool;
|
||||||
|
@ -39,13 +37,15 @@ import java.util.ArrayList;
|
||||||
|
|
||||||
import static com.google.common.collect.Lists.newArrayList;
|
import static com.google.common.collect.Lists.newArrayList;
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.ClusterScope;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.Scope;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertThrows;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertThrows;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ElasticsearchIntegrationTest.ClusterScope(scope = ElasticsearchIntegrationTest.Scope.TEST, numNodes = 0)
|
@ClusterScope(scope = Scope.TEST, numDataNodes = 0)
|
||||||
public class DedicatedClusterSnapshotRestoreTests extends AbstractSnapshotTests {
|
public class DedicatedClusterSnapshotRestoreTests extends AbstractSnapshotTests {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -153,7 +153,7 @@ public class DedicatedClusterSnapshotRestoreTests extends AbstractSnapshotTests
|
||||||
assertThat(client().prepareCount("test-idx-1").get().getCount(), equalTo(100L));
|
assertThat(client().prepareCount("test-idx-1").get().getCount(), equalTo(100L));
|
||||||
|
|
||||||
logger.info("--> shutdown one of the nodes");
|
logger.info("--> shutdown one of the nodes");
|
||||||
cluster().stopRandomNode();
|
cluster().stopRandomDataNode();
|
||||||
assertThat(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForNodes("<2").execute().actionGet().isTimedOut(), equalTo(false));
|
assertThat(client().admin().cluster().prepareHealth().setWaitForEvents(Priority.LANGUID).setTimeout("1m").setWaitForNodes("<2").execute().actionGet().isTimedOut(), equalTo(false));
|
||||||
|
|
||||||
assertAcked(prepareCreate("test-idx-2", 1, settingsBuilder().put("number_of_shards", 6)
|
assertAcked(prepareCreate("test-idx-2", 1, settingsBuilder().put("number_of_shards", 6)
|
||||||
|
|
|
@ -982,7 +982,7 @@ public class SharedClusterSnapshotRestoreTests extends AbstractSnapshotTests {
|
||||||
|
|
||||||
long snapshotPause = 0L;
|
long snapshotPause = 0L;
|
||||||
long restorePause = 0L;
|
long restorePause = 0L;
|
||||||
for (RepositoriesService repositoriesService : cluster().getInstances(RepositoriesService.class)) {
|
for (RepositoriesService repositoriesService : cluster().getDataNodeInstances(RepositoriesService.class)) {
|
||||||
snapshotPause += repositoriesService.repository("test-repo").snapshotThrottleTimeInNanos();
|
snapshotPause += repositoriesService.repository("test-repo").snapshotThrottleTimeInNanos();
|
||||||
restorePause += repositoriesService.repository("test-repo").restoreThrottleTimeInNanos();
|
restorePause += repositoriesService.repository("test-repo").restoreThrottleTimeInNanos();
|
||||||
}
|
}
|
||||||
|
|
|
@ -134,7 +134,7 @@ import static org.hamcrest.Matchers.equalTo;
|
||||||
* the tests start.
|
* the tests start.
|
||||||
* <p/>
|
* <p/>
|
||||||
* <pre>
|
* <pre>
|
||||||
* @ClusterScope(scope=Scope.SUITE, numNodes=3)
|
* @ClusterScope(scope=Scope.SUITE, numDataNodes=3)
|
||||||
* public class SomeIntegrationTest extends ElasticsearchIntegrationTest {
|
* public class SomeIntegrationTest extends ElasticsearchIntegrationTest {
|
||||||
* @Test public void testMethod() {}
|
* @Test public void testMethod() {}
|
||||||
* }
|
* }
|
||||||
|
@ -304,7 +304,7 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
if (randomizeNumberOfShardsAndReplicas()) {
|
if (randomizeNumberOfShardsAndReplicas()) {
|
||||||
randomSettingsBuilder.put(SETTING_NUMBER_OF_SHARDS, between(DEFAULT_MIN_NUM_SHARDS, DEFAULT_MAX_NUM_SHARDS))
|
randomSettingsBuilder.put(SETTING_NUMBER_OF_SHARDS, between(DEFAULT_MIN_NUM_SHARDS, DEFAULT_MAX_NUM_SHARDS))
|
||||||
//use either 0 or 1 replica, yet a higher amount when possible, but only rarely
|
//use either 0 or 1 replica, yet a higher amount when possible, but only rarely
|
||||||
.put(SETTING_NUMBER_OF_REPLICAS, between(0, getRandom().nextInt(10) > 0 ? 1 : immutableCluster().dataNodes() - 1));
|
.put(SETTING_NUMBER_OF_REPLICAS, between(0, getRandom().nextInt(10) > 0 ? 1 : immutableCluster().numDataNodes() - 1));
|
||||||
}
|
}
|
||||||
client().admin().indices().preparePutTemplate("random_index_template")
|
client().admin().indices().preparePutTemplate("random_index_template")
|
||||||
.setTemplate("*")
|
.setTemplate("*")
|
||||||
|
@ -493,6 +493,13 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
return client;
|
return client;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Client dataNodeClient() {
|
||||||
|
Client client = cluster().dataNodeClient();
|
||||||
|
if (frequently()) {
|
||||||
|
client = new RandomizingClient((InternalClient) client, getRandom());
|
||||||
|
}
|
||||||
|
return client;
|
||||||
|
}
|
||||||
|
|
||||||
public static Iterable<Client> clients() {
|
public static Iterable<Client> clients() {
|
||||||
return immutableCluster();
|
return immutableCluster();
|
||||||
|
@ -515,7 +522,7 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
}
|
}
|
||||||
|
|
||||||
protected int maximumNumberOfReplicas() {
|
protected int maximumNumberOfReplicas() {
|
||||||
return immutableCluster().dataNodes() - 1;
|
return immutableCluster().numDataNodes() - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected int numberOfReplicas() {
|
protected int numberOfReplicas() {
|
||||||
|
@ -594,7 +601,7 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
* </p>
|
* </p>
|
||||||
*/
|
*/
|
||||||
public CreateIndexRequestBuilder prepareCreate(String index, int numNodes, ImmutableSettings.Builder settingsBuilder) {
|
public CreateIndexRequestBuilder prepareCreate(String index, int numNodes, ImmutableSettings.Builder settingsBuilder) {
|
||||||
cluster().ensureAtLeastNumNodes(numNodes);
|
cluster().ensureAtLeastNumDataNodes(numNodes);
|
||||||
|
|
||||||
ImmutableSettings.Builder builder = ImmutableSettings.builder().put(indexSettings()).put(settingsBuilder.build());
|
ImmutableSettings.Builder builder = ImmutableSettings.builder().put(indexSettings()).put(settingsBuilder.build());
|
||||||
|
|
||||||
|
@ -605,7 +612,7 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
}
|
}
|
||||||
|
|
||||||
private ImmutableSettings.Builder getExcludeSettings(String index, int num, ImmutableSettings.Builder builder) {
|
private ImmutableSettings.Builder getExcludeSettings(String index, int num, ImmutableSettings.Builder builder) {
|
||||||
String exclude = Joiner.on(',').join(cluster().allButN(num));
|
String exclude = Joiner.on(',').join(cluster().allDataNodesButN(num));
|
||||||
builder.put("index.routing.allocation.exclude._name", exclude);
|
builder.put("index.routing.allocation.exclude._name", exclude);
|
||||||
return builder;
|
return builder;
|
||||||
}
|
}
|
||||||
|
@ -617,7 +624,7 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
*/
|
*/
|
||||||
public void allowNodes(String index, int n) {
|
public void allowNodes(String index, int n) {
|
||||||
assert index != null;
|
assert index != null;
|
||||||
cluster().ensureAtLeastNumNodes(n);
|
cluster().ensureAtLeastNumDataNodes(n);
|
||||||
ImmutableSettings.Builder builder = ImmutableSettings.builder();
|
ImmutableSettings.Builder builder = ImmutableSettings.builder();
|
||||||
if (n > 0) {
|
if (n > 0) {
|
||||||
getExcludeSettings(index, n, builder);
|
getExcludeSettings(index, n, builder);
|
||||||
|
@ -1025,19 +1032,25 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
* a random number of nodes is used, where the minimum and maximum number of nodes
|
* a random number of nodes is used, where the minimum and maximum number of nodes
|
||||||
* are either the specified ones or the default ones if not specified.
|
* are either the specified ones or the default ones if not specified.
|
||||||
*/
|
*/
|
||||||
int numNodes() default -1;
|
int numDataNodes() default -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the minimum number of nodes in the cluster. Default is {@link org.elasticsearch.test.TestCluster#DEFAULT_MIN_NUM_NODES}.
|
* Returns the minimum number of nodes in the cluster. Default is {@link org.elasticsearch.test.TestCluster#DEFAULT_MIN_NUM_DATA_NODES}.
|
||||||
* Ignored when {@link ClusterScope#numNodes()} is set.
|
* Ignored when {@link ClusterScope#numDataNodes()} is set.
|
||||||
*/
|
*/
|
||||||
int minNumNodes() default TestCluster.DEFAULT_MIN_NUM_NODES;
|
int minNumDataNodes() default TestCluster.DEFAULT_MIN_NUM_DATA_NODES;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the maximum number of nodes in the cluster. Default is {@link org.elasticsearch.test.TestCluster#DEFAULT_MAX_NUM_NODES}.
|
* Returns the maximum number of nodes in the cluster. Default is {@link org.elasticsearch.test.TestCluster#DEFAULT_MAX_NUM_DATA_NODES}.
|
||||||
* Ignored when {@link ClusterScope#numNodes()} is set.
|
* Ignored when {@link ClusterScope#numDataNodes()} is set.
|
||||||
*/
|
*/
|
||||||
int maxNumNodes() default TestCluster.DEFAULT_MAX_NUM_NODES;
|
int maxNumDataNodes() default TestCluster.DEFAULT_MAX_NUM_DATA_NODES;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the number of client nodes in the cluster. Default is {@link org.elasticsearch.test.TestCluster#DEFAULT_NUM_CLIENT_NODES}, a
|
||||||
|
* negative value means that the number of client nodes will be randomized.
|
||||||
|
*/
|
||||||
|
int numClientNodes() default TestCluster.DEFAULT_NUM_CLIENT_NODES;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the transport client ratio. By default this returns <code>-1</code> which means a random
|
* Returns the transport client ratio. By default this returns <code>-1</code> which means a random
|
||||||
|
@ -1115,19 +1128,24 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
return annotation == null ? Scope.GLOBAL : annotation.scope();
|
return annotation == null ? Scope.GLOBAL : annotation.scope();
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getNumNodes() {
|
private int getNumDataNodes() {
|
||||||
ClusterScope annotation = getAnnotation(this.getClass());
|
ClusterScope annotation = getAnnotation(this.getClass());
|
||||||
return annotation == null ? -1 : annotation.numNodes();
|
return annotation == null ? -1 : annotation.numDataNodes();
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getMinNumNodes() {
|
private int getMinNumDataNodes() {
|
||||||
ClusterScope annotation = getAnnotation(this.getClass());
|
ClusterScope annotation = getAnnotation(this.getClass());
|
||||||
return annotation == null ? TestCluster.DEFAULT_MIN_NUM_NODES : annotation.minNumNodes();
|
return annotation == null ? TestCluster.DEFAULT_MIN_NUM_DATA_NODES : annotation.minNumDataNodes();
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getMaxNumNodes() {
|
private int getMaxNumDataNodes() {
|
||||||
ClusterScope annotation = getAnnotation(this.getClass());
|
ClusterScope annotation = getAnnotation(this.getClass());
|
||||||
return annotation == null ? TestCluster.DEFAULT_MAX_NUM_NODES : annotation.maxNumNodes();
|
return annotation == null ? TestCluster.DEFAULT_MAX_NUM_DATA_NODES : annotation.maxNumDataNodes();
|
||||||
|
}
|
||||||
|
|
||||||
|
private int getNumClientNodes() {
|
||||||
|
ClusterScope annotation = getAnnotation(this.getClass());
|
||||||
|
return annotation == null ? TestCluster.DEFAULT_NUM_CLIENT_NODES : annotation.numClientNodes();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1143,7 +1161,7 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
|
|
||||||
private TestCluster buildTestCluster(Scope scope) {
|
private TestCluster buildTestCluster(Scope scope) {
|
||||||
long currentClusterSeed = randomLong();
|
long currentClusterSeed = randomLong();
|
||||||
int numNodes = getNumNodes();
|
int numNodes = getNumDataNodes();
|
||||||
NodeSettingsSource nodeSettingsSource;
|
NodeSettingsSource nodeSettingsSource;
|
||||||
if (numNodes > 0) {
|
if (numNodes > 0) {
|
||||||
NodeSettingsSource.Immutable.Builder nodesSettings = NodeSettingsSource.Immutable.builder();
|
NodeSettingsSource.Immutable.Builder nodesSettings = NodeSettingsSource.Immutable.builder();
|
||||||
|
@ -1164,11 +1182,12 @@ public abstract class ElasticsearchIntegrationTest extends ElasticsearchTestCase
|
||||||
if (numNodes >= 0) {
|
if (numNodes >= 0) {
|
||||||
minNumNodes = maxNumNodes = numNodes;
|
minNumNodes = maxNumNodes = numNodes;
|
||||||
} else {
|
} else {
|
||||||
minNumNodes = getMinNumNodes();
|
minNumNodes = getMinNumDataNodes();
|
||||||
maxNumNodes = getMaxNumNodes();
|
maxNumNodes = getMaxNumDataNodes();
|
||||||
}
|
}
|
||||||
|
|
||||||
return new TestCluster(currentClusterSeed, minNumNodes, maxNumNodes, clusterName(scope.name(), ElasticsearchTestCase.CHILD_VM_ID, currentClusterSeed), nodeSettingsSource);
|
int numClientNodes = getNumClientNodes();
|
||||||
|
return new TestCluster(currentClusterSeed, minNumNodes, maxNumNodes, clusterName(scope.name(), ElasticsearchTestCase.CHILD_VM_ID, currentClusterSeed), nodeSettingsSource, numClientNodes);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -46,7 +46,7 @@ public final class ExternalTestCluster extends ImmutableTestCluster {
|
||||||
|
|
||||||
private final InetSocketAddress[] httpAddresses;
|
private final InetSocketAddress[] httpAddresses;
|
||||||
|
|
||||||
private final int dataNodes;
|
private final int numDataNodes;
|
||||||
|
|
||||||
public ExternalTestCluster(TransportAddress... transportAddresses) {
|
public ExternalTestCluster(TransportAddress... transportAddresses) {
|
||||||
this.client = new TransportClient(ImmutableSettings.settingsBuilder().put("client.transport.ignore_cluster_name", true))
|
this.client = new TransportClient(ImmutableSettings.settingsBuilder().put("client.transport.ignore_cluster_name", true))
|
||||||
|
@ -62,7 +62,7 @@ public final class ExternalTestCluster extends ImmutableTestCluster {
|
||||||
dataNodes++;
|
dataNodes++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.dataNodes = dataNodes;
|
this.numDataNodes = dataNodes;
|
||||||
logger.info("Setup ExternalTestCluster [{}] made of [{}] nodes", nodeInfos.getClusterName().value(), size());
|
logger.info("Setup ExternalTestCluster [{}] made of [{}] nodes", nodeInfos.getClusterName().value(), size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,8 +82,8 @@ public final class ExternalTestCluster extends ImmutableTestCluster {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int dataNodes() {
|
public int numDataNodes() {
|
||||||
return dataNodes;
|
return numDataNodes;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -98,7 +98,7 @@ public abstract class ImmutableTestCluster implements Iterable<Client> {
|
||||||
/**
|
/**
|
||||||
* Returns the number of data nodes in the cluster.
|
* Returns the number of data nodes in the cluster.
|
||||||
*/
|
*/
|
||||||
public abstract int dataNodes();
|
public abstract int numDataNodes();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the http addresses of the nodes within the cluster.
|
* Returns the http addresses of the nodes within the cluster.
|
||||||
|
|
|
@ -19,13 +19,11 @@
|
||||||
package org.elasticsearch.test;
|
package org.elasticsearch.test;
|
||||||
|
|
||||||
import com.carrotsearch.randomizedtesting.SeedUtils;
|
import com.carrotsearch.randomizedtesting.SeedUtils;
|
||||||
|
import com.carrotsearch.randomizedtesting.generators.RandomInts;
|
||||||
import com.carrotsearch.randomizedtesting.generators.RandomPicks;
|
import com.carrotsearch.randomizedtesting.generators.RandomPicks;
|
||||||
import com.google.common.base.Predicate;
|
import com.google.common.base.Predicate;
|
||||||
import com.google.common.base.Predicates;
|
import com.google.common.base.Predicates;
|
||||||
import com.google.common.collect.Collections2;
|
import com.google.common.collect.*;
|
||||||
import com.google.common.collect.Iterators;
|
|
||||||
import com.google.common.collect.Lists;
|
|
||||||
import com.google.common.collect.Sets;
|
|
||||||
import com.google.common.util.concurrent.Futures;
|
import com.google.common.util.concurrent.Futures;
|
||||||
import com.google.common.util.concurrent.ListenableFuture;
|
import com.google.common.util.concurrent.ListenableFuture;
|
||||||
import com.google.common.util.concurrent.SettableFuture;
|
import com.google.common.util.concurrent.SettableFuture;
|
||||||
|
@ -121,8 +119,12 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
|
|
||||||
private static final boolean ENABLE_MOCK_MODULES = systemPropertyAsBoolean(TESTS_ENABLE_MOCK_MODULES, true);
|
private static final boolean ENABLE_MOCK_MODULES = systemPropertyAsBoolean(TESTS_ENABLE_MOCK_MODULES, true);
|
||||||
|
|
||||||
static final int DEFAULT_MIN_NUM_NODES = 2;
|
static final int DEFAULT_MIN_NUM_DATA_NODES = 2;
|
||||||
static final int DEFAULT_MAX_NUM_NODES = 6;
|
static final int DEFAULT_MAX_NUM_DATA_NODES = 6;
|
||||||
|
|
||||||
|
static final int DEFAULT_NUM_CLIENT_NODES = -1;
|
||||||
|
static final int DEFAULT_MIN_NUM_CLIENT_NODES = 0;
|
||||||
|
static final int DEFAULT_MAX_NUM_CLIENT_NODES = 1;
|
||||||
|
|
||||||
/* sorted map to make traverse order reproducible, concurrent since we do checks on it not within a sync block */
|
/* sorted map to make traverse order reproducible, concurrent since we do checks on it not within a sync block */
|
||||||
private final NavigableMap<String, NodeAndClient> nodes = new TreeMap<>();
|
private final NavigableMap<String, NodeAndClient> nodes = new TreeMap<>();
|
||||||
|
@ -142,39 +144,50 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
* fully shared cluster to be more reproducible */
|
* fully shared cluster to be more reproducible */
|
||||||
private final long[] sharedNodesSeeds;
|
private final long[] sharedNodesSeeds;
|
||||||
|
|
||||||
|
private final int numSharedDataNodes;
|
||||||
|
|
||||||
|
private final int numSharedClientNodes;
|
||||||
|
|
||||||
private final NodeSettingsSource nodeSettingsSource;
|
private final NodeSettingsSource nodeSettingsSource;
|
||||||
|
|
||||||
private final ExecutorService executor;
|
private final ExecutorService executor;
|
||||||
|
|
||||||
public TestCluster(long clusterSeed, String clusterName) {
|
public TestCluster(long clusterSeed, String clusterName) {
|
||||||
this(clusterSeed, DEFAULT_MIN_NUM_NODES, DEFAULT_MAX_NUM_NODES, clusterName, NodeSettingsSource.EMPTY);
|
this(clusterSeed, DEFAULT_MIN_NUM_DATA_NODES, DEFAULT_MAX_NUM_DATA_NODES, clusterName, NodeSettingsSource.EMPTY, DEFAULT_NUM_CLIENT_NODES);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TestCluster(long clusterSeed, int minNumNodes, int maxNumNodes, String clusterName) {
|
public TestCluster(long clusterSeed, int minNumDataNodes, int maxNumDataNodes, String clusterName, int numClientNodes) {
|
||||||
this(clusterSeed, minNumNodes, maxNumNodes, clusterName, NodeSettingsSource.EMPTY);
|
this(clusterSeed, minNumDataNodes, maxNumDataNodes, clusterName, NodeSettingsSource.EMPTY, numClientNodes);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TestCluster(long clusterSeed, int minNumNodes, int maxNumNodes, String clusterName, NodeSettingsSource nodeSettingsSource) {
|
public TestCluster(long clusterSeed, int minNumDataNodes, int maxNumDataNodes, String clusterName, NodeSettingsSource nodeSettingsSource, int numClientNodes) {
|
||||||
this.clusterName = clusterName;
|
this.clusterName = clusterName;
|
||||||
|
|
||||||
if (minNumNodes < 0 || maxNumNodes < 0) {
|
if (minNumDataNodes < 0 || maxNumDataNodes < 0) {
|
||||||
throw new IllegalArgumentException("minimum and maximum number of nodes must be >= 0");
|
throw new IllegalArgumentException("minimum and maximum number of data nodes must be >= 0");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (maxNumNodes < minNumNodes) {
|
if (maxNumDataNodes < minNumDataNodes) {
|
||||||
throw new IllegalArgumentException("maximum number of nodes must be >= minimum number of nodes");
|
throw new IllegalArgumentException("maximum number of data nodes must be >= minimum number of data nodes");
|
||||||
}
|
}
|
||||||
|
|
||||||
Random random = new Random(clusterSeed);
|
Random random = new Random(clusterSeed);
|
||||||
|
|
||||||
int numSharedNodes;
|
this.numSharedDataNodes = RandomInts.randomIntBetween(random, minNumDataNodes, maxNumDataNodes);
|
||||||
if (minNumNodes == maxNumNodes) {
|
assert this.numSharedDataNodes >= 0;
|
||||||
numSharedNodes = minNumNodes;
|
|
||||||
} else {
|
//for now all shared data nodes are also master eligible
|
||||||
numSharedNodes = minNumNodes + random.nextInt(maxNumNodes - minNumNodes);
|
if (numSharedDataNodes == 0) {
|
||||||
}
|
this.numSharedClientNodes = 0;
|
||||||
|
} else {
|
||||||
|
if (numClientNodes < 0) {
|
||||||
|
this.numSharedClientNodes = RandomInts.randomIntBetween(random, DEFAULT_MIN_NUM_CLIENT_NODES, DEFAULT_MAX_NUM_CLIENT_NODES);
|
||||||
|
} else {
|
||||||
|
this.numSharedClientNodes = numClientNodes;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
assert this.numSharedClientNodes >=0;
|
||||||
|
|
||||||
assert numSharedNodes >= 0;
|
|
||||||
/*
|
/*
|
||||||
* TODO
|
* TODO
|
||||||
* - we might want start some master only nodes?
|
* - we might want start some master only nodes?
|
||||||
|
@ -182,11 +195,12 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
* - we could add a flag that never returns a client to the master
|
* - we could add a flag that never returns a client to the master
|
||||||
* - along those lines use a dedicated node that is master eligible and let all other nodes be only data nodes
|
* - along those lines use a dedicated node that is master eligible and let all other nodes be only data nodes
|
||||||
*/
|
*/
|
||||||
sharedNodesSeeds = new long[numSharedNodes];
|
sharedNodesSeeds = new long[numSharedDataNodes + numSharedClientNodes];
|
||||||
for (int i = 0; i < sharedNodesSeeds.length; i++) {
|
for (int i = 0; i < sharedNodesSeeds.length; i++) {
|
||||||
sharedNodesSeeds[i] = random.nextLong();
|
sharedNodesSeeds[i] = random.nextLong();
|
||||||
}
|
}
|
||||||
logger.info("Setup TestCluster [{}] with seed [{}] using [{}] nodes", clusterName, SeedUtils.formatSeed(clusterSeed), numSharedNodes);
|
|
||||||
|
logger.info("Setup TestCluster [{}] with seed [{}] using [{}] data nodes and [{}] client nodes", clusterName, SeedUtils.formatSeed(clusterSeed), numSharedDataNodes, numSharedClientNodes);
|
||||||
this.nodeSettingsSource = nodeSettingsSource;
|
this.nodeSettingsSource = nodeSettingsSource;
|
||||||
Builder builder = ImmutableSettings.settingsBuilder();
|
Builder builder = ImmutableSettings.settingsBuilder();
|
||||||
if (random.nextInt(5) == 0) { // sometimes set this
|
if (random.nextInt(5) == 0) { // sometimes set this
|
||||||
|
@ -333,14 +347,14 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ensures that at least <code>n</code> nodes are present in the cluster.
|
* Ensures that at least <code>n</code> data nodes are present in the cluster.
|
||||||
* if more nodes than <code>n</code> are present this method will not
|
* if more nodes than <code>n</code> are present this method will not
|
||||||
* stop any of the running nodes.
|
* stop any of the running nodes.
|
||||||
*/
|
*/
|
||||||
public void ensureAtLeastNumNodes(int n) {
|
public void ensureAtLeastNumDataNodes(int n) {
|
||||||
List<ListenableFuture<String>> futures = Lists.newArrayList();
|
List<ListenableFuture<String>> futures = Lists.newArrayList();
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
int size = nodes.size();
|
int size = numDataNodes();
|
||||||
for (int i = size; i < n; i++) {
|
for (int i = size; i < n; i++) {
|
||||||
logger.info("increasing cluster size from {} to {}", size, n);
|
logger.info("increasing cluster size from {} to {}", size, n);
|
||||||
futures.add(startNodeAsync());
|
futures.add(startNodeAsync());
|
||||||
|
@ -358,14 +372,17 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
* If less nodes that <code>n</code> are running this method
|
* If less nodes that <code>n</code> are running this method
|
||||||
* will not start any additional nodes.
|
* will not start any additional nodes.
|
||||||
*/
|
*/
|
||||||
public synchronized void ensureAtMostNumNodes(int n) {
|
public synchronized void ensureAtMostNumDataNodes(int n) {
|
||||||
if (nodes.size() <= n) {
|
int size = numDataNodes();
|
||||||
|
if (size <= n) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// prevent killing the master if possible
|
// prevent killing the master if possible and client nodes
|
||||||
final Iterator<NodeAndClient> values = n == 0 ? nodes.values().iterator() : Iterators.filter(nodes.values().iterator(), Predicates.not(new MasterNodePredicate(getMasterName())));
|
final Iterator<NodeAndClient> values = n == 0 ? nodes.values().iterator() : Iterators.filter(nodes.values().iterator(),
|
||||||
final Iterator<NodeAndClient> limit = Iterators.limit(values, nodes.size() - n);
|
Predicates.and(new DataNodePredicate(), Predicates.not(new MasterNodePredicate(getMasterName()))));
|
||||||
logger.info("changing cluster size from {} to {}", nodes.size() - n, n);
|
|
||||||
|
final Iterator<NodeAndClient> limit = Iterators.limit(values, size - n);
|
||||||
|
logger.info("changing cluster size from {} to {}, {} data nodes", size(), n + numSharedClientNodes, n);
|
||||||
Set<NodeAndClient> nodesToRemove = new HashSet<>();
|
Set<NodeAndClient> nodesToRemove = new HashSet<>();
|
||||||
while (limit.hasNext()) {
|
while (limit.hasNext()) {
|
||||||
NodeAndClient next = limit.next();
|
NodeAndClient next = limit.next();
|
||||||
|
@ -414,6 +431,16 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
return getOrBuildRandomNode().client(random);
|
return getOrBuildRandomNode().client(random);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a node client to a data node in the cluster.
|
||||||
|
* Note: use this with care tests should not rely on a certain nodes client.
|
||||||
|
*/
|
||||||
|
public synchronized Client dataNodeClient() {
|
||||||
|
ensureOpen();
|
||||||
|
/* Randomly return a client to one of the nodes in the cluster */
|
||||||
|
return getRandomNodeAndClient(new DataNodePredicate()).client(random);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a node client to the current master node.
|
* Returns a node client to the current master node.
|
||||||
* Note: use this with care tests should not rely on a certain nodes client.
|
* Note: use this with care tests should not rely on a certain nodes client.
|
||||||
|
@ -707,8 +734,9 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
|
|
||||||
|
|
||||||
Set<NodeAndClient> sharedNodes = new HashSet<>();
|
Set<NodeAndClient> sharedNodes = new HashSet<>();
|
||||||
|
assert sharedNodesSeeds.length == numSharedDataNodes + numSharedClientNodes;
|
||||||
boolean changed = false;
|
boolean changed = false;
|
||||||
for (int i = 0; i < sharedNodesSeeds.length; i++) {
|
for (int i = 0; i < numSharedDataNodes; i++) {
|
||||||
String buildNodeName = buildNodeName(i);
|
String buildNodeName = buildNodeName(i);
|
||||||
NodeAndClient nodeAndClient = nodes.get(buildNodeName);
|
NodeAndClient nodeAndClient = nodes.get(buildNodeName);
|
||||||
if (nodeAndClient == null) {
|
if (nodeAndClient == null) {
|
||||||
|
@ -719,6 +747,18 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
}
|
}
|
||||||
sharedNodes.add(nodeAndClient);
|
sharedNodes.add(nodeAndClient);
|
||||||
}
|
}
|
||||||
|
for (int i = numSharedDataNodes; i < numSharedDataNodes + numSharedClientNodes; i++) {
|
||||||
|
String buildNodeName = buildNodeName(i);
|
||||||
|
NodeAndClient nodeAndClient = nodes.get(buildNodeName);
|
||||||
|
if (nodeAndClient == null) {
|
||||||
|
changed = true;
|
||||||
|
Settings clientSettings = ImmutableSettings.builder().put("node.data", "false").put("node.master", "false").build();
|
||||||
|
nodeAndClient = buildNode(i, sharedNodesSeeds[i], clientSettings, Version.CURRENT);
|
||||||
|
nodeAndClient.node.start();
|
||||||
|
logger.info("Start Shared Node [{}] not shared", nodeAndClient.name);
|
||||||
|
}
|
||||||
|
sharedNodes.add(nodeAndClient);
|
||||||
|
}
|
||||||
if (!changed && sharedNodes.size() == nodes.size()) {
|
if (!changed && sharedNodes.size() == nodes.size()) {
|
||||||
logger.debug("Cluster is consistent - moving out - nodes: [{}] nextNodeId: [{}] numSharedNodes: [{}]", nodes.keySet(), nextNodeId.get(), sharedNodesSeeds.length);
|
logger.debug("Cluster is consistent - moving out - nodes: [{}] nextNodeId: [{}] numSharedNodes: [{}]", nodes.keySet(), nextNodeId.get(), sharedNodesSeeds.length);
|
||||||
if (size() > 0) {
|
if (size() > 0) {
|
||||||
|
@ -791,6 +831,22 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
return instances;
|
return instances;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an Iterable to all instances for the given class >T< across all data nodes in the cluster.
|
||||||
|
*/
|
||||||
|
public synchronized <T> Iterable<T> getDataNodeInstances(Class<T> clazz) {
|
||||||
|
return getInstances(clazz, new DataNodePredicate());
|
||||||
|
}
|
||||||
|
|
||||||
|
private synchronized <T> Iterable<T> getInstances(Class<T> clazz, Predicate<NodeAndClient> predicate) {
|
||||||
|
Iterable<NodeAndClient> filteredNodes = Iterables.filter(nodes.values(), predicate);
|
||||||
|
List<T> instances = new ArrayList<>();
|
||||||
|
for (NodeAndClient nodeAndClient : filteredNodes) {
|
||||||
|
instances.add(getInstanceFromNode(clazz, nodeAndClient.node));
|
||||||
|
}
|
||||||
|
return instances;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a reference to the given nodes instances of the given class >T<
|
* Returns a reference to the given nodes instances of the given class >T<
|
||||||
*/
|
*/
|
||||||
|
@ -805,6 +861,14 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
} else {
|
} else {
|
||||||
predicate = Predicates.alwaysTrue();
|
predicate = Predicates.alwaysTrue();
|
||||||
}
|
}
|
||||||
|
return getInstance(clazz, predicate);
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized <T> T getDataNodeInstance(Class<T> clazz) {
|
||||||
|
return getInstance(clazz, new DataNodePredicate());
|
||||||
|
}
|
||||||
|
|
||||||
|
private synchronized <T> T getInstance(Class<T> clazz, Predicate<NodeAndClient> predicate) {
|
||||||
NodeAndClient randomNodeAndClient = getRandomNodeAndClient(predicate);
|
NodeAndClient randomNodeAndClient = getRandomNodeAndClient(predicate);
|
||||||
assert randomNodeAndClient != null;
|
assert randomNodeAndClient != null;
|
||||||
return getInstanceFromNode(clazz, randomNodeAndClient.node);
|
return getInstanceFromNode(clazz, randomNodeAndClient.node);
|
||||||
|
@ -814,7 +878,7 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
* Returns a reference to a random nodes instances of the given class >T<
|
* Returns a reference to a random nodes instances of the given class >T<
|
||||||
*/
|
*/
|
||||||
public synchronized <T> T getInstance(Class<T> clazz) {
|
public synchronized <T> T getInstance(Class<T> clazz) {
|
||||||
return getInstance(clazz, null);
|
return getInstance(clazz, Predicates.<NodeAndClient>alwaysTrue());
|
||||||
}
|
}
|
||||||
|
|
||||||
private synchronized <T> T getInstanceFromNode(Class<T> clazz, InternalNode node) {
|
private synchronized <T> T getInstanceFromNode(Class<T> clazz, InternalNode node) {
|
||||||
|
@ -836,11 +900,11 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stops a random node in the cluster.
|
* Stops a random data node in the cluster.
|
||||||
*/
|
*/
|
||||||
public synchronized void stopRandomNode() {
|
public synchronized void stopRandomDataNode() {
|
||||||
ensureOpen();
|
ensureOpen();
|
||||||
NodeAndClient nodeAndClient = getRandomNodeAndClient();
|
NodeAndClient nodeAndClient = getRandomNodeAndClient(new DataNodePredicate());
|
||||||
if (nodeAndClient != null) {
|
if (nodeAndClient != null) {
|
||||||
logger.info("Closing random node [{}] ", nodeAndClient.name);
|
logger.info("Closing random node [{}] ", nodeAndClient.name);
|
||||||
nodes.remove(nodeAndClient.name);
|
nodes.remove(nodeAndClient.name);
|
||||||
|
@ -899,13 +963,33 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
restartRandomNode(EMPTY_CALLBACK);
|
restartRandomNode(EMPTY_CALLBACK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Restarts a random node in the cluster and calls the callback during restart.
|
* Restarts a random node in the cluster and calls the callback during restart.
|
||||||
*/
|
*/
|
||||||
public void restartRandomNode(RestartCallback callback) throws Exception {
|
public void restartRandomNode(RestartCallback callback) throws Exception {
|
||||||
|
restartRandomNode(Predicates.<NodeAndClient>alwaysTrue(), callback);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Restarts a random data node in the cluster
|
||||||
|
*/
|
||||||
|
public void restartRandomDataNode() throws Exception {
|
||||||
|
restartRandomNode(EMPTY_CALLBACK);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Restarts a random data node in the cluster and calls the callback during restart.
|
||||||
|
*/
|
||||||
|
public void restartRandomDataNode(RestartCallback callback) throws Exception {
|
||||||
|
restartRandomNode(new DataNodePredicate(), callback);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Restarts a random node in the cluster and calls the callback during restart.
|
||||||
|
*/
|
||||||
|
private void restartRandomNode(Predicate<NodeAndClient> predicate, RestartCallback callback) throws Exception {
|
||||||
ensureOpen();
|
ensureOpen();
|
||||||
NodeAndClient nodeAndClient = getRandomNodeAndClient();
|
NodeAndClient nodeAndClient = getRandomNodeAndClient(predicate);
|
||||||
if (nodeAndClient != null) {
|
if (nodeAndClient != null) {
|
||||||
logger.info("Restarting random node [{}] ", nodeAndClient.name);
|
logger.info("Restarting random node [{}] ", nodeAndClient.name);
|
||||||
nodeAndClient.restart(callback);
|
nodeAndClient.restart(callback);
|
||||||
|
@ -996,13 +1080,14 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
synchronized Set<String> allButN(int numNodes) {
|
synchronized Set<String> allDataNodesButN(int numNodes) {
|
||||||
return nRandomNodes(size() - numNodes);
|
return nRandomDataNodes(numDataNodes() - numNodes);
|
||||||
}
|
}
|
||||||
|
|
||||||
private synchronized Set<String> nRandomNodes(int numNodes) {
|
private synchronized Set<String> nRandomDataNodes(int numNodes) {
|
||||||
assert size() >= numNodes;
|
assert size() >= numNodes;
|
||||||
return Sets.newHashSet(Iterators.limit(this.nodes.keySet().iterator(), numNodes));
|
NavigableMap<String, NodeAndClient> dataNodes = Maps.filterEntries(nodes, new EntryNodePredicate(new DataNodePredicate()));
|
||||||
|
return Sets.newHashSet(Iterators.limit(dataNodes.keySet().iterator(), numNodes));
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void startNodeClient(Settings settings) {
|
public synchronized void startNodeClient(Settings settings) {
|
||||||
|
@ -1154,11 +1239,11 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int dataNodes() {
|
public int numDataNodes() {
|
||||||
return dataNodeAndClients().size();
|
return dataNodeAndClients().size();
|
||||||
}
|
}
|
||||||
|
|
||||||
private Collection<NodeAndClient> dataNodeAndClients() {
|
private synchronized Collection<NodeAndClient> dataNodeAndClients() {
|
||||||
return Collections2.filter(nodes.values(), new DataNodePredicate());
|
return Collections2.filter(nodes.values(), new DataNodePredicate());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1183,13 +1268,25 @@ public final class TestCluster extends ImmutableTestCluster {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final class ClientNodePredicate implements Predicate<NodeAndClient> {
|
private static final class ClientNodePredicate implements Predicate<NodeAndClient> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(NodeAndClient nodeAndClient) {
|
public boolean apply(NodeAndClient nodeAndClient) {
|
||||||
return nodeAndClient.node.settings().getAsBoolean("node.client", false);
|
return nodeAndClient.node.settings().getAsBoolean("node.client", false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final class EntryNodePredicate implements Predicate<Map.Entry<String, NodeAndClient>> {
|
||||||
|
private final Predicate<NodeAndClient> delegateNodePredicate;
|
||||||
|
|
||||||
|
EntryNodePredicate(Predicate<NodeAndClient> delegateNodePredicate) {
|
||||||
|
this.delegateNodePredicate = delegateNodePredicate;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean apply(Map.Entry<String, NodeAndClient> entry) {
|
||||||
|
return delegateNodePredicate.apply(entry.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized Iterator<Client> iterator() {
|
public synchronized Iterator<Client> iterator() {
|
||||||
ensureOpen();
|
ensureOpen();
|
||||||
|
|
|
@ -38,11 +38,12 @@ import java.util.Map;
|
||||||
import java.util.concurrent.*;
|
import java.util.concurrent.*;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.TEST, numNodes=2)
|
@ClusterScope(scope= Scope.TEST, numDataNodes =2)
|
||||||
public class SimpleThreadPoolTests extends ElasticsearchIntegrationTest {
|
public class SimpleThreadPoolTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -52,7 +53,7 @@ public class SimpleThreadPoolTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Test(timeout = 20000)
|
@Test(timeout = 20000)
|
||||||
public void testUpdatingThreadPoolSettings() throws Exception {
|
public void testUpdatingThreadPoolSettings() throws Exception {
|
||||||
ThreadPool threadPool = cluster().getInstance(ThreadPool.class);
|
ThreadPool threadPool = cluster().getDataNodeInstance(ThreadPool.class);
|
||||||
// Check that settings are changed
|
// Check that settings are changed
|
||||||
assertThat(((ThreadPoolExecutor) threadPool.executor(Names.SEARCH)).getKeepAliveTime(TimeUnit.MINUTES), equalTo(5L));
|
assertThat(((ThreadPoolExecutor) threadPool.executor(Names.SEARCH)).getKeepAliveTime(TimeUnit.MINUTES), equalTo(5L));
|
||||||
client().admin().cluster().prepareUpdateSettings().setTransientSettings(settingsBuilder().put("threadpool.search.keep_alive", "10m").build()).execute().actionGet();
|
client().admin().cluster().prepareUpdateSettings().setTransientSettings(settingsBuilder().put("threadpool.search.keep_alive", "10m").build()).execute().actionGet();
|
||||||
|
|
|
@ -58,9 +58,9 @@ public class TribeTests extends ElasticsearchIntegrationTest {
|
||||||
public static void setupSecondCluster() throws Exception {
|
public static void setupSecondCluster() throws Exception {
|
||||||
ElasticsearchIntegrationTest.beforeClass();
|
ElasticsearchIntegrationTest.beforeClass();
|
||||||
// create another cluster
|
// create another cluster
|
||||||
cluster2 = new TestCluster(randomLong(), 2, 2, Strings.randomBase64UUID(getRandom()));
|
cluster2 = new TestCluster(randomLong(), 2, 2, Strings.randomBase64UUID(getRandom()), 0);
|
||||||
cluster2.beforeTest(getRandom(), 0.1);
|
cluster2.beforeTest(getRandom(), 0.1);
|
||||||
cluster2.ensureAtLeastNumNodes(2);
|
cluster2.ensureAtLeastNumDataNodes(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@AfterClass
|
@AfterClass
|
||||||
|
@ -301,7 +301,7 @@ public class TribeTests extends ElasticsearchIntegrationTest {
|
||||||
});
|
});
|
||||||
|
|
||||||
logger.info("stop a node, make sure its reflected");
|
logger.info("stop a node, make sure its reflected");
|
||||||
cluster2.stopRandomNode();
|
cluster2.stopRandomDataNode();
|
||||||
awaitSameNodeCounts();
|
awaitSameNodeCounts();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -32,10 +32,11 @@ import org.junit.Test;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.SUITE, numNodes = 1)
|
@ClusterScope(scope= Scope.SUITE, numDataNodes = 1)
|
||||||
public class SimpleTTLTests extends ElasticsearchIntegrationTest {
|
public class SimpleTTLTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
static private final long PURGE_INTERVAL = 200;
|
static private final long PURGE_INTERVAL = 200;
|
||||||
|
|
|
@ -31,13 +31,14 @@ import org.junit.Test;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import static org.elasticsearch.test.ElasticsearchIntegrationTest.*;
|
||||||
import static org.hamcrest.Matchers.hasKey;
|
import static org.hamcrest.Matchers.hasKey;
|
||||||
import static org.hamcrest.Matchers.is;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ClusterScope(scope= ElasticsearchIntegrationTest.Scope.SUITE, numNodes=1)
|
@ClusterScope(scope= Scope.SUITE, numDataNodes =1)
|
||||||
public class UpdateByNativeScriptTests extends ElasticsearchIntegrationTest {
|
public class UpdateByNativeScriptTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue