Fix x-plugins following count/scan removal from elasticsearch-core.

Original commit: elastic/x-pack-elasticsearch@ee43991a0a
This commit is contained in:
Adrien Grand 2015-09-07 17:44:01 +02:00
parent 9a729638da
commit 06ec935a08
9 changed files with 32 additions and 83 deletions

View File

@ -223,7 +223,6 @@ public class InternalAuthorizationService extends AbstractComponent implements A
private static boolean isScrollRelatedAction(String action) { private static boolean isScrollRelatedAction(String action) {
return action.equals(SearchScrollAction.NAME) || return action.equals(SearchScrollAction.NAME) ||
action.equals(SearchServiceTransportAction.SCAN_SCROLL_ACTION_NAME) ||
action.equals(SearchServiceTransportAction.FETCH_ID_SCROLL_ACTION_NAME) || action.equals(SearchServiceTransportAction.FETCH_ID_SCROLL_ACTION_NAME) ||
action.equals(SearchServiceTransportAction.QUERY_FETCH_SCROLL_ACTION_NAME) || action.equals(SearchServiceTransportAction.QUERY_FETCH_SCROLL_ACTION_NAME) ||
action.equals(SearchServiceTransportAction.QUERY_SCROLL_ACTION_NAME) || action.equals(SearchServiceTransportAction.QUERY_SCROLL_ACTION_NAME) ||

View File

@ -175,9 +175,6 @@ public class InternalAuthorizationServiceTests extends ESTestCase {
internalAuthorizationService.authorize(user, SearchServiceTransportAction.CLEAR_SCROLL_CONTEXTS_ACTION_NAME, request); internalAuthorizationService.authorize(user, SearchServiceTransportAction.CLEAR_SCROLL_CONTEXTS_ACTION_NAME, request);
verify(auditTrail).accessGranted(user, SearchServiceTransportAction.CLEAR_SCROLL_CONTEXTS_ACTION_NAME, request); verify(auditTrail).accessGranted(user, SearchServiceTransportAction.CLEAR_SCROLL_CONTEXTS_ACTION_NAME, request);
internalAuthorizationService.authorize(user, SearchServiceTransportAction.SCAN_SCROLL_ACTION_NAME, request);
verify(auditTrail).accessGranted(user, SearchServiceTransportAction.SCAN_SCROLL_ACTION_NAME, request);
internalAuthorizationService.authorize(user, SearchServiceTransportAction.FETCH_ID_SCROLL_ACTION_NAME, request); internalAuthorizationService.authorize(user, SearchServiceTransportAction.FETCH_ID_SCROLL_ACTION_NAME, request);
verify(auditTrail).accessGranted(user, SearchServiceTransportAction.FETCH_ID_SCROLL_ACTION_NAME, request); verify(auditTrail).accessGranted(user, SearchServiceTransportAction.FETCH_ID_SCROLL_ACTION_NAME, request);

View File

@ -40,8 +40,6 @@ indices:data/read/search[phase/query/id]
indices:data/read/search[phase/query/query+fetch] indices:data/read/search[phase/query/query+fetch]
indices:data/read/search[phase/query/scroll] indices:data/read/search[phase/query/scroll]
indices:data/read/search[phase/query] indices:data/read/search[phase/query]
indices:data/read/search[phase/scan/scroll]
indices:data/read/search[phase/scan]
indices:data/read/suggest[s] indices:data/read/suggest[s]
indices:data/read/tv[s] indices:data/read/tv[s]
indices:data/write/bulk[s] indices:data/write/bulk[s]

View File

@ -26,6 +26,7 @@ import org.elasticsearch.common.unit.TimeValue;
import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory;
import org.elasticsearch.search.SearchHit; import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.builder.SearchSourceBuilder; import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.search.sort.SortBuilders;
import org.elasticsearch.watcher.support.init.proxy.ClientProxy; import org.elasticsearch.watcher.support.init.proxy.ClientProxy;
import java.io.IOException; import java.io.IOException;
@ -250,21 +251,18 @@ public class TriggeredWatchStore extends AbstractComponent {
throw illegalState("scan search was supposed to run on [{}] shards, but ran on [{}] shards", numPrimaryShards, response.getSuccessfulShards()); throw illegalState("scan search was supposed to run on [{}] shards, but ran on [{}] shards", numPrimaryShards, response.getSuccessfulShards());
} }
if (response.getHits().getTotalHits() > 0) { while (response.getHits().hits().length != 0) {
response = client.searchScroll(response.getScrollId(), scrollTimeout); for (SearchHit sh : response.getHits()) {
while (response.getHits().hits().length != 0) { String id = sh.getId();
for (SearchHit sh : response.getHits()) { try {
String id = sh.getId(); TriggeredWatch triggeredWatch = triggeredWatchParser.parse(id, sh.version(), sh.getSourceRef());
try { logger.debug("loaded triggered watch [{}/{}/{}]", sh.index(), sh.type(), sh.id());
TriggeredWatch triggeredWatch = triggeredWatchParser.parse(id, sh.version(), sh.getSourceRef()); triggeredWatches.add(triggeredWatch);
logger.debug("loaded triggered watch [{}/{}/{}]", sh.index(), sh.type(), sh.id()); } catch (Exception e) {
triggeredWatches.add(triggeredWatch); logger.error("couldn't load triggered watch [{}], ignoring it...", e, id);
} catch (Exception e) {
logger.error("couldn't load triggered watch [{}], ignoring it...", e, id);
}
} }
response = client.searchScroll(response.getScrollId(), scrollTimeout);
} }
response = client.searchScroll(response.getScrollId(), scrollTimeout);
} }
} finally { } finally {
client.clearScroll(response.getScrollId()); client.clearScroll(response.getScrollId());
@ -274,11 +272,11 @@ public class TriggeredWatchStore extends AbstractComponent {
private SearchRequest createScanSearchRequest() { private SearchRequest createScanSearchRequest() {
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder() SearchSourceBuilder sourceBuilder = new SearchSourceBuilder()
.size(scrollSize); .size(scrollSize)
.sort(SortBuilders.fieldSort("_doc"));
SearchRequest searchRequest = new SearchRequest(INDEX_NAME); SearchRequest searchRequest = new SearchRequest(INDEX_NAME);
searchRequest.source(sourceBuilder); searchRequest.source(sourceBuilder);
searchRequest.searchType(SearchType.SCAN);
searchRequest.types(DOC_TYPE); searchRequest.types(DOC_TYPE);
searchRequest.scroll(scrollTimeout); searchRequest.scroll(scrollTimeout);
searchRequest.preference("_primary"); searchRequest.preference("_primary");

View File

@ -231,9 +231,6 @@ public final class WatcherUtils {
searchRequest.types(Strings.delimitedListToStringArray(typesStr, ",", " \t")); searchRequest.types(Strings.delimitedListToStringArray(typesStr, ",", " \t"));
} else if (ParseFieldMatcher.STRICT.match(currentFieldName, SEARCH_TYPE_FIELD)) { } else if (ParseFieldMatcher.STRICT.match(currentFieldName, SEARCH_TYPE_FIELD)) {
searchType = SearchType.fromString(parser.text().toLowerCase(Locale.ROOT), ParseFieldMatcher.EMPTY); searchType = SearchType.fromString(parser.text().toLowerCase(Locale.ROOT), ParseFieldMatcher.EMPTY);
if (searchType == SearchType.SCAN){
throw new ElasticsearchParseException("could not read search request. value [" + searchType.name() + "] is not supported for field [" + SEARCH_TYPE_FIELD.getPreferredName() + "]" );
}
} else { } else {
throw new ElasticsearchParseException("could not read search request. unexpected string field [" + currentFieldName + "]"); throw new ElasticsearchParseException("could not read search request. unexpected string field [" + currentFieldName + "]");
} }

View File

@ -31,6 +31,7 @@ import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.json.JsonXContent; import org.elasticsearch.common.xcontent.json.JsonXContent;
import org.elasticsearch.search.SearchHit; import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.builder.SearchSourceBuilder; import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.search.sort.SortBuilders;
import org.elasticsearch.watcher.support.init.proxy.ClientProxy; import org.elasticsearch.watcher.support.init.proxy.ClientProxy;
import java.io.IOException; import java.io.IOException;
@ -230,10 +231,10 @@ public class WatchStore extends AbstractComponent {
SearchRequest searchRequest = new SearchRequest(INDEX) SearchRequest searchRequest = new SearchRequest(INDEX)
.types(DOC_TYPE) .types(DOC_TYPE)
.preference("_primary") .preference("_primary")
.searchType(SearchType.SCAN)
.scroll(scrollTimeout) .scroll(scrollTimeout)
.source(new SearchSourceBuilder() .source(new SearchSourceBuilder()
.size(scrollSize) .size(scrollSize)
.sort(SortBuilders.fieldSort("_doc"))
.version(true)); .version(true));
SearchResponse response = client.search(searchRequest, null); SearchResponse response = client.search(searchRequest, null);
try { try {
@ -241,23 +242,20 @@ public class WatchStore extends AbstractComponent {
throw new ElasticsearchException("Partial response while loading watches"); throw new ElasticsearchException("Partial response while loading watches");
} }
if (response.getHits().getTotalHits() > 0) { while (response.getHits().hits().length != 0) {
response = client.searchScroll(response.getScrollId(), scrollTimeout); for (SearchHit hit : response.getHits()) {
while (response.getHits().hits().length != 0) { String id = hit.getId();
for (SearchHit hit : response.getHits()) { try {
String id = hit.getId(); Watch watch = watchParser.parse(id, true, hit.getSourceRef());
try { watch.status().version(hit.version());
Watch watch = watchParser.parse(id, true, hit.getSourceRef()); watch.version(hit.version());
watch.status().version(hit.version()); watches.put(id, watch);
watch.version(hit.version()); count++;
watches.put(id, watch); } catch (Exception e) {
count++; logger.error("couldn't load watch [{}], ignoring it...", e, id);
} catch (Exception e) {
logger.error("couldn't load watch [{}], ignoring it...", e, id);
}
} }
response = client.searchScroll(response.getScrollId(), scrollTimeout);
} }
response = client.searchScroll(response.getScrollId(), scrollTimeout);
} }
} finally { } finally {
client.clearScroll(response.getScrollId()); client.clearScroll(response.getScrollId());

View File

@ -6,6 +6,7 @@
package org.elasticsearch.watcher.input.search; package org.elasticsearch.watcher.input.search;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import org.elasticsearch.ElasticsearchParseException; import org.elasticsearch.ElasticsearchParseException;
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequest; import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequest;
import org.elasticsearch.action.search.SearchRequest; import org.elasticsearch.action.search.SearchRequest;
@ -19,6 +20,7 @@ import org.elasticsearch.common.xcontent.XContentParser;
import org.elasticsearch.common.xcontent.json.JsonXContent; import org.elasticsearch.common.xcontent.json.JsonXContent;
import org.elasticsearch.common.xcontent.support.XContentMapValues; import org.elasticsearch.common.xcontent.support.XContentMapValues;
import org.elasticsearch.search.builder.SearchSourceBuilder; import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.search.sort.SortBuilders;
import org.elasticsearch.test.ESIntegTestCase; import org.elasticsearch.test.ESIntegTestCase;
import org.elasticsearch.test.ESIntegTestCase.ClusterScope; import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
import org.elasticsearch.watcher.actions.ActionStatus; import org.elasticsearch.watcher.actions.ActionStatus;
@ -315,24 +317,6 @@ public class SearchInputTests extends ESIntegTestCase {
assertThat(names, arrayContaining("test", "test-" + DateTimeFormat.forPattern(dateFormat).print(now.minusDays(1)))); assertThat(names, arrayContaining("test", "test-" + DateTimeFormat.forPattern(dateFormat).print(now.minusDays(1))));
} }
@Test(expected = ElasticsearchParseException.class)
public void testParser_ScanNotSupported() throws Exception {
SearchRequest request = client().prepareSearch()
.setSearchType(SearchType.SCAN)
.request()
.source(searchSource()
.query(filteredQuery(matchQuery("event_type", "a"), rangeQuery("_timestamp").from("{{ctx.trigger.scheduled_time}}||-30s").to("{{ctx.trigger.triggered_time}}"))));
XContentBuilder builder = jsonBuilder().value(new SearchInput(request, null, null, null));
XContentParser parser = JsonXContent.jsonXContent.createParser(builder.bytes());
parser.nextToken();
SearchInputFactory factory = new SearchInputFactory(Settings.EMPTY, ClientProxy.of(client()));
factory.parseInput("_id", parser);
fail("expected a SearchInputException as search type SCAN should not be supported");
}
private WatchExecutionContext createContext() { private WatchExecutionContext createContext() {
return new TriggeredExecutionContext( return new TriggeredExecutionContext(
new Watch("test-watch", new Watch("test-watch",

View File

@ -255,7 +255,7 @@ public abstract class AbstractWatcherIntegrationTestCase extends ESIntegTestCase
} }
protected long docCount(String index, String type, SearchSourceBuilder source) { protected long docCount(String index, String type, SearchSourceBuilder source) {
SearchRequestBuilder builder = client().prepareSearch(index).setSearchType(SearchType.COUNT); SearchRequestBuilder builder = client().prepareSearch(index).setSize(0);
if (type != null) { if (type != null) {
builder.setTypes(type); builder.setTypes(type);
} }
@ -378,7 +378,7 @@ public abstract class AbstractWatcherIntegrationTestCase extends ESIntegTestCase
refresh(); refresh();
SearchResponse searchResponse = client().prepareSearch(HistoryStore.INDEX_PREFIX + "*") SearchResponse searchResponse = client().prepareSearch(HistoryStore.INDEX_PREFIX + "*")
.setIndicesOptions(IndicesOptions.lenientExpandOpen()) .setIndicesOptions(IndicesOptions.lenientExpandOpen())
.setSearchType(SearchType.COUNT) .setSize(0)
.setQuery(matchQuery("watch_id", watchName)) .setQuery(matchQuery("watch_id", watchName))
.get(); .get();
return searchResponse.getHits().getTotalHits(); return searchResponse.getHits().getTotalHits();

View File

@ -6,7 +6,6 @@
package org.elasticsearch.watcher.transform.search; package org.elasticsearch.watcher.transform.search;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import org.elasticsearch.ElasticsearchParseException;
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequest; import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequest;
import org.elasticsearch.action.search.SearchRequest; import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.action.search.SearchResponse;
@ -363,27 +362,6 @@ public class SearchTransformTests extends ESIntegTestCase {
assertThat(names, arrayContaining("idx", "idx-" + DateTimeFormat.forPattern(dateFormat).print(now.minusDays(3)))); assertThat(names, arrayContaining("idx", "idx-" + DateTimeFormat.forPattern(dateFormat).print(now.minusDays(3))));
} }
@Test(expected = ElasticsearchParseException.class)
public void testParser_ScanNotSupported() throws Exception {
SearchRequest request = client().prepareSearch()
.setSearchType(SearchType.SCAN)
.request()
.source(searchSource()
.query(filteredQuery(matchQuery("event_type", "a"), rangeQuery("_timestamp").from("{{ctx.trigger.scheduled_time}}||-30s").to("{{ctx.trigger.triggered_time}}"))));
SearchTransform searchTransform = TransformBuilders.searchTransform(request).build();
XContentBuilder builder = jsonBuilder().value(searchTransform);
XContentParser parser = JsonXContent.jsonXContent.createParser(builder.bytes());
parser.nextToken();
DynamicIndexName.Parser indexNamesParser = new DynamicIndexName.Parser();
SearchTransformFactory factory = new SearchTransformFactory(Settings.EMPTY, ClientProxy.of(client()));
factory.parseTransform("_id", parser);
fail("expected a SearchTransformException as search type SCAN should not be supported");
}
@Test @Test
public void testSearch_InlineTemplate() throws Exception { public void testSearch_InlineTemplate() throws Exception {
WatchExecutionContext ctx = createContext(); WatchExecutionContext ctx = createContext();