Better check for verifying that the _percolator type is removed
This commit is contained in:
parent
43e374f793
commit
fec196b8d8
|
@ -22,11 +22,13 @@ package org.elasticsearch.test.integration.percolator;
|
||||||
import org.elasticsearch.action.admin.cluster.node.stats.NodeStats;
|
import org.elasticsearch.action.admin.cluster.node.stats.NodeStats;
|
||||||
import org.elasticsearch.action.admin.cluster.node.stats.NodesStatsResponse;
|
import org.elasticsearch.action.admin.cluster.node.stats.NodesStatsResponse;
|
||||||
import org.elasticsearch.action.admin.indices.alias.IndicesAliasesResponse;
|
import org.elasticsearch.action.admin.indices.alias.IndicesAliasesResponse;
|
||||||
|
import org.elasticsearch.action.admin.indices.exists.types.TypesExistsResponse;
|
||||||
import org.elasticsearch.action.admin.indices.stats.IndicesStatsResponse;
|
import org.elasticsearch.action.admin.indices.stats.IndicesStatsResponse;
|
||||||
import org.elasticsearch.action.count.CountResponse;
|
import org.elasticsearch.action.count.CountResponse;
|
||||||
import org.elasticsearch.action.percolate.PercolateResponse;
|
import org.elasticsearch.action.percolate.PercolateResponse;
|
||||||
import org.elasticsearch.action.search.SearchResponse;
|
import org.elasticsearch.action.search.SearchResponse;
|
||||||
import org.elasticsearch.action.support.IgnoreIndices;
|
import org.elasticsearch.action.support.IgnoreIndices;
|
||||||
|
import org.elasticsearch.client.Client;
|
||||||
import org.elasticsearch.client.Requests;
|
import org.elasticsearch.client.Requests;
|
||||||
import org.elasticsearch.common.Strings;
|
import org.elasticsearch.common.Strings;
|
||||||
import org.elasticsearch.common.settings.ImmutableSettings;
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
|
@ -45,6 +47,7 @@ import static org.elasticsearch.action.percolate.PercolateSourceBuilder.docBuild
|
||||||
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
import static org.elasticsearch.common.settings.ImmutableSettings.settingsBuilder;
|
||||||
import static org.elasticsearch.common.xcontent.XContentFactory.*;
|
import static org.elasticsearch.common.xcontent.XContentFactory.*;
|
||||||
import static org.elasticsearch.index.query.QueryBuilders.*;
|
import static org.elasticsearch.index.query.QueryBuilders.*;
|
||||||
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertNoFailures;
|
||||||
import static org.hamcrest.Matchers.*;
|
import static org.hamcrest.Matchers.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1041,32 +1044,39 @@ public class SimplePercolatorTests extends AbstractSharedClusterTest {
|
||||||
assertThat(response.getCount(), equalTo(2l));
|
assertThat(response.getCount(), equalTo(2l));
|
||||||
|
|
||||||
client().admin().indices().prepareDeleteMapping("test1").setType("_percolator").execute().actionGet();
|
client().admin().indices().prepareDeleteMapping("test1").setType("_percolator").execute().actionGet();
|
||||||
// To verify that the type is really deleted from all the node
|
percolatorTypeRemoved("test1");
|
||||||
SearchResponse searchResponse;
|
|
||||||
do {
|
|
||||||
searchResponse = client().prepareSearch("test1").setTypes("_percolator").execute().actionGet();
|
|
||||||
} while (searchResponse.getHits().totalHits() != 0);
|
|
||||||
|
|
||||||
response = client().preparePercolate()
|
response = client().preparePercolate()
|
||||||
.setIndices("test1", "test2").setDocumentType("type").setOnlyCount(true)
|
.setIndices("test1", "test2").setDocumentType("type").setOnlyCount(true)
|
||||||
.setPercolateDoc(docBuilder().setDoc(jsonBuilder().startObject().field("field1", "b").endObject()))
|
.setPercolateDoc(docBuilder().setDoc(jsonBuilder().startObject().field("field1", "b").endObject()))
|
||||||
.execute().actionGet();
|
.execute().actionGet();
|
||||||
|
assertNoFailures(response);
|
||||||
assertThat(response.getCount(), equalTo(1l));
|
assertThat(response.getCount(), equalTo(1l));
|
||||||
|
|
||||||
client().admin().indices().prepareDeleteMapping("test2").setType("_percolator").execute().actionGet();
|
client().admin().indices().prepareDeleteMapping("test2").setType("_percolator").execute().actionGet();
|
||||||
// To verify that the type is really deleted from all the node
|
percolatorTypeRemoved("test2");
|
||||||
do {
|
|
||||||
searchResponse = client().prepareSearch("test2").setTypes("_percolator").execute().actionGet();
|
|
||||||
} while (searchResponse.getHits().totalHits() != 0);
|
|
||||||
|
|
||||||
// Percolate api should return 0 matches, because all _percolate types have been removed.
|
// Percolate api should return 0 matches, because all _percolate types have been removed.
|
||||||
response = client().preparePercolate()
|
response = client().preparePercolate()
|
||||||
.setIndices("test1", "test2").setDocumentType("type").setOnlyCount(true)
|
.setIndices("test1", "test2").setDocumentType("type").setOnlyCount(true)
|
||||||
.setPercolateDoc(docBuilder().setDoc(jsonBuilder().startObject().field("field1", "b").endObject()))
|
.setPercolateDoc(docBuilder().setDoc(jsonBuilder().startObject().field("field1", "b").endObject()))
|
||||||
.execute().actionGet();
|
.execute().actionGet();
|
||||||
|
assertNoFailures(response);
|
||||||
assertThat(response.getCount(), equalTo(0l));
|
assertThat(response.getCount(), equalTo(0l));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void percolatorTypeRemoved(String index) {
|
||||||
|
my_goto: while (true) {
|
||||||
|
for (Client client : clients()) {
|
||||||
|
TypesExistsResponse existsResponse =
|
||||||
|
client.admin().indices().prepareTypesExists(index).setTypes("_percolator").execute().actionGet();
|
||||||
|
if (existsResponse.isExists()) {
|
||||||
|
continue my_goto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static String[] convertFromTextArray(PercolateResponse.Match[] matches, String index) {
|
public static String[] convertFromTextArray(PercolateResponse.Match[] matches, String index) {
|
||||||
if (matches.length == 0) {
|
if (matches.length == 0) {
|
||||||
return Strings.EMPTY_ARRAY;
|
return Strings.EMPTY_ARRAY;
|
||||||
|
|
Loading…
Reference in New Issue