renamed Data to IngestDocument

moved all metadata related fields to a single metadata map
removed specific metadata getters with a generic getMetadata()
This commit is contained in:
Martijn van Groningen 2015-11-23 13:12:46 +01:00
parent 36655b688c
commit ecc8158b89
27 changed files with 416 additions and 397 deletions

View File

@ -24,26 +24,26 @@ import org.elasticsearch.common.Strings;
import java.util.*; import java.util.*;
/** /**
* Represents the data and meta data (like id and type) of a single document that is going to be indexed. * Represents a single document being captured before indexing and holds the source and meta data (like id, type and index).
*/ */
public final class Data { public final class IngestDocument {
private final String index; private final Map<String, String> metaData;
private final String type; private final Map<String, Object> source;
private final String id;
private final Map<String, Object> document;
private boolean modified = false; private boolean modified = false;
public Data(String index, String type, String id, Map<String, Object> document) { public IngestDocument(String index, String type, String id, Map<String, Object> source) {
this.index = index; this.metaData = new HashMap<>();
this.type = type; this.metaData.put("_index", index);
this.id = id; this.metaData.put("_type", type);
this.document = document; this.metaData.put("_id", id);
this.source = source;
} }
public Data(Data other) { public IngestDocument(IngestDocument other) {
this(other.index, other.type, other.id, new HashMap<>(other.document)); this.metaData = new HashMap<>(other.metaData);
this.source = new HashMap<>(other.source);
} }
/** /**
@ -116,7 +116,7 @@ public final class Data {
} }
private Map<String, Object> getParent(String[] pathElements) { private Map<String, Object> getParent(String[] pathElements) {
Map<String, Object> innerMap = document; Map<String, Object> innerMap = source;
for (int i = 0; i < pathElements.length - 1; i++) { for (int i = 0; i < pathElements.length - 1; i++) {
Object obj = innerMap.get(pathElements[i]); Object obj = innerMap.get(pathElements[i]);
if (obj instanceof Map) { if (obj instanceof Map) {
@ -143,7 +143,7 @@ public final class Data {
String[] pathElements = Strings.splitStringToArray(path, '.'); String[] pathElements = Strings.splitStringToArray(path, '.');
assert pathElements.length > 0; assert pathElements.length > 0;
Map<String, Object> inner = document; Map<String, Object> inner = source;
for (int i = 0; i < pathElements.length - 1; i++) { for (int i = 0; i < pathElements.length - 1; i++) {
String pathElement = pathElements[i]; String pathElement = pathElements[i];
if (inner.containsKey(pathElement)) { if (inner.containsKey(pathElement)) {
@ -169,16 +169,8 @@ public final class Data {
modified = true; modified = true;
} }
public String getIndex() { public String getMetadata(MetaData metaData) {
return index; return this.metaData.get(metaData.getName());
}
public String getType() {
return type;
}
public String getId() {
return id;
} }
/** /**
@ -186,8 +178,8 @@ public final class Data {
* not be reflected to the modified flag. Modify the document instead using {@link #setPropertyValue(String, Object)} * not be reflected to the modified flag. Modify the document instead using {@link #setPropertyValue(String, Object)}
* and {@link #removeProperty(String)} * and {@link #removeProperty(String)}
*/ */
public Map<String, Object> getDocument() { public Map<String, Object> getSource() {
return document; return source;
} }
public boolean isModified() { public boolean isModified() {
@ -201,15 +193,35 @@ public final class Data {
return false; return false;
} }
Data other = (Data) obj; IngestDocument other = (IngestDocument) obj;
return Objects.equals(document, other.document) && return Objects.equals(source, other.source) &&
Objects.equals(index, other.index) && Objects.equals(metaData, other.metaData);
Objects.equals(type, other.type) &&
Objects.equals(id, other.id);
} }
@Override @Override
public int hashCode() { public int hashCode() {
return Objects.hash(index, type, id, document); return Objects.hash(metaData, source);
}
public enum MetaData {
INDEX("_index"),
TYPE("_type"),
ID("_id"),
ROUTING("_routing"),
PARENT("_parent"),
TIMESTAMP("_timestamp"),
TTL("_ttl");
private final String name;
MetaData(String name) {
this.name = name;
}
public String getName() {
return name;
} }
} }
}

View File

@ -44,9 +44,9 @@ public final class Pipeline {
/** /**
* Modifies the data of a document to be indexed based on the processor this pipeline holds * Modifies the data of a document to be indexed based on the processor this pipeline holds
*/ */
public void execute(Data data) { public void execute(IngestDocument ingestDocument) {
for (Processor processor : processors) { for (Processor processor : processors) {
processor.execute(data); processor.execute(ingestDocument);
} }
} }

View File

@ -20,7 +20,7 @@
package org.elasticsearch.ingest.processor; package org.elasticsearch.ingest.processor;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import java.io.Closeable; import java.io.Closeable;
import java.io.IOException; import java.io.IOException;
@ -36,7 +36,7 @@ public interface Processor {
/** /**
* Introspect and potentially modify the incoming data. * Introspect and potentially modify the incoming data.
*/ */
void execute(Data data); void execute(IngestDocument ingestDocument);
/** /**
* Gets the type of a processor * Gets the type of a processor

View File

@ -19,7 +19,7 @@
package org.elasticsearch.ingest.processor.date; package org.elasticsearch.ingest.processor.date;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.processor.ConfigurationUtils; import org.elasticsearch.ingest.processor.ConfigurationUtils;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
import org.joda.time.DateTime; import org.joda.time.DateTime;
@ -56,8 +56,8 @@ public final class DateProcessor implements Processor {
} }
@Override @Override
public void execute(Data data) { public void execute(IngestDocument ingestDocument) {
String value = data.getPropertyValue(matchField, String.class); String value = ingestDocument.getPropertyValue(matchField, String.class);
// TODO(talevy): handle custom timestamp fields // TODO(talevy): handle custom timestamp fields
DateTime dateTime = null; DateTime dateTime = null;
@ -75,7 +75,7 @@ public final class DateProcessor implements Processor {
throw new IllegalArgumentException("unable to parse date [" + value + "]", lastException); throw new IllegalArgumentException("unable to parse date [" + value + "]", lastException);
} }
data.setPropertyValue(targetField, ISODateTimeFormat.dateTime().print(dateTime)); ingestDocument.setPropertyValue(targetField, ISODateTimeFormat.dateTime().print(dateTime));
} }
@Override @Override

View File

@ -26,7 +26,7 @@ import com.maxmind.geoip2.model.CountryResponse;
import com.maxmind.geoip2.record.*; import com.maxmind.geoip2.record.*;
import org.elasticsearch.SpecialPermission; import org.elasticsearch.SpecialPermission;
import org.elasticsearch.common.network.NetworkAddress; import org.elasticsearch.common.network.NetworkAddress;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
import java.io.IOException; import java.io.IOException;
@ -60,8 +60,8 @@ public final class GeoIpProcessor implements Processor {
} }
@Override @Override
public void execute(Data data) { public void execute(IngestDocument ingestDocument) {
String ip = data.getPropertyValue(sourceField, String.class); String ip = ingestDocument.getPropertyValue(sourceField, String.class);
final InetAddress ipAddress; final InetAddress ipAddress;
try { try {
ipAddress = InetAddress.getByName(ip); ipAddress = InetAddress.getByName(ip);
@ -88,7 +88,7 @@ public final class GeoIpProcessor implements Processor {
default: default:
throw new IllegalStateException("Unsupported database type [" + dbReader.getMetadata().getDatabaseType() + "]"); throw new IllegalStateException("Unsupported database type [" + dbReader.getMetadata().getDatabaseType() + "]");
} }
data.setPropertyValue(targetField, geoData); ingestDocument.setPropertyValue(targetField, geoData);
} }
@Override @Override

View File

@ -19,7 +19,7 @@
package org.elasticsearch.ingest.processor.grok; package org.elasticsearch.ingest.processor.grok;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.processor.ConfigurationUtils; import org.elasticsearch.ingest.processor.ConfigurationUtils;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
@ -45,13 +45,13 @@ public final class GrokProcessor implements Processor {
} }
@Override @Override
public void execute(Data data) { public void execute(IngestDocument ingestDocument) {
Object field = data.getPropertyValue(matchField, Object.class); Object field = ingestDocument.getPropertyValue(matchField, Object.class);
// TODO(talevy): handle invalid field types // TODO(talevy): handle invalid field types
if (field instanceof String) { if (field instanceof String) {
Map<String, Object> matches = grok.captures((String) field); Map<String, Object> matches = grok.captures((String) field);
if (matches != null) { if (matches != null) {
matches.forEach((k, v) -> data.setPropertyValue(k, v)); matches.forEach((k, v) -> ingestDocument.setPropertyValue(k, v));
} }
} }
} }

View File

@ -20,7 +20,7 @@
package org.elasticsearch.ingest.processor.mutate; package org.elasticsearch.ingest.processor.mutate;
import org.elasticsearch.common.Booleans; import org.elasticsearch.common.Booleans;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.processor.ConfigurationUtils; import org.elasticsearch.ingest.processor.ConfigurationUtils;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
@ -101,36 +101,36 @@ public final class MutateProcessor implements Processor {
} }
@Override @Override
public void execute(Data data) { public void execute(IngestDocument ingestDocument) {
if (update != null) { if (update != null) {
doUpdate(data); doUpdate(ingestDocument);
} }
if (rename != null) { if (rename != null) {
doRename(data); doRename(ingestDocument);
} }
if (convert != null) { if (convert != null) {
doConvert(data); doConvert(ingestDocument);
} }
if (split != null) { if (split != null) {
doSplit(data); doSplit(ingestDocument);
} }
if (gsub != null) { if (gsub != null) {
doGsub(data); doGsub(ingestDocument);
} }
if (join != null) { if (join != null) {
doJoin(data); doJoin(ingestDocument);
} }
if (remove != null) { if (remove != null) {
doRemove(data); doRemove(ingestDocument);
} }
if (trim != null) { if (trim != null) {
doTrim(data); doTrim(ingestDocument);
} }
if (uppercase != null) { if (uppercase != null) {
doUppercase(data); doUppercase(ingestDocument);
} }
if (lowercase != null) { if (lowercase != null) {
doLowercase(data); doLowercase(ingestDocument);
} }
} }
@ -139,18 +139,18 @@ public final class MutateProcessor implements Processor {
return TYPE; return TYPE;
} }
private void doUpdate(Data data) { private void doUpdate(IngestDocument ingestDocument) {
for(Map.Entry<String, Object> entry : update.entrySet()) { for(Map.Entry<String, Object> entry : update.entrySet()) {
data.setPropertyValue(entry.getKey(), entry.getValue()); ingestDocument.setPropertyValue(entry.getKey(), entry.getValue());
} }
} }
private void doRename(Data data) { private void doRename(IngestDocument ingestDocument) {
for(Map.Entry<String, String> entry : rename.entrySet()) { for(Map.Entry<String, String> entry : rename.entrySet()) {
if (data.hasPropertyValue(entry.getKey())) { if (ingestDocument.hasPropertyValue(entry.getKey())) {
Object oldVal = data.getPropertyValue(entry.getKey(), Object.class); Object oldVal = ingestDocument.getPropertyValue(entry.getKey(), Object.class);
data.getDocument().remove(entry.getKey()); ingestDocument.getSource().remove(entry.getKey());
data.setPropertyValue(entry.getValue(), oldVal); ingestDocument.setPropertyValue(entry.getValue(), oldVal);
} }
} }
} }
@ -175,11 +175,11 @@ public final class MutateProcessor implements Processor {
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
private void doConvert(Data data) { private void doConvert(IngestDocument ingestDocument) {
for(Map.Entry<String, String> entry : convert.entrySet()) { for(Map.Entry<String, String> entry : convert.entrySet()) {
String toType = entry.getValue(); String toType = entry.getValue();
Object oldVal = data.getPropertyValue(entry.getKey(), Object.class); Object oldVal = ingestDocument.getPropertyValue(entry.getKey(), Object.class);
Object newVal; Object newVal;
if (oldVal instanceof List) { if (oldVal instanceof List) {
@ -194,91 +194,91 @@ public final class MutateProcessor implements Processor {
newVal = parseValueAsType(oldVal, toType); newVal = parseValueAsType(oldVal, toType);
} }
data.setPropertyValue(entry.getKey(), newVal); ingestDocument.setPropertyValue(entry.getKey(), newVal);
} }
} }
private void doSplit(Data data) { private void doSplit(IngestDocument ingestDocument) {
for(Map.Entry<String, String> entry : split.entrySet()) { for(Map.Entry<String, String> entry : split.entrySet()) {
Object oldVal = data.getPropertyValue(entry.getKey(), Object.class); Object oldVal = ingestDocument.getPropertyValue(entry.getKey(), Object.class);
if (oldVal == null) { if (oldVal == null) {
throw new IllegalArgumentException("Cannot split field. [" + entry.getKey() + "] is null."); throw new IllegalArgumentException("Cannot split field. [" + entry.getKey() + "] is null.");
} else if (oldVal instanceof String) { } else if (oldVal instanceof String) {
data.setPropertyValue(entry.getKey(), Arrays.asList(((String) oldVal).split(entry.getValue()))); ingestDocument.setPropertyValue(entry.getKey(), Arrays.asList(((String) oldVal).split(entry.getValue())));
} else { } else {
throw new IllegalArgumentException("Cannot split a field that is not a String type"); throw new IllegalArgumentException("Cannot split a field that is not a String type");
} }
} }
} }
private void doGsub(Data data) { private void doGsub(IngestDocument ingestDocument) {
for (GsubExpression gsubExpression : gsub) { for (GsubExpression gsubExpression : gsub) {
String oldVal = data.getPropertyValue(gsubExpression.getFieldName(), String.class); String oldVal = ingestDocument.getPropertyValue(gsubExpression.getFieldName(), String.class);
if (oldVal == null) { if (oldVal == null) {
throw new IllegalArgumentException("Field \"" + gsubExpression.getFieldName() + "\" is null, cannot match pattern."); throw new IllegalArgumentException("Field \"" + gsubExpression.getFieldName() + "\" is null, cannot match pattern.");
} }
Matcher matcher = gsubExpression.getPattern().matcher(oldVal); Matcher matcher = gsubExpression.getPattern().matcher(oldVal);
String newVal = matcher.replaceAll(gsubExpression.getReplacement()); String newVal = matcher.replaceAll(gsubExpression.getReplacement());
data.setPropertyValue(gsubExpression.getFieldName(), newVal); ingestDocument.setPropertyValue(gsubExpression.getFieldName(), newVal);
} }
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
private void doJoin(Data data) { private void doJoin(IngestDocument ingestDocument) {
for(Map.Entry<String, String> entry : join.entrySet()) { for(Map.Entry<String, String> entry : join.entrySet()) {
Object oldVal = data.getPropertyValue(entry.getKey(), Object.class); Object oldVal = ingestDocument.getPropertyValue(entry.getKey(), Object.class);
if (oldVal instanceof List) { if (oldVal instanceof List) {
String joined = (String) ((List) oldVal) String joined = (String) ((List) oldVal)
.stream() .stream()
.map(Object::toString) .map(Object::toString)
.collect(Collectors.joining(entry.getValue())); .collect(Collectors.joining(entry.getValue()));
data.setPropertyValue(entry.getKey(), joined); ingestDocument.setPropertyValue(entry.getKey(), joined);
} else { } else {
throw new IllegalArgumentException("Cannot join field:" + entry.getKey() + " with type: " + oldVal.getClass()); throw new IllegalArgumentException("Cannot join field:" + entry.getKey() + " with type: " + oldVal.getClass());
} }
} }
} }
private void doRemove(Data data) { private void doRemove(IngestDocument ingestDocument) {
for(String field : remove) { for(String field : remove) {
data.getDocument().remove(field); ingestDocument.getSource().remove(field);
} }
} }
private void doTrim(Data data) { private void doTrim(IngestDocument ingestDocument) {
for(String field : trim) { for(String field : trim) {
Object val = data.getPropertyValue(field, Object.class); Object val = ingestDocument.getPropertyValue(field, Object.class);
if (val == null) { if (val == null) {
throw new IllegalArgumentException("Cannot trim field. [" + field + "] is null."); throw new IllegalArgumentException("Cannot trim field. [" + field + "] is null.");
} else if (val instanceof String) { } else if (val instanceof String) {
data.setPropertyValue(field, ((String) val).trim()); ingestDocument.setPropertyValue(field, ((String) val).trim());
} else { } else {
throw new IllegalArgumentException("Cannot trim field:" + field + " with type: " + val.getClass()); throw new IllegalArgumentException("Cannot trim field:" + field + " with type: " + val.getClass());
} }
} }
} }
private void doUppercase(Data data) { private void doUppercase(IngestDocument ingestDocument) {
for(String field : uppercase) { for(String field : uppercase) {
Object val = data.getPropertyValue(field, Object.class); Object val = ingestDocument.getPropertyValue(field, Object.class);
if (val == null) { if (val == null) {
throw new IllegalArgumentException("Cannot uppercase field. [" + field + "] is null."); throw new IllegalArgumentException("Cannot uppercase field. [" + field + "] is null.");
} else if (val instanceof String) { } else if (val instanceof String) {
data.setPropertyValue(field, ((String) val).toUpperCase(Locale.ROOT)); ingestDocument.setPropertyValue(field, ((String) val).toUpperCase(Locale.ROOT));
} else { } else {
throw new IllegalArgumentException("Cannot uppercase field:" + field + " with type: " + val.getClass()); throw new IllegalArgumentException("Cannot uppercase field:" + field + " with type: " + val.getClass());
} }
} }
} }
private void doLowercase(Data data) { private void doLowercase(IngestDocument ingestDocument) {
for(String field : lowercase) { for(String field : lowercase) {
Object val = data.getPropertyValue(field, Object.class); Object val = ingestDocument.getPropertyValue(field, Object.class);
if (val == null) { if (val == null) {
throw new IllegalArgumentException("Cannot lowercase field. [" + field + "] is null."); throw new IllegalArgumentException("Cannot lowercase field. [" + field + "] is null.");
} else if (val instanceof String) { } else if (val instanceof String) {
data.setPropertyValue(field, ((String) val).toLowerCase(Locale.ROOT)); ingestDocument.setPropertyValue(field, ((String) val).toLowerCase(Locale.ROOT));
} else { } else {
throw new IllegalArgumentException("Cannot lowercase field:" + field + " with type: " + val.getClass()); throw new IllegalArgumentException("Cannot lowercase field:" + field + " with type: " + val.getClass());
} }

View File

@ -23,7 +23,7 @@ import org.elasticsearch.common.inject.Inject;
import org.elasticsearch.common.logging.support.LoggerMessageFormat; import org.elasticsearch.common.logging.support.LoggerMessageFormat;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.util.concurrent.EsExecutors; import org.elasticsearch.common.util.concurrent.EsExecutors;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.Pipeline; import org.elasticsearch.ingest.Pipeline;
import org.elasticsearch.threadpool.ThreadPool; import org.elasticsearch.threadpool.ThreadPool;
@ -40,7 +40,7 @@ public class PipelineExecutionService {
this.threadPool = threadPool; this.threadPool = threadPool;
} }
public void execute(Data data, String pipelineId, Listener listener) { public void execute(IngestDocument ingestDocument, String pipelineId, Listener listener) {
Pipeline pipeline = store.get(pipelineId); Pipeline pipeline = store.get(pipelineId);
if (pipeline == null) { if (pipeline == null) {
listener.failed(new IllegalArgumentException(LoggerMessageFormat.format("pipeline with id [{}] does not exist", pipelineId))); listener.failed(new IllegalArgumentException(LoggerMessageFormat.format("pipeline with id [{}] does not exist", pipelineId)));
@ -51,8 +51,8 @@ public class PipelineExecutionService {
@Override @Override
public void run() { public void run() {
try { try {
pipeline.execute(data); pipeline.execute(ingestDocument);
listener.executed(data); listener.executed(ingestDocument);
} catch (Exception e) { } catch (Exception e) {
listener.failed(e); listener.failed(e);
} }
@ -62,7 +62,7 @@ public class PipelineExecutionService {
public interface Listener { public interface Listener {
void executed(Data data); void executed(IngestDocument ingestDocument);
void failed(Exception e); void failed(Exception e);

View File

@ -29,7 +29,7 @@ import org.elasticsearch.action.support.ActionFilterChain;
import org.elasticsearch.common.component.AbstractComponent; import org.elasticsearch.common.component.AbstractComponent;
import org.elasticsearch.common.inject.Inject; import org.elasticsearch.common.inject.Inject;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.plugin.ingest.IngestPlugin; import org.elasticsearch.plugin.ingest.IngestPlugin;
import org.elasticsearch.plugin.ingest.PipelineExecutionService; import org.elasticsearch.plugin.ingest.PipelineExecutionService;
@ -82,12 +82,12 @@ public class IngestActionFilter extends AbstractComponent implements ActionFilte
} }
Map<String, Object> sourceAsMap = indexRequest.sourceAsMap(); Map<String, Object> sourceAsMap = indexRequest.sourceAsMap();
Data data = new Data(indexRequest.index(), indexRequest.type(), indexRequest.id(), sourceAsMap); IngestDocument ingestDocument = new IngestDocument(indexRequest.index(), indexRequest.type(), indexRequest.id(), sourceAsMap);
executionService.execute(data, pipelineId, new PipelineExecutionService.Listener() { executionService.execute(ingestDocument, pipelineId, new PipelineExecutionService.Listener() {
@Override @Override
public void executed(Data data) { public void executed(IngestDocument ingestDocument) {
if (data.isModified()) { if (ingestDocument.isModified()) {
indexRequest.source(data.getDocument()); indexRequest.source(ingestDocument.getSource());
} }
indexRequest.putHeader(IngestPlugin.PIPELINE_ALREADY_PROCESSED, true); indexRequest.putHeader(IngestPlugin.PIPELINE_ALREADY_PROCESSED, true);
chain.proceed(action, indexRequest, listener); chain.proceed(action, indexRequest, listener);
@ -115,12 +115,12 @@ public class IngestActionFilter extends AbstractComponent implements ActionFilte
IndexRequest indexRequest = (IndexRequest) actionRequest; IndexRequest indexRequest = (IndexRequest) actionRequest;
Map<String, Object> sourceAsMap = indexRequest.sourceAsMap(); Map<String, Object> sourceAsMap = indexRequest.sourceAsMap();
Data data = new Data(indexRequest.index(), indexRequest.type(), indexRequest.id(), sourceAsMap); IngestDocument ingestDocument = new IngestDocument(indexRequest.index(), indexRequest.type(), indexRequest.id(), sourceAsMap);
executionService.execute(data, pipelineId, new PipelineExecutionService.Listener() { executionService.execute(ingestDocument, pipelineId, new PipelineExecutionService.Listener() {
@Override @Override
public void executed(Data data) { public void executed(IngestDocument ingestDocument) {
if (data.isModified()) { if (ingestDocument.isModified()) {
indexRequest.source(data.getDocument()); indexRequest.source(ingestDocument.getSource());
} }
processBulkIndexRequest(action, listener, chain, bulkRequest, pipelineId, requests); processBulkIndexRequest(action, listener, chain, bulkRequest, pipelineId, requests);
} }

View File

@ -25,24 +25,28 @@ import org.elasticsearch.common.io.stream.Writeable;
import org.elasticsearch.common.xcontent.ToXContent; import org.elasticsearch.common.xcontent.ToXContent;
import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.XContentBuilderString; import org.elasticsearch.common.xcontent.XContentBuilderString;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import java.io.IOException; import java.io.IOException;
import java.util.Map; import java.util.Map;
import java.util.Objects; import java.util.Objects;
import static org.elasticsearch.ingest.IngestDocument.MetaData.ID;
import static org.elasticsearch.ingest.IngestDocument.MetaData.INDEX;
import static org.elasticsearch.ingest.IngestDocument.MetaData.TYPE;
public class TransportData implements Writeable<TransportData>, ToXContent { public class TransportData implements Writeable<TransportData>, ToXContent {
private static final TransportData PROTOTYPE = new TransportData(null); private static final TransportData PROTOTYPE = new TransportData(null);
private final Data data; private final IngestDocument ingestDocument;
public TransportData(Data data) { public TransportData(IngestDocument ingestDocument) {
this.data = data; this.ingestDocument = ingestDocument;
} }
public Data get() { public IngestDocument get() {
return data; return ingestDocument;
} }
public static TransportData readTransportDataFrom(StreamInput in) throws IOException { public static TransportData readTransportDataFrom(StreamInput in) throws IOException {
@ -55,25 +59,25 @@ public class TransportData implements Writeable<TransportData>, ToXContent {
String type = in.readString(); String type = in.readString();
String id = in.readString(); String id = in.readString();
Map<String, Object> doc = in.readMap(); Map<String, Object> doc = in.readMap();
return new TransportData(new Data(index, type, id, doc)); return new TransportData(new IngestDocument(index, type, id, doc));
} }
@Override @Override
public void writeTo(StreamOutput out) throws IOException { public void writeTo(StreamOutput out) throws IOException {
out.writeString(data.getIndex()); out.writeString(ingestDocument.getMetadata(INDEX));
out.writeString(data.getType()); out.writeString(ingestDocument.getMetadata(TYPE));
out.writeString(data.getId()); out.writeString(ingestDocument.getMetadata(ID));
out.writeMap(data.getDocument()); out.writeMap(ingestDocument.getSource());
} }
@Override @Override
public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException { public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException {
builder.startObject(Fields.DOCUMENT); builder.startObject(Fields.DOCUMENT);
builder.field(Fields.MODIFIED, data.isModified()); builder.field(Fields.MODIFIED, ingestDocument.isModified());
builder.field(Fields.INDEX, data.getIndex()); builder.field(Fields.INDEX, ingestDocument.getMetadata(INDEX));
builder.field(Fields.TYPE, data.getType()); builder.field(Fields.TYPE, ingestDocument.getMetadata(TYPE));
builder.field(Fields.ID, data.getId()); builder.field(Fields.ID, ingestDocument.getMetadata(ID));
builder.field(Fields.SOURCE, data.getDocument()); builder.field(Fields.SOURCE, ingestDocument.getSource());
builder.endObject(); builder.endObject();
return builder; return builder;
} }
@ -87,12 +91,12 @@ public class TransportData implements Writeable<TransportData>, ToXContent {
return false; return false;
} }
TransportData that = (TransportData) o; TransportData that = (TransportData) o;
return Objects.equals(data, that.data); return Objects.equals(ingestDocument, that.ingestDocument);
} }
@Override @Override
public int hashCode() { public int hashCode() {
return Objects.hash(data); return Objects.hash(ingestDocument);
} }
static final class Fields { static final class Fields {

View File

@ -18,7 +18,7 @@
*/ */
package org.elasticsearch.plugin.ingest.transport.simulate; package org.elasticsearch.plugin.ingest.transport.simulate;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.Pipeline; import org.elasticsearch.ingest.Pipeline;
import org.elasticsearch.ingest.processor.ConfigurationUtils; import org.elasticsearch.ingest.processor.ConfigurationUtils;
import org.elasticsearch.plugin.ingest.PipelineStore; import org.elasticsearch.plugin.ingest.PipelineStore;
@ -29,11 +29,11 @@ import java.util.*;
import static org.elasticsearch.plugin.ingest.transport.simulate.SimulatePipelineRequest.Fields; import static org.elasticsearch.plugin.ingest.transport.simulate.SimulatePipelineRequest.Fields;
public class ParsedSimulateRequest { public class ParsedSimulateRequest {
private final List<Data> documents; private final List<IngestDocument> documents;
private final Pipeline pipeline; private final Pipeline pipeline;
private final boolean verbose; private final boolean verbose;
ParsedSimulateRequest(Pipeline pipeline, List<Data> documents, boolean verbose) { ParsedSimulateRequest(Pipeline pipeline, List<IngestDocument> documents, boolean verbose) {
this.pipeline = pipeline; this.pipeline = pipeline;
this.documents = Collections.unmodifiableList(documents); this.documents = Collections.unmodifiableList(documents);
this.verbose = verbose; this.verbose = verbose;
@ -43,7 +43,7 @@ public class ParsedSimulateRequest {
return pipeline; return pipeline;
} }
public List<Data> getDocuments() { public List<IngestDocument> getDocuments() {
return documents; return documents;
} }
@ -55,18 +55,18 @@ public class ParsedSimulateRequest {
private static final Pipeline.Factory PIPELINE_FACTORY = new Pipeline.Factory(); private static final Pipeline.Factory PIPELINE_FACTORY = new Pipeline.Factory();
public static final String SIMULATED_PIPELINE_ID = "_simulate_pipeline"; public static final String SIMULATED_PIPELINE_ID = "_simulate_pipeline";
private List<Data> parseDocs(Map<String, Object> config) { private List<IngestDocument> parseDocs(Map<String, Object> config) {
List<Map<String, Object>> docs = ConfigurationUtils.readList(config, Fields.DOCS); List<Map<String, Object>> docs = ConfigurationUtils.readList(config, Fields.DOCS);
List<Data> dataList = new ArrayList<>(); List<IngestDocument> ingestDocumentList = new ArrayList<>();
for (Map<String, Object> dataMap : docs) { for (Map<String, Object> dataMap : docs) {
Map<String, Object> document = ConfigurationUtils.readMap(dataMap, Fields.SOURCE); Map<String, Object> document = ConfigurationUtils.readMap(dataMap, Fields.SOURCE);
Data data = new Data(ConfigurationUtils.readStringProperty(dataMap, Fields.INDEX), IngestDocument ingestDocument = new IngestDocument(ConfigurationUtils.readStringProperty(dataMap, Fields.INDEX),
ConfigurationUtils.readStringProperty(dataMap, Fields.TYPE), ConfigurationUtils.readStringProperty(dataMap, Fields.TYPE),
ConfigurationUtils.readStringProperty(dataMap, Fields.ID), ConfigurationUtils.readStringProperty(dataMap, Fields.ID),
document); document);
dataList.add(data); ingestDocumentList.add(ingestDocument);
} }
return dataList; return ingestDocumentList;
} }
public ParsedSimulateRequest parseWithPipelineId(String pipelineId, Map<String, Object> config, boolean verbose, PipelineStore pipelineStore) { public ParsedSimulateRequest parseWithPipelineId(String pipelineId, Map<String, Object> config, boolean verbose, PipelineStore pipelineStore) {
@ -74,16 +74,16 @@ public class ParsedSimulateRequest {
throw new IllegalArgumentException("param [pipeline] is null"); throw new IllegalArgumentException("param [pipeline] is null");
} }
Pipeline pipeline = pipelineStore.get(pipelineId); Pipeline pipeline = pipelineStore.get(pipelineId);
List<Data> dataList = parseDocs(config); List<IngestDocument> ingestDocumentList = parseDocs(config);
return new ParsedSimulateRequest(pipeline, dataList, verbose); return new ParsedSimulateRequest(pipeline, ingestDocumentList, verbose);
} }
public ParsedSimulateRequest parse(Map<String, Object> config, boolean verbose, PipelineStore pipelineStore) throws IOException { public ParsedSimulateRequest parse(Map<String, Object> config, boolean verbose, PipelineStore pipelineStore) throws IOException {
Map<String, Object> pipelineConfig = ConfigurationUtils.readMap(config, Fields.PIPELINE); Map<String, Object> pipelineConfig = ConfigurationUtils.readMap(config, Fields.PIPELINE);
Pipeline pipeline = PIPELINE_FACTORY.create(SIMULATED_PIPELINE_ID, pipelineConfig, pipelineStore.getProcessorFactoryRegistry()); Pipeline pipeline = PIPELINE_FACTORY.create(SIMULATED_PIPELINE_ID, pipelineConfig, pipelineStore.getProcessorFactoryRegistry());
List<Data> dataList = parseDocs(config); List<IngestDocument> ingestDocumentList = parseDocs(config);
return new ParsedSimulateRequest(pipeline, dataList, verbose); return new ParsedSimulateRequest(pipeline, ingestDocumentList, verbose);
} }
} }
} }

View File

@ -22,20 +22,20 @@ import org.elasticsearch.ElasticsearchException;
import org.elasticsearch.common.io.stream.StreamInput; import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.common.io.stream.StreamOutput; import org.elasticsearch.common.io.stream.StreamOutput;
import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.plugin.ingest.transport.TransportData; import org.elasticsearch.plugin.ingest.transport.TransportData;
import java.io.IOException; import java.io.IOException;
public class SimulateDocumentSimpleResult implements SimulateDocumentResult<SimulateDocumentSimpleResult> { public class SimulateDocumentSimpleResult implements SimulateDocumentResult<SimulateDocumentSimpleResult> {
private static final SimulateDocumentSimpleResult PROTOTYPE = new SimulateDocumentSimpleResult((Data)null); private static final SimulateDocumentSimpleResult PROTOTYPE = new SimulateDocumentSimpleResult((IngestDocument)null);
private TransportData data; private TransportData data;
private Exception failure; private Exception failure;
public SimulateDocumentSimpleResult(Data data) { public SimulateDocumentSimpleResult(IngestDocument ingestDocument) {
this.data = new TransportData(data); this.data = new TransportData(ingestDocument);
} }
private SimulateDocumentSimpleResult(TransportData data) { private SimulateDocumentSimpleResult(TransportData data) {
@ -46,7 +46,7 @@ public class SimulateDocumentSimpleResult implements SimulateDocumentResult<Simu
this.failure = failure; this.failure = failure;
} }
public Data getData() { public IngestDocument getData() {
if (data == null) { if (data == null) {
return null; return null;
} }

View File

@ -21,7 +21,7 @@ package org.elasticsearch.plugin.ingest.transport.simulate;
import org.elasticsearch.action.ActionListener; import org.elasticsearch.action.ActionListener;
import org.elasticsearch.common.inject.Inject; import org.elasticsearch.common.inject.Inject;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.Pipeline; import org.elasticsearch.ingest.Pipeline;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
import org.elasticsearch.threadpool.ThreadPool; import org.elasticsearch.threadpool.ThreadPool;
@ -40,30 +40,30 @@ public class SimulateExecutionService {
this.threadPool = threadPool; this.threadPool = threadPool;
} }
SimulateDocumentResult executeItem(Pipeline pipeline, Data data) { SimulateDocumentResult executeItem(Pipeline pipeline, IngestDocument ingestDocument) {
try { try {
pipeline.execute(data); pipeline.execute(ingestDocument);
return new SimulateDocumentSimpleResult(data); return new SimulateDocumentSimpleResult(ingestDocument);
} catch (Exception e) { } catch (Exception e) {
return new SimulateDocumentSimpleResult(e); return new SimulateDocumentSimpleResult(e);
} }
} }
SimulateDocumentVerboseResult executeVerboseItem(Pipeline pipeline, Data data) { SimulateDocumentVerboseResult executeVerboseItem(Pipeline pipeline, IngestDocument ingestDocument) {
List<SimulateProcessorResult> processorResultList = new ArrayList<>(); List<SimulateProcessorResult> processorResultList = new ArrayList<>();
Data currentData = new Data(data); IngestDocument currentIngestDocument = new IngestDocument(ingestDocument);
for (int i = 0; i < pipeline.getProcessors().size(); i++) { for (int i = 0; i < pipeline.getProcessors().size(); i++) {
Processor processor = pipeline.getProcessors().get(i); Processor processor = pipeline.getProcessors().get(i);
String processorId = "processor[" + processor.getType() + "]-" + i; String processorId = "processor[" + processor.getType() + "]-" + i;
try { try {
processor.execute(currentData); processor.execute(currentIngestDocument);
processorResultList.add(new SimulateProcessorResult(processorId, currentData)); processorResultList.add(new SimulateProcessorResult(processorId, currentIngestDocument));
} catch (Exception e) { } catch (Exception e) {
processorResultList.add(new SimulateProcessorResult(processorId, e)); processorResultList.add(new SimulateProcessorResult(processorId, e));
} }
currentData = new Data(currentData); currentIngestDocument = new IngestDocument(currentIngestDocument);
} }
return new SimulateDocumentVerboseResult(processorResultList); return new SimulateDocumentVerboseResult(processorResultList);
} }
@ -73,11 +73,11 @@ public class SimulateExecutionService {
@Override @Override
public void run() { public void run() {
List<SimulateDocumentResult> responses = new ArrayList<>(); List<SimulateDocumentResult> responses = new ArrayList<>();
for (Data data : request.getDocuments()) { for (IngestDocument ingestDocument : request.getDocuments()) {
if (request.isVerbose()) { if (request.isVerbose()) {
responses.add(executeVerboseItem(request.getPipeline(), data)); responses.add(executeVerboseItem(request.getPipeline(), ingestDocument));
} else { } else {
responses.add(executeItem(request.getPipeline(), data)); responses.add(executeItem(request.getPipeline(), ingestDocument));
} }
} }
listener.onResponse(new SimulatePipelineResponse(request.getPipeline().getId(), request.isVerbose(), responses)); listener.onResponse(new SimulatePipelineResponse(request.getPipeline().getId(), request.isVerbose(), responses));

View File

@ -25,22 +25,22 @@ import org.elasticsearch.common.io.stream.Writeable;
import org.elasticsearch.common.xcontent.ToXContent; import org.elasticsearch.common.xcontent.ToXContent;
import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.common.xcontent.XContentBuilderString; import org.elasticsearch.common.xcontent.XContentBuilderString;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.plugin.ingest.transport.TransportData; import org.elasticsearch.plugin.ingest.transport.TransportData;
import java.io.IOException; import java.io.IOException;
public class SimulateProcessorResult implements Writeable<SimulateProcessorResult>, ToXContent { public class SimulateProcessorResult implements Writeable<SimulateProcessorResult>, ToXContent {
private static final SimulateProcessorResult PROTOTYPE = new SimulateProcessorResult(null, (Data)null); private static final SimulateProcessorResult PROTOTYPE = new SimulateProcessorResult(null, (IngestDocument)null);
private String processorId; private String processorId;
private TransportData data; private TransportData data;
private Exception failure; private Exception failure;
public SimulateProcessorResult(String processorId, Data data) { public SimulateProcessorResult(String processorId, IngestDocument ingestDocument) {
this.processorId = processorId; this.processorId = processorId;
this.data = new TransportData(data); this.data = new TransportData(ingestDocument);
} }
private SimulateProcessorResult(String processorId, TransportData data) { private SimulateProcessorResult(String processorId, TransportData data) {
@ -53,7 +53,7 @@ public class SimulateProcessorResult implements Writeable<SimulateProcessorResul
this.failure = failure; this.failure = failure;
} }
public Data getData() { public IngestDocument getData() {
if (data == null) { if (data == null) {
return null; return null;
} }

View File

@ -30,7 +30,7 @@ import static org.hamcrest.Matchers.*;
public class DataTests extends ESTestCase { public class DataTests extends ESTestCase {
private Data data; private IngestDocument ingestDocument;
@Before @Before
public void setData() { public void setData() {
@ -41,28 +41,28 @@ public class DataTests extends ESTestCase {
innerObject.put("buzz", "hello world"); innerObject.put("buzz", "hello world");
innerObject.put("foo_null", null); innerObject.put("foo_null", null);
document.put("fizz", innerObject); document.put("fizz", innerObject);
data = new Data("index", "type", "id", document); ingestDocument = new IngestDocument("index", "type", "id", document);
} }
public void testSimpleGetPropertyValue() { public void testSimpleGetPropertyValue() {
assertThat(data.getPropertyValue("foo", String.class), equalTo("bar")); assertThat(ingestDocument.getPropertyValue("foo", String.class), equalTo("bar"));
assertThat(data.getPropertyValue("int", Integer.class), equalTo(123)); assertThat(ingestDocument.getPropertyValue("int", Integer.class), equalTo(123));
} }
public void testGetPropertyValueNullValue() { public void testGetPropertyValueNullValue() {
assertThat(data.getPropertyValue("fizz.foo_null", Object.class), nullValue()); assertThat(ingestDocument.getPropertyValue("fizz.foo_null", Object.class), nullValue());
} }
public void testSimpleGetPropertyValueTypeMismatch() { public void testSimpleGetPropertyValueTypeMismatch() {
try { try {
data.getPropertyValue("int", String.class); ingestDocument.getPropertyValue("int", String.class);
fail("getProperty should have failed"); fail("getProperty should have failed");
} catch(IllegalArgumentException e) { } catch(IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("field [int] of type [java.lang.Integer] cannot be cast to [java.lang.String]")); assertThat(e.getMessage(), equalTo("field [int] of type [java.lang.Integer] cannot be cast to [java.lang.String]"));
} }
try { try {
data.getPropertyValue("foo", Integer.class); ingestDocument.getPropertyValue("foo", Integer.class);
fail("getProperty should have failed"); fail("getProperty should have failed");
} catch(IllegalArgumentException e) { } catch(IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("field [foo] of type [java.lang.String] cannot be cast to [java.lang.Integer]")); assertThat(e.getMessage(), equalTo("field [foo] of type [java.lang.String] cannot be cast to [java.lang.Integer]"));
@ -70,67 +70,67 @@ public class DataTests extends ESTestCase {
} }
public void testNestedGetPropertyValue() { public void testNestedGetPropertyValue() {
assertThat(data.getPropertyValue("fizz.buzz", String.class), equalTo("hello world")); assertThat(ingestDocument.getPropertyValue("fizz.buzz", String.class), equalTo("hello world"));
} }
public void testGetPropertyValueNotFound() { public void testGetPropertyValueNotFound() {
assertThat(data.getPropertyValue("not.here", String.class), nullValue()); assertThat(ingestDocument.getPropertyValue("not.here", String.class), nullValue());
} }
public void testGetPropertyValueNull() { public void testGetPropertyValueNull() {
assertNull(data.getPropertyValue(null, String.class)); assertNull(ingestDocument.getPropertyValue(null, String.class));
} }
public void testGetPropertyValueEmpty() { public void testGetPropertyValueEmpty() {
assertNull(data.getPropertyValue("", String.class)); assertNull(ingestDocument.getPropertyValue("", String.class));
} }
public void testHasProperty() { public void testHasProperty() {
assertTrue(data.hasPropertyValue("fizz")); assertTrue(ingestDocument.hasPropertyValue("fizz"));
} }
public void testHasPropertyValueNested() { public void testHasPropertyValueNested() {
assertTrue(data.hasPropertyValue("fizz.buzz")); assertTrue(ingestDocument.hasPropertyValue("fizz.buzz"));
} }
public void testHasPropertyValueNotFound() { public void testHasPropertyValueNotFound() {
assertFalse(data.hasPropertyValue("doesnotexist")); assertFalse(ingestDocument.hasPropertyValue("doesnotexist"));
} }
public void testHasPropertyValueNestedNotFound() { public void testHasPropertyValueNestedNotFound() {
assertFalse(data.hasPropertyValue("fizz.doesnotexist")); assertFalse(ingestDocument.hasPropertyValue("fizz.doesnotexist"));
} }
public void testHasPropertyValueNull() { public void testHasPropertyValueNull() {
assertFalse(data.hasPropertyValue(null)); assertFalse(ingestDocument.hasPropertyValue(null));
} }
public void testHasPropertyValueNullValue() { public void testHasPropertyValueNullValue() {
assertTrue(data.hasPropertyValue("fizz.foo_null")); assertTrue(ingestDocument.hasPropertyValue("fizz.foo_null"));
} }
public void testHasPropertyValueEmpty() { public void testHasPropertyValueEmpty() {
assertFalse(data.hasPropertyValue("")); assertFalse(ingestDocument.hasPropertyValue(""));
} }
public void testSimpleSetPropertyValue() { public void testSimpleSetPropertyValue() {
data.setPropertyValue("new_field", "foo"); ingestDocument.setPropertyValue("new_field", "foo");
assertThat(data.getDocument().get("new_field"), equalTo("foo")); assertThat(ingestDocument.getSource().get("new_field"), equalTo("foo"));
assertThat(data.isModified(), equalTo(true)); assertThat(ingestDocument.isModified(), equalTo(true));
} }
public void testSetPropertyValueNullValue() { public void testSetPropertyValueNullValue() {
data.setPropertyValue("new_field", null); ingestDocument.setPropertyValue("new_field", null);
assertThat(data.getDocument().containsKey("new_field"), equalTo(true)); assertThat(ingestDocument.getSource().containsKey("new_field"), equalTo(true));
assertThat(data.getDocument().get("new_field"), nullValue()); assertThat(ingestDocument.getSource().get("new_field"), nullValue());
assertThat(data.isModified(), equalTo(true)); assertThat(ingestDocument.isModified(), equalTo(true));
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public void testNestedSetPropertyValue() { public void testNestedSetPropertyValue() {
data.setPropertyValue("a.b.c.d", "foo"); ingestDocument.setPropertyValue("a.b.c.d", "foo");
assertThat(data.getDocument().get("a"), instanceOf(Map.class)); assertThat(ingestDocument.getSource().get("a"), instanceOf(Map.class));
Map<String, Object> a = (Map<String, Object>) data.getDocument().get("a"); Map<String, Object> a = (Map<String, Object>) ingestDocument.getSource().get("a");
assertThat(a.get("b"), instanceOf(Map.class)); assertThat(a.get("b"), instanceOf(Map.class));
Map<String, Object> b = (Map<String, Object>) a.get("b"); Map<String, Object> b = (Map<String, Object>) a.get("b");
assertThat(b.get("c"), instanceOf(Map.class)); assertThat(b.get("c"), instanceOf(Map.class));
@ -138,110 +138,110 @@ public class DataTests extends ESTestCase {
assertThat(c.get("d"), instanceOf(String.class)); assertThat(c.get("d"), instanceOf(String.class));
String d = (String) c.get("d"); String d = (String) c.get("d");
assertThat(d, equalTo("foo")); assertThat(d, equalTo("foo"));
assertThat(data.isModified(), equalTo(true)); assertThat(ingestDocument.isModified(), equalTo(true));
} }
public void testSetPropertyValueOnExistingField() { public void testSetPropertyValueOnExistingField() {
data.setPropertyValue("foo", "newbar"); ingestDocument.setPropertyValue("foo", "newbar");
assertThat(data.getDocument().get("foo"), equalTo("newbar")); assertThat(ingestDocument.getSource().get("foo"), equalTo("newbar"));
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public void testSetPropertyValueOnExistingParent() { public void testSetPropertyValueOnExistingParent() {
data.setPropertyValue("fizz.new", "bar"); ingestDocument.setPropertyValue("fizz.new", "bar");
assertThat(data.getDocument().get("fizz"), instanceOf(Map.class)); assertThat(ingestDocument.getSource().get("fizz"), instanceOf(Map.class));
Map<String, Object> innerMap = (Map<String, Object>) data.getDocument().get("fizz"); Map<String, Object> innerMap = (Map<String, Object>) ingestDocument.getSource().get("fizz");
assertThat(innerMap.get("new"), instanceOf(String.class)); assertThat(innerMap.get("new"), instanceOf(String.class));
String value = (String) innerMap.get("new"); String value = (String) innerMap.get("new");
assertThat(value, equalTo("bar")); assertThat(value, equalTo("bar"));
assertThat(data.isModified(), equalTo(true)); assertThat(ingestDocument.isModified(), equalTo(true));
} }
public void testSetPropertyValueOnExistingParentTypeMismatch() { public void testSetPropertyValueOnExistingParentTypeMismatch() {
try { try {
data.setPropertyValue("fizz.buzz.new", "bar"); ingestDocument.setPropertyValue("fizz.buzz.new", "bar");
fail("add field should have failed"); fail("add field should have failed");
} catch(IllegalArgumentException e) { } catch(IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("cannot add field to parent [buzz] of type [java.lang.String], [java.util.Map] expected instead.")); assertThat(e.getMessage(), equalTo("cannot add field to parent [buzz] of type [java.lang.String], [java.util.Map] expected instead."));
assertThat(data.isModified(), equalTo(false)); assertThat(ingestDocument.isModified(), equalTo(false));
} }
} }
public void testSetPropertyValueOnExistingNullParent() { public void testSetPropertyValueOnExistingNullParent() {
try { try {
data.setPropertyValue("fizz.foo_null.test", "bar"); ingestDocument.setPropertyValue("fizz.foo_null.test", "bar");
fail("add field should have failed"); fail("add field should have failed");
} catch(IllegalArgumentException e) { } catch(IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("cannot add field to null parent, [java.util.Map] expected instead.")); assertThat(e.getMessage(), equalTo("cannot add field to null parent, [java.util.Map] expected instead."));
assertThat(data.isModified(), equalTo(false)); assertThat(ingestDocument.isModified(), equalTo(false));
} }
} }
public void testSetPropertyValueNullName() { public void testSetPropertyValueNullName() {
try { try {
data.setPropertyValue(null, "bar"); ingestDocument.setPropertyValue(null, "bar");
fail("add field should have failed"); fail("add field should have failed");
} catch(IllegalArgumentException e) { } catch(IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("cannot add null or empty field")); assertThat(e.getMessage(), equalTo("cannot add null or empty field"));
assertThat(data.isModified(), equalTo(false)); assertThat(ingestDocument.isModified(), equalTo(false));
} }
} }
public void testSetPropertyValueEmptyName() { public void testSetPropertyValueEmptyName() {
try { try {
data.setPropertyValue("", "bar"); ingestDocument.setPropertyValue("", "bar");
fail("add field should have failed"); fail("add field should have failed");
} catch(IllegalArgumentException e) { } catch(IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("cannot add null or empty field")); assertThat(e.getMessage(), equalTo("cannot add null or empty field"));
assertThat(data.isModified(), equalTo(false)); assertThat(ingestDocument.isModified(), equalTo(false));
} }
} }
public void testRemoveProperty() { public void testRemoveProperty() {
data.removeProperty("foo"); ingestDocument.removeProperty("foo");
assertThat(data.isModified(), equalTo(true)); assertThat(ingestDocument.isModified(), equalTo(true));
assertThat(data.getDocument().size(), equalTo(2)); assertThat(ingestDocument.getSource().size(), equalTo(2));
assertThat(data.getDocument().containsKey("foo"), equalTo(false)); assertThat(ingestDocument.getSource().containsKey("foo"), equalTo(false));
} }
public void testRemoveInnerProperty() { public void testRemoveInnerProperty() {
data.removeProperty("fizz.buzz"); ingestDocument.removeProperty("fizz.buzz");
assertThat(data.getDocument().size(), equalTo(3)); assertThat(ingestDocument.getSource().size(), equalTo(3));
assertThat(data.getDocument().get("fizz"), instanceOf(Map.class)); assertThat(ingestDocument.getSource().get("fizz"), instanceOf(Map.class));
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
Map<String, Object> map = (Map<String, Object>)data.getDocument().get("fizz"); Map<String, Object> map = (Map<String, Object>) ingestDocument.getSource().get("fizz");
assertThat(map.size(), equalTo(1)); assertThat(map.size(), equalTo(1));
assertThat(map.containsKey("buzz"), equalTo(false)); assertThat(map.containsKey("buzz"), equalTo(false));
data.removeProperty("fizz.foo_null"); ingestDocument.removeProperty("fizz.foo_null");
assertThat(map.size(), equalTo(0)); assertThat(map.size(), equalTo(0));
assertThat(data.getDocument().size(), equalTo(3)); assertThat(ingestDocument.getSource().size(), equalTo(3));
assertThat(data.getDocument().containsKey("fizz"), equalTo(true)); assertThat(ingestDocument.getSource().containsKey("fizz"), equalTo(true));
assertThat(data.isModified(), equalTo(true)); assertThat(ingestDocument.isModified(), equalTo(true));
} }
public void testRemoveNonExistingProperty() { public void testRemoveNonExistingProperty() {
data.removeProperty("does_not_exist"); ingestDocument.removeProperty("does_not_exist");
assertThat(data.isModified(), equalTo(false)); assertThat(ingestDocument.isModified(), equalTo(false));
assertThat(data.getDocument().size(), equalTo(3)); assertThat(ingestDocument.getSource().size(), equalTo(3));
} }
public void testRemoveExistingParentTypeMismatch() { public void testRemoveExistingParentTypeMismatch() {
data.removeProperty("foo.test"); ingestDocument.removeProperty("foo.test");
assertThat(data.isModified(), equalTo(false)); assertThat(ingestDocument.isModified(), equalTo(false));
assertThat(data.getDocument().size(), equalTo(3)); assertThat(ingestDocument.getSource().size(), equalTo(3));
} }
public void testRemoveNullProperty() { public void testRemoveNullProperty() {
data.removeProperty(null); ingestDocument.removeProperty(null);
assertThat(data.isModified(), equalTo(false)); assertThat(ingestDocument.isModified(), equalTo(false));
assertThat(data.getDocument().size(), equalTo(3)); assertThat(ingestDocument.getSource().size(), equalTo(3));
} }
public void testRemoveEmptyProperty() { public void testRemoveEmptyProperty() {
data.removeProperty(""); ingestDocument.removeProperty("");
assertThat(data.isModified(), equalTo(false)); assertThat(ingestDocument.isModified(), equalTo(false));
assertThat(data.getDocument().size(), equalTo(3)); assertThat(ingestDocument.getSource().size(), equalTo(3));
} }
public void testEqualsAndHashcode() throws Exception { public void testEqualsAndHashcode() throws Exception {
@ -250,7 +250,7 @@ public class DataTests extends ESTestCase {
String id = randomAsciiOfLengthBetween(1, 10); String id = randomAsciiOfLengthBetween(1, 10);
String fieldName = randomAsciiOfLengthBetween(1, 10); String fieldName = randomAsciiOfLengthBetween(1, 10);
String fieldValue = randomAsciiOfLengthBetween(1, 10); String fieldValue = randomAsciiOfLengthBetween(1, 10);
Data data = new Data(index, type, id, Collections.singletonMap(fieldName, fieldValue)); IngestDocument ingestDocument = new IngestDocument(index, type, id, Collections.singletonMap(fieldName, fieldValue));
boolean changed = false; boolean changed = false;
String otherIndex; String otherIndex;
@ -282,16 +282,16 @@ public class DataTests extends ESTestCase {
document = Collections.singletonMap(fieldName, fieldValue); document = Collections.singletonMap(fieldName, fieldValue);
} }
Data otherData = new Data(otherIndex, otherType, otherId, document); IngestDocument otherIngestDocument = new IngestDocument(otherIndex, otherType, otherId, document);
if (changed) { if (changed) {
assertThat(data, not(equalTo(otherData))); assertThat(ingestDocument, not(equalTo(otherIngestDocument)));
assertThat(otherData, not(equalTo(data))); assertThat(otherIngestDocument, not(equalTo(ingestDocument)));
} else { } else {
assertThat(data, equalTo(otherData)); assertThat(ingestDocument, equalTo(otherIngestDocument));
assertThat(otherData, equalTo(data)); assertThat(otherIngestDocument, equalTo(ingestDocument));
Data thirdData = new Data(index, type, id, Collections.singletonMap(fieldName, fieldValue)); IngestDocument thirdIngestDocument = new IngestDocument(index, type, id, Collections.singletonMap(fieldName, fieldValue));
assertThat(thirdData, equalTo(data)); assertThat(thirdIngestDocument, equalTo(ingestDocument));
assertThat(data, equalTo(thirdData)); assertThat(ingestDocument, equalTo(thirdIngestDocument));
} }
} }
} }

View File

@ -106,8 +106,8 @@ public class IngestClientIT extends ESIntegTestCase {
assertThat(response.getResults().size(), equalTo(1)); assertThat(response.getResults().size(), equalTo(1));
assertThat(response.getResults().get(0), instanceOf(SimulateDocumentSimpleResult.class)); assertThat(response.getResults().get(0), instanceOf(SimulateDocumentSimpleResult.class));
SimulateDocumentSimpleResult simulateDocumentSimpleResult = (SimulateDocumentSimpleResult) response.getResults().get(0); SimulateDocumentSimpleResult simulateDocumentSimpleResult = (SimulateDocumentSimpleResult) response.getResults().get(0);
Data expectedData = new Data("index", "type", "id", Collections.singletonMap("foo", "bar")); IngestDocument expectedIngestDocument = new IngestDocument("index", "type", "id", Collections.singletonMap("foo", "bar"));
assertThat(simulateDocumentSimpleResult.getData(), equalTo(expectedData)); assertThat(simulateDocumentSimpleResult.getData(), equalTo(expectedIngestDocument));
assertThat(simulateDocumentSimpleResult.getFailure(), nullValue()); assertThat(simulateDocumentSimpleResult.getFailure(), nullValue());
} }

View File

@ -19,7 +19,7 @@
package org.elasticsearch.ingest.processor.date; package org.elasticsearch.ingest.processor.date;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
import org.joda.time.DateTime; import org.joda.time.DateTime;
import org.joda.time.DateTimeZone; import org.joda.time.DateTimeZone;
@ -36,9 +36,9 @@ public class DateProcessorTests extends ESTestCase {
"date_as_string", Collections.singletonList("yyyy dd MM hh:mm:ss"), "date_as_date"); "date_as_string", Collections.singletonList("yyyy dd MM hh:mm:ss"), "date_as_date");
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("date_as_string", "2010 12 06 11:05:15"); document.put("date_as_string", "2010 12 06 11:05:15");
Data data = new Data("index", "type", "id", document); IngestDocument ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T11:05:15.000+02:00")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T11:05:15.000+02:00"));
} }
public void testJodaPatternMultipleFormats() { public void testJodaPatternMultipleFormats() {
@ -51,27 +51,27 @@ public class DateProcessorTests extends ESTestCase {
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("date_as_string", "2010 12 06"); document.put("date_as_string", "2010 12 06");
Data data = new Data("index", "type", "id", document); IngestDocument ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T00:00:00.000+02:00")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T00:00:00.000+02:00"));
document = new HashMap<>(); document = new HashMap<>();
document.put("date_as_string", "12/06/2010"); document.put("date_as_string", "12/06/2010");
data = new Data("index", "type", "id", document); ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T00:00:00.000+02:00")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T00:00:00.000+02:00"));
document = new HashMap<>(); document = new HashMap<>();
document.put("date_as_string", "12-06-2010"); document.put("date_as_string", "12-06-2010");
data = new Data("index", "type", "id", document); ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T00:00:00.000+02:00")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T00:00:00.000+02:00"));
document = new HashMap<>(); document = new HashMap<>();
document.put("date_as_string", "2010"); document.put("date_as_string", "2010");
data = new Data("index", "type", "id", document); ingestDocument = new IngestDocument("index", "type", "id", document);
try { try {
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
fail("processor should have failed due to not supported date format"); fail("processor should have failed due to not supported date format");
} catch(IllegalArgumentException e) { } catch(IllegalArgumentException e) {
assertThat(e.getMessage(), containsString("unable to parse date [2010]")); assertThat(e.getMessage(), containsString("unable to parse date [2010]"));
@ -83,9 +83,9 @@ public class DateProcessorTests extends ESTestCase {
"date_as_string", Collections.singletonList("yyyy dd MMM"), "date_as_date"); "date_as_string", Collections.singletonList("yyyy dd MMM"), "date_as_date");
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("date_as_string", "2010 12 giugno"); document.put("date_as_string", "2010 12 giugno");
Data data = new Data("index", "type", "id", document); IngestDocument ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T00:00:00.000+02:00")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo("2010-06-12T00:00:00.000+02:00"));
} }
public void testJodaPatternDefaultYear() { public void testJodaPatternDefaultYear() {
@ -93,9 +93,9 @@ public class DateProcessorTests extends ESTestCase {
"date_as_string", Collections.singletonList("dd/MM"), "date_as_date"); "date_as_string", Collections.singletonList("dd/MM"), "date_as_date");
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("date_as_string", "12/06"); document.put("date_as_string", "12/06");
Data data = new Data("index", "type", "id", document); IngestDocument ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo(DateTime.now().getYear() + "-06-12T00:00:00.000+02:00")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo(DateTime.now().getYear() + "-06-12T00:00:00.000+02:00"));
} }
public void testTAI64N() { public void testTAI64N() {
@ -104,9 +104,9 @@ public class DateProcessorTests extends ESTestCase {
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
String dateAsString = (randomBoolean() ? "@" : "") + "4000000050d506482dbdf024"; String dateAsString = (randomBoolean() ? "@" : "") + "4000000050d506482dbdf024";
document.put("date_as_string", dateAsString); document.put("date_as_string", dateAsString);
Data data = new Data("index", "type", "id", document); IngestDocument ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo("2012-12-22T03:00:46.767+02:00")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo("2012-12-22T03:00:46.767+02:00"));
} }
public void testUnixMs() { public void testUnixMs() {
@ -114,9 +114,9 @@ public class DateProcessorTests extends ESTestCase {
"date_as_string", Collections.singletonList(DateParserFactory.UNIX_MS), "date_as_date"); "date_as_string", Collections.singletonList(DateParserFactory.UNIX_MS), "date_as_date");
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("date_as_string", "1000500"); document.put("date_as_string", "1000500");
Data data = new Data("index", "type", "id", document); IngestDocument ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo("1970-01-01T00:16:40.500Z")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo("1970-01-01T00:16:40.500Z"));
} }
public void testUnix() { public void testUnix() {
@ -124,8 +124,8 @@ public class DateProcessorTests extends ESTestCase {
"date_as_string", Collections.singletonList(DateParserFactory.UNIX), "date_as_date"); "date_as_string", Collections.singletonList(DateParserFactory.UNIX), "date_as_date");
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("date_as_string", "1000.5"); document.put("date_as_string", "1000.5");
Data data = new Data("index", "type", "id", document); IngestDocument ingestDocument = new IngestDocument("index", "type", "id", document);
dateProcessor.execute(data); dateProcessor.execute(ingestDocument);
assertThat(data.getPropertyValue("date_as_date", String.class), equalTo("1970-01-01T00:16:40.500Z")); assertThat(ingestDocument.getPropertyValue("date_as_date", String.class), equalTo("1970-01-01T00:16:40.500Z"));
} }
} }

View File

@ -20,7 +20,7 @@
package org.elasticsearch.ingest.processor.geoip; package org.elasticsearch.ingest.processor.geoip;
import com.maxmind.geoip2.DatabaseReader; import com.maxmind.geoip2.DatabaseReader;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
import java.io.InputStream; import java.io.InputStream;
@ -38,13 +38,13 @@ public class GeoIpProcessorTests extends ESTestCase {
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("source_field", "82.170.213.79"); document.put("source_field", "82.170.213.79");
Data data = new Data("_index", "_type", "_id", document); IngestDocument ingestDocument = new IngestDocument("_index", "_type", "_id", document);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(2)); assertThat(ingestDocument.getSource().size(), equalTo(2));
assertThat(data.getDocument().get("source_field"), equalTo("82.170.213.79")); assertThat(ingestDocument.getSource().get("source_field"), equalTo("82.170.213.79"));
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
Map<String, Object> geoData = (Map<String, Object>) data.getDocument().get("target_field"); Map<String, Object> geoData = (Map<String, Object>) ingestDocument.getSource().get("target_field");
assertThat(geoData.size(), equalTo(10)); assertThat(geoData.size(), equalTo(10));
assertThat(geoData.get("ip"), equalTo("82.170.213.79")); assertThat(geoData.get("ip"), equalTo("82.170.213.79"));
assertThat(geoData.get("country_iso_code"), equalTo("NL")); assertThat(geoData.get("country_iso_code"), equalTo("NL"));
@ -64,13 +64,13 @@ public class GeoIpProcessorTests extends ESTestCase {
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("source_field", "82.170.213.79"); document.put("source_field", "82.170.213.79");
Data data = new Data("_index", "_type", "_id", document); IngestDocument ingestDocument = new IngestDocument("_index", "_type", "_id", document);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(2)); assertThat(ingestDocument.getSource().size(), equalTo(2));
assertThat(data.getDocument().get("source_field"), equalTo("82.170.213.79")); assertThat(ingestDocument.getSource().get("source_field"), equalTo("82.170.213.79"));
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
Map<String, Object> geoData = (Map<String, Object>) data.getDocument().get("target_field"); Map<String, Object> geoData = (Map<String, Object>) ingestDocument.getSource().get("target_field");
assertThat(geoData.size(), equalTo(4)); assertThat(geoData.size(), equalTo(4));
assertThat(geoData.get("ip"), equalTo("82.170.213.79")); assertThat(geoData.get("ip"), equalTo("82.170.213.79"));
assertThat(geoData.get("country_iso_code"), equalTo("NL")); assertThat(geoData.get("country_iso_code"), equalTo("NL"));
@ -84,10 +84,10 @@ public class GeoIpProcessorTests extends ESTestCase {
Map<String, Object> document = new HashMap<>(); Map<String, Object> document = new HashMap<>();
document.put("source_field", "202.45.11.11"); document.put("source_field", "202.45.11.11");
Data data = new Data("_index", "_type", "_id", document); IngestDocument ingestDocument = new IngestDocument("_index", "_type", "_id", document);
processor.execute(data); processor.execute(ingestDocument);
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
Map<String, Object> geoData = (Map<String, Object>) data.getDocument().get("target_field"); Map<String, Object> geoData = (Map<String, Object>) ingestDocument.getSource().get("target_field");
assertThat(geoData.size(), equalTo(0)); assertThat(geoData.size(), equalTo(0));
} }

View File

@ -19,7 +19,7 @@
package org.elasticsearch.ingest.processor.mutate; package org.elasticsearch.ingest.processor.mutate;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
import org.junit.Before; import org.junit.Before;
@ -34,7 +34,7 @@ import static org.hamcrest.Matchers.nullValue;
public class MutateProcessorTests extends ESTestCase { public class MutateProcessorTests extends ESTestCase {
private Data data; private IngestDocument ingestDocument;
@Before @Before
public void setData() { public void setData() {
@ -49,35 +49,35 @@ public class MutateProcessorTests extends ESTestCase {
fizz.put("buzz", "hello world"); fizz.put("buzz", "hello world");
document.put("fizz", fizz); document.put("fizz", fizz);
data = new Data("index", "type", "id", document); ingestDocument = new IngestDocument("index", "type", "id", document);
} }
public void testUpdate() throws IOException { public void testUpdate() throws IOException {
Map<String, Object> update = new HashMap<>(); Map<String, Object> update = new HashMap<>();
update.put("foo", 123); update.put("foo", 123);
Processor processor = new MutateProcessor(update, null, null, null, null, null, null, null, null, null); Processor processor = new MutateProcessor(update, null, null, null, null, null, null, null, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("foo", Integer.class), equalTo(123)); assertThat(ingestDocument.getPropertyValue("foo", Integer.class), equalTo(123));
} }
public void testRename() throws IOException { public void testRename() throws IOException {
Map<String, String> rename = new HashMap<>(); Map<String, String> rename = new HashMap<>();
rename.put("foo", "bar"); rename.put("foo", "bar");
Processor processor = new MutateProcessor(null, rename, null, null, null, null, null, null, null, null); Processor processor = new MutateProcessor(null, rename, null, null, null, null, null, null, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("bar", String.class), equalTo("bar")); assertThat(ingestDocument.getPropertyValue("bar", String.class), equalTo("bar"));
assertThat(data.hasPropertyValue("foo"), is(false)); assertThat(ingestDocument.hasPropertyValue("foo"), is(false));
} }
public void testConvert() throws IOException { public void testConvert() throws IOException {
Map<String, String> convert = new HashMap<>(); Map<String, String> convert = new HashMap<>();
convert.put("num", "integer"); convert.put("num", "integer");
Processor processor = new MutateProcessor(null, null, convert, null, null, null, null, null, null, null); Processor processor = new MutateProcessor(null, null, convert, null, null, null, null, null, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("num", Integer.class), equalTo(64)); assertThat(ingestDocument.getPropertyValue("num", Integer.class), equalTo(64));
} }
public void testConvertNullField() throws IOException { public void testConvertNullField() throws IOException {
@ -85,7 +85,7 @@ public class MutateProcessorTests extends ESTestCase {
convert.put("null", "integer"); convert.put("null", "integer");
Processor processor = new MutateProcessor(null, null, convert, null, null, null, null, null, null, null); Processor processor = new MutateProcessor(null, null, convert, null, null, null, null, null, null, null);
try { try {
processor.execute(data); processor.execute(ingestDocument);
fail("processor execute should have failed"); fail("processor execute should have failed");
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("Field \"null\" is null, cannot be converted to a/an integer")); assertThat(e.getMessage(), equalTo("Field \"null\" is null, cannot be converted to a/an integer"));
@ -96,18 +96,18 @@ public class MutateProcessorTests extends ESTestCase {
Map<String, String> convert = new HashMap<>(); Map<String, String> convert = new HashMap<>();
convert.put("arr", "integer"); convert.put("arr", "integer");
Processor processor = new MutateProcessor(null, null, convert, null, null, null, null, null, null, null); Processor processor = new MutateProcessor(null, null, convert, null, null, null, null, null, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("arr", List.class), equalTo(Arrays.asList(1, 2, 3))); assertThat(ingestDocument.getPropertyValue("arr", List.class), equalTo(Arrays.asList(1, 2, 3)));
} }
public void testSplit() throws IOException { public void testSplit() throws IOException {
Map<String, String> split = new HashMap<>(); Map<String, String> split = new HashMap<>();
split.put("ip", "\\."); split.put("ip", "\\.");
Processor processor = new MutateProcessor(null, null, null, split, null, null, null, null, null, null); Processor processor = new MutateProcessor(null, null, null, split, null, null, null, null, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("ip", List.class), equalTo(Arrays.asList("127", "0", "0", "1"))); assertThat(ingestDocument.getPropertyValue("ip", List.class), equalTo(Arrays.asList("127", "0", "0", "1")));
} }
public void testSplitNullValue() throws IOException { public void testSplitNullValue() throws IOException {
@ -115,7 +115,7 @@ public class MutateProcessorTests extends ESTestCase {
split.put("not.found", "\\."); split.put("not.found", "\\.");
Processor processor = new MutateProcessor(null, null, null, split, null, null, null, null, null, null); Processor processor = new MutateProcessor(null, null, null, split, null, null, null, null, null, null);
try { try {
processor.execute(data); processor.execute(ingestDocument);
fail(); fail();
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("Cannot split field. [not.found] is null.")); assertThat(e.getMessage(), equalTo("Cannot split field. [not.found] is null."));
@ -125,16 +125,16 @@ public class MutateProcessorTests extends ESTestCase {
public void testGsub() throws IOException { public void testGsub() throws IOException {
List<GsubExpression> gsubExpressions = Collections.singletonList(new GsubExpression("ip", Pattern.compile("\\."), "-")); List<GsubExpression> gsubExpressions = Collections.singletonList(new GsubExpression("ip", Pattern.compile("\\."), "-"));
Processor processor = new MutateProcessor(null, null, null, null, gsubExpressions, null, null, null, null, null); Processor processor = new MutateProcessor(null, null, null, null, gsubExpressions, null, null, null, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("ip", String.class), equalTo("127-0-0-1")); assertThat(ingestDocument.getPropertyValue("ip", String.class), equalTo("127-0-0-1"));
} }
public void testGsub_NullValue() throws IOException { public void testGsub_NullValue() throws IOException {
List<GsubExpression> gsubExpressions = Collections.singletonList(new GsubExpression("null_field", Pattern.compile("\\."), "-")); List<GsubExpression> gsubExpressions = Collections.singletonList(new GsubExpression("null_field", Pattern.compile("\\."), "-"));
Processor processor = new MutateProcessor(null, null, null, null, gsubExpressions, null, null, null, null, null); Processor processor = new MutateProcessor(null, null, null, null, gsubExpressions, null, null, null, null, null);
try { try {
processor.execute(data); processor.execute(ingestDocument);
fail("processor execution should have failed"); fail("processor execution should have failed");
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("Field \"null_field\" is null, cannot match pattern.")); assertThat(e.getMessage(), equalTo("Field \"null_field\" is null, cannot match pattern."));
@ -145,34 +145,34 @@ public class MutateProcessorTests extends ESTestCase {
HashMap<String, String> join = new HashMap<>(); HashMap<String, String> join = new HashMap<>();
join.put("arr", "-"); join.put("arr", "-");
Processor processor = new MutateProcessor(null, null, null, null, null, join, null, null, null, null); Processor processor = new MutateProcessor(null, null, null, null, null, join, null, null, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("arr", String.class), equalTo("1-2-3")); assertThat(ingestDocument.getPropertyValue("arr", String.class), equalTo("1-2-3"));
} }
public void testRemove() throws IOException { public void testRemove() throws IOException {
List<String> remove = Arrays.asList("foo", "ip"); List<String> remove = Arrays.asList("foo", "ip");
Processor processor = new MutateProcessor(null, null, null, null, null, null, remove, null, null, null); Processor processor = new MutateProcessor(null, null, null, null, null, null, remove, null, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(5)); assertThat(ingestDocument.getSource().size(), equalTo(5));
assertThat(data.getPropertyValue("foo", Object.class), nullValue()); assertThat(ingestDocument.getPropertyValue("foo", Object.class), nullValue());
assertThat(data.getPropertyValue("ip", Object.class), nullValue()); assertThat(ingestDocument.getPropertyValue("ip", Object.class), nullValue());
} }
public void testTrim() throws IOException { public void testTrim() throws IOException {
List<String> trim = Arrays.asList("to_strip", "foo"); List<String> trim = Arrays.asList("to_strip", "foo");
Processor processor = new MutateProcessor(null, null, null, null, null, null, null, trim, null, null); Processor processor = new MutateProcessor(null, null, null, null, null, null, null, trim, null, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("foo", String.class), equalTo("bar")); assertThat(ingestDocument.getPropertyValue("foo", String.class), equalTo("bar"));
assertThat(data.getPropertyValue("to_strip", String.class), equalTo("clean")); assertThat(ingestDocument.getPropertyValue("to_strip", String.class), equalTo("clean"));
} }
public void testTrimNullValue() throws IOException { public void testTrimNullValue() throws IOException {
List<String> trim = Collections.singletonList("not.found"); List<String> trim = Collections.singletonList("not.found");
Processor processor = new MutateProcessor(null, null, null, null, null, null, null, trim, null, null); Processor processor = new MutateProcessor(null, null, null, null, null, null, null, trim, null, null);
try { try {
processor.execute(data); processor.execute(ingestDocument);
fail(); fail();
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("Cannot trim field. [not.found] is null.")); assertThat(e.getMessage(), equalTo("Cannot trim field. [not.found] is null."));
@ -182,16 +182,16 @@ public class MutateProcessorTests extends ESTestCase {
public void testUppercase() throws IOException { public void testUppercase() throws IOException {
List<String> uppercase = Collections.singletonList("foo"); List<String> uppercase = Collections.singletonList("foo");
Processor processor = new MutateProcessor(null, null, null, null, null, null, null, null, uppercase, null); Processor processor = new MutateProcessor(null, null, null, null, null, null, null, null, uppercase, null);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("foo", String.class), equalTo("BAR")); assertThat(ingestDocument.getPropertyValue("foo", String.class), equalTo("BAR"));
} }
public void testUppercaseNullValue() throws IOException { public void testUppercaseNullValue() throws IOException {
List<String> uppercase = Collections.singletonList("not.found"); List<String> uppercase = Collections.singletonList("not.found");
Processor processor = new MutateProcessor(null, null, null, null, null, null, null, null, uppercase, null); Processor processor = new MutateProcessor(null, null, null, null, null, null, null, null, uppercase, null);
try { try {
processor.execute(data); processor.execute(ingestDocument);
fail(); fail();
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("Cannot uppercase field. [not.found] is null.")); assertThat(e.getMessage(), equalTo("Cannot uppercase field. [not.found] is null."));
@ -201,16 +201,16 @@ public class MutateProcessorTests extends ESTestCase {
public void testLowercase() throws IOException { public void testLowercase() throws IOException {
List<String> lowercase = Collections.singletonList("alpha"); List<String> lowercase = Collections.singletonList("alpha");
Processor processor = new MutateProcessor(null, null, null, null, null, null, null, null, null, lowercase); Processor processor = new MutateProcessor(null, null, null, null, null, null, null, null, null, lowercase);
processor.execute(data); processor.execute(ingestDocument);
assertThat(data.getDocument().size(), equalTo(7)); assertThat(ingestDocument.getSource().size(), equalTo(7));
assertThat(data.getPropertyValue("alpha", String.class), equalTo("abcd")); assertThat(ingestDocument.getPropertyValue("alpha", String.class), equalTo("abcd"));
} }
public void testLowercaseNullValue() throws IOException { public void testLowercaseNullValue() throws IOException {
List<String> lowercase = Collections.singletonList("not.found"); List<String> lowercase = Collections.singletonList("not.found");
Processor processor = new MutateProcessor(null, null, null, null, null, null, null, null, null, lowercase); Processor processor = new MutateProcessor(null, null, null, null, null, null, null, null, null, lowercase);
try { try {
processor.execute(data); processor.execute(ingestDocument);
fail(); fail();
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
assertThat(e.getMessage(), equalTo("Cannot lowercase field. [not.found] is null.")); assertThat(e.getMessage(), equalTo("Cannot lowercase field. [not.found] is null."));

View File

@ -20,7 +20,7 @@
package org.elasticsearch.plugin.ingest; package org.elasticsearch.plugin.ingest;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.Pipeline; import org.elasticsearch.ingest.Pipeline;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
@ -59,25 +59,25 @@ public class PipelineExecutionServiceTests extends ESTestCase {
public void testExecute_pipelineDoesNotExist() { public void testExecute_pipelineDoesNotExist() {
when(store.get("_id")).thenReturn(null); when(store.get("_id")).thenReturn(null);
Data data = new Data("_index", "_type", "_id", Collections.emptyMap()); IngestDocument ingestDocument = new IngestDocument("_index", "_type", "_id", Collections.emptyMap());
PipelineExecutionService.Listener listener = mock(PipelineExecutionService.Listener.class); PipelineExecutionService.Listener listener = mock(PipelineExecutionService.Listener.class);
executionService.execute(data, "_id", listener); executionService.execute(ingestDocument, "_id", listener);
verify(listener).failed(any(IllegalArgumentException.class)); verify(listener).failed(any(IllegalArgumentException.class));
verify(listener, times(0)).executed(data); verify(listener, times(0)).executed(ingestDocument);
} }
public void testExecute_success() throws Exception { public void testExecute_success() throws Exception {
Processor processor = mock(Processor.class); Processor processor = mock(Processor.class);
when(store.get("_id")).thenReturn(new Pipeline("_id", "_description", Arrays.asList(processor))); when(store.get("_id")).thenReturn(new Pipeline("_id", "_description", Arrays.asList(processor)));
Data data = new Data("_index", "_type", "_id", Collections.emptyMap()); IngestDocument ingestDocument = new IngestDocument("_index", "_type", "_id", Collections.emptyMap());
PipelineExecutionService.Listener listener = mock(PipelineExecutionService.Listener.class); PipelineExecutionService.Listener listener = mock(PipelineExecutionService.Listener.class);
executionService.execute(data, "_id", listener); executionService.execute(ingestDocument, "_id", listener);
assertBusy(new Runnable() { assertBusy(new Runnable() {
@Override @Override
public void run() { public void run() {
verify(processor).execute(data); verify(processor).execute(ingestDocument);
verify(listener).executed(data); verify(listener).executed(ingestDocument);
verify(listener, times(0)).failed(any(Exception.class)); verify(listener, times(0)).failed(any(Exception.class));
} }
}); });
@ -86,15 +86,15 @@ public class PipelineExecutionServiceTests extends ESTestCase {
public void testExecute_failure() throws Exception { public void testExecute_failure() throws Exception {
Processor processor = mock(Processor.class); Processor processor = mock(Processor.class);
when(store.get("_id")).thenReturn(new Pipeline("_id", "_description", Arrays.asList(processor))); when(store.get("_id")).thenReturn(new Pipeline("_id", "_description", Arrays.asList(processor)));
Data data = new Data("_index", "_type", "_id", Collections.emptyMap()); IngestDocument ingestDocument = new IngestDocument("_index", "_type", "_id", Collections.emptyMap());
doThrow(new RuntimeException()).when(processor).execute(data); doThrow(new RuntimeException()).when(processor).execute(ingestDocument);
PipelineExecutionService.Listener listener = mock(PipelineExecutionService.Listener.class); PipelineExecutionService.Listener listener = mock(PipelineExecutionService.Listener.class);
executionService.execute(data, "_id", listener); executionService.execute(ingestDocument, "_id", listener);
assertBusy(new Runnable() { assertBusy(new Runnable() {
@Override @Override
public void run() { public void run() {
verify(processor).execute(data); verify(processor).execute(ingestDocument);
verify(listener, times(0)).executed(data); verify(listener, times(0)).executed(ingestDocument);
verify(listener).failed(any(RuntimeException.class)); verify(listener).failed(any(RuntimeException.class));
} }
}); });

View File

@ -27,7 +27,7 @@ import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.support.ActionFilterChain; import org.elasticsearch.action.support.ActionFilterChain;
import org.elasticsearch.action.update.UpdateRequest; import org.elasticsearch.action.update.UpdateRequest;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.Pipeline; import org.elasticsearch.ingest.Pipeline;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
import org.elasticsearch.ingest.processor.mutate.MutateProcessor; import org.elasticsearch.ingest.processor.mutate.MutateProcessor;
@ -80,7 +80,7 @@ public class IngestActionFilterTests extends ESTestCase {
filter.apply("_action", indexRequest, actionListener, actionFilterChain); filter.apply("_action", indexRequest, actionListener, actionFilterChain);
verify(executionService).execute(any(Data.class), eq("_id"), any(PipelineExecutionService.Listener.class)); verify(executionService).execute(any(IngestDocument.class), eq("_id"), any(PipelineExecutionService.Listener.class));
verifyZeroInteractions(actionFilterChain); verifyZeroInteractions(actionFilterChain);
} }
@ -93,7 +93,7 @@ public class IngestActionFilterTests extends ESTestCase {
filter.apply("_action", indexRequest, actionListener, actionFilterChain); filter.apply("_action", indexRequest, actionListener, actionFilterChain);
verify(executionService).execute(any(Data.class), eq("_id"), any(PipelineExecutionService.Listener.class)); verify(executionService).execute(any(IngestDocument.class), eq("_id"), any(PipelineExecutionService.Listener.class));
verifyZeroInteractions(actionFilterChain); verifyZeroInteractions(actionFilterChain);
} }
@ -121,16 +121,16 @@ public class IngestActionFilterTests extends ESTestCase {
Answer answer = new Answer() { Answer answer = new Answer() {
@Override @Override
public Object answer(InvocationOnMock invocationOnMock) throws Throwable { public Object answer(InvocationOnMock invocationOnMock) throws Throwable {
Data data = (Data) invocationOnMock.getArguments()[0]; IngestDocument ingestDocument = (IngestDocument) invocationOnMock.getArguments()[0];
PipelineExecutionService.Listener listener = (PipelineExecutionService.Listener) invocationOnMock.getArguments()[2]; PipelineExecutionService.Listener listener = (PipelineExecutionService.Listener) invocationOnMock.getArguments()[2];
listener.executed(data); listener.executed(ingestDocument);
return null; return null;
} }
}; };
doAnswer(answer).when(executionService).execute(any(Data.class), eq("_id"), any(PipelineExecutionService.Listener.class)); doAnswer(answer).when(executionService).execute(any(IngestDocument.class), eq("_id"), any(PipelineExecutionService.Listener.class));
filter.apply("_action", indexRequest, actionListener, actionFilterChain); filter.apply("_action", indexRequest, actionListener, actionFilterChain);
verify(executionService).execute(any(Data.class), eq("_id"), any(PipelineExecutionService.Listener.class)); verify(executionService).execute(any(IngestDocument.class), eq("_id"), any(PipelineExecutionService.Listener.class));
verify(actionFilterChain).proceed("_action", indexRequest, actionListener); verify(actionFilterChain).proceed("_action", indexRequest, actionListener);
verifyZeroInteractions(actionListener); verifyZeroInteractions(actionListener);
} }
@ -151,10 +151,10 @@ public class IngestActionFilterTests extends ESTestCase {
return null; return null;
} }
}; };
doAnswer(answer).when(executionService).execute(any(Data.class), eq("_id"), any(PipelineExecutionService.Listener.class)); doAnswer(answer).when(executionService).execute(any(IngestDocument.class), eq("_id"), any(PipelineExecutionService.Listener.class));
filter.apply("_action", indexRequest, actionListener, actionFilterChain); filter.apply("_action", indexRequest, actionListener, actionFilterChain);
verify(executionService).execute(any(Data.class), eq("_id"), any(PipelineExecutionService.Listener.class)); verify(executionService).execute(any(IngestDocument.class), eq("_id"), any(PipelineExecutionService.Listener.class));
verify(actionListener).onFailure(exception); verify(actionListener).onFailure(exception);
verifyZeroInteractions(actionFilterChain); verifyZeroInteractions(actionFilterChain);
} }

View File

@ -21,7 +21,7 @@ package org.elasticsearch.plugin.ingest.transport;
import org.elasticsearch.common.io.stream.BytesStreamOutput; import org.elasticsearch.common.io.stream.BytesStreamOutput;
import org.elasticsearch.common.io.stream.StreamInput; import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
import java.io.IOException; import java.io.IOException;
@ -39,7 +39,7 @@ public class TransportDataTests extends ESTestCase {
String id = randomAsciiOfLengthBetween(1, 10); String id = randomAsciiOfLengthBetween(1, 10);
String fieldName = randomAsciiOfLengthBetween(1, 10); String fieldName = randomAsciiOfLengthBetween(1, 10);
String fieldValue = randomAsciiOfLengthBetween(1, 10); String fieldValue = randomAsciiOfLengthBetween(1, 10);
TransportData transportData = new TransportData(new Data(index, type, id, Collections.singletonMap(fieldName, fieldValue))); TransportData transportData = new TransportData(new IngestDocument(index, type, id, Collections.singletonMap(fieldName, fieldValue)));
boolean changed = false; boolean changed = false;
String otherIndex; String otherIndex;
@ -71,23 +71,23 @@ public class TransportDataTests extends ESTestCase {
document = Collections.singletonMap(fieldName, fieldValue); document = Collections.singletonMap(fieldName, fieldValue);
} }
TransportData otherTransportData = new TransportData(new Data(otherIndex, otherType, otherId, document)); TransportData otherTransportData = new TransportData(new IngestDocument(otherIndex, otherType, otherId, document));
if (changed) { if (changed) {
assertThat(transportData, not(equalTo(otherTransportData))); assertThat(transportData, not(equalTo(otherTransportData)));
assertThat(otherTransportData, not(equalTo(transportData))); assertThat(otherTransportData, not(equalTo(transportData)));
} else { } else {
assertThat(transportData, equalTo(otherTransportData)); assertThat(transportData, equalTo(otherTransportData));
assertThat(otherTransportData, equalTo(transportData)); assertThat(otherTransportData, equalTo(transportData));
TransportData thirdTransportData = new TransportData(new Data(index, type, id, Collections.singletonMap(fieldName, fieldValue))); TransportData thirdTransportData = new TransportData(new IngestDocument(index, type, id, Collections.singletonMap(fieldName, fieldValue)));
assertThat(thirdTransportData, equalTo(transportData)); assertThat(thirdTransportData, equalTo(transportData));
assertThat(transportData, equalTo(thirdTransportData)); assertThat(transportData, equalTo(thirdTransportData));
} }
} }
public void testSerialization() throws IOException { public void testSerialization() throws IOException {
Data data = new Data(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), IngestDocument ingestDocument = new IngestDocument(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10),
Collections.singletonMap(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10))); Collections.singletonMap(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10)));
TransportData transportData = new TransportData(data); TransportData transportData = new TransportData(ingestDocument);
BytesStreamOutput out = new BytesStreamOutput(); BytesStreamOutput out = new BytesStreamOutput();
transportData.writeTo(out); transportData.writeTo(out);

View File

@ -19,7 +19,7 @@
package org.elasticsearch.plugin.ingest.transport.simulate; package org.elasticsearch.plugin.ingest.transport.simulate;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.Pipeline; import org.elasticsearch.ingest.Pipeline;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
import org.elasticsearch.plugin.ingest.PipelineStore; import org.elasticsearch.plugin.ingest.PipelineStore;
@ -29,6 +29,9 @@ import org.junit.Before;
import java.io.IOException; import java.io.IOException;
import java.util.*; import java.util.*;
import static org.elasticsearch.ingest.IngestDocument.MetaData.ID;
import static org.elasticsearch.ingest.IngestDocument.MetaData.INDEX;
import static org.elasticsearch.ingest.IngestDocument.MetaData.TYPE;
import static org.elasticsearch.plugin.ingest.transport.simulate.SimulatePipelineRequest.Fields; import static org.elasticsearch.plugin.ingest.transport.simulate.SimulatePipelineRequest.Fields;
import static org.hamcrest.Matchers.equalTo; import static org.hamcrest.Matchers.equalTo;
import static org.hamcrest.Matchers.nullValue; import static org.hamcrest.Matchers.nullValue;
@ -80,12 +83,12 @@ public class ParsedSimulateRequestParserTests extends ESTestCase {
assertThat(actualRequest.isVerbose(), equalTo(false)); assertThat(actualRequest.isVerbose(), equalTo(false));
assertThat(actualRequest.getDocuments().size(), equalTo(numDocs)); assertThat(actualRequest.getDocuments().size(), equalTo(numDocs));
Iterator<Map<String, Object>> expectedDocsIterator = expectedDocs.iterator(); Iterator<Map<String, Object>> expectedDocsIterator = expectedDocs.iterator();
for (Data data : actualRequest.getDocuments()) { for (IngestDocument ingestDocument : actualRequest.getDocuments()) {
Map<String, Object> expectedDocument = expectedDocsIterator.next(); Map<String, Object> expectedDocument = expectedDocsIterator.next();
assertThat(data.getDocument(), equalTo(expectedDocument.get(Fields.SOURCE))); assertThat(ingestDocument.getSource(), equalTo(expectedDocument.get(Fields.SOURCE)));
assertThat(data.getIndex(), equalTo(expectedDocument.get(Fields.INDEX))); assertThat(ingestDocument.getMetadata(INDEX), equalTo(expectedDocument.get(Fields.INDEX)));
assertThat(data.getType(), equalTo(expectedDocument.get(Fields.TYPE))); assertThat(ingestDocument.getMetadata(TYPE), equalTo(expectedDocument.get(Fields.TYPE)));
assertThat(data.getId(), equalTo(expectedDocument.get(Fields.ID))); assertThat(ingestDocument.getMetadata(ID), equalTo(expectedDocument.get(Fields.ID)));
} }
assertThat(actualRequest.getPipeline().getId(), equalTo(ParsedSimulateRequest.Parser.SIMULATED_PIPELINE_ID)); assertThat(actualRequest.getPipeline().getId(), equalTo(ParsedSimulateRequest.Parser.SIMULATED_PIPELINE_ID));
@ -133,12 +136,12 @@ public class ParsedSimulateRequestParserTests extends ESTestCase {
assertThat(actualRequest.isVerbose(), equalTo(false)); assertThat(actualRequest.isVerbose(), equalTo(false));
assertThat(actualRequest.getDocuments().size(), equalTo(numDocs)); assertThat(actualRequest.getDocuments().size(), equalTo(numDocs));
Iterator<Map<String, Object>> expectedDocsIterator = expectedDocs.iterator(); Iterator<Map<String, Object>> expectedDocsIterator = expectedDocs.iterator();
for (Data data : actualRequest.getDocuments()) { for (IngestDocument ingestDocument : actualRequest.getDocuments()) {
Map<String, Object> expectedDocument = expectedDocsIterator.next(); Map<String, Object> expectedDocument = expectedDocsIterator.next();
assertThat(data.getDocument(), equalTo(expectedDocument.get(Fields.SOURCE))); assertThat(ingestDocument.getSource(), equalTo(expectedDocument.get(Fields.SOURCE)));
assertThat(data.getIndex(), equalTo(expectedDocument.get(Fields.INDEX))); assertThat(ingestDocument.getMetadata(INDEX), equalTo(expectedDocument.get(Fields.INDEX)));
assertThat(data.getType(), equalTo(expectedDocument.get(Fields.TYPE))); assertThat(ingestDocument.getMetadata(TYPE), equalTo(expectedDocument.get(Fields.TYPE)));
assertThat(data.getId(), equalTo(expectedDocument.get(Fields.ID))); assertThat(ingestDocument.getMetadata(ID), equalTo(expectedDocument.get(Fields.ID)));
} }
assertThat(actualRequest.getPipeline().getId(), equalTo(ParsedSimulateRequest.Parser.SIMULATED_PIPELINE_ID)); assertThat(actualRequest.getPipeline().getId(), equalTo(ParsedSimulateRequest.Parser.SIMULATED_PIPELINE_ID));

View File

@ -21,7 +21,7 @@ package org.elasticsearch.plugin.ingest.transport.simulate;
import org.elasticsearch.common.io.stream.BytesStreamOutput; import org.elasticsearch.common.io.stream.BytesStreamOutput;
import org.elasticsearch.common.io.stream.StreamInput; import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
import java.io.IOException; import java.io.IOException;
@ -38,9 +38,9 @@ public class SimulateDocumentSimpleResultTests extends ESTestCase {
if (isFailure) { if (isFailure) {
simulateDocumentSimpleResult = new SimulateDocumentSimpleResult(new IllegalArgumentException("test")); simulateDocumentSimpleResult = new SimulateDocumentSimpleResult(new IllegalArgumentException("test"));
} else { } else {
Data data = new Data(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), IngestDocument ingestDocument = new IngestDocument(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10),
Collections.singletonMap(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10))); Collections.singletonMap(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10)));
simulateDocumentSimpleResult = new SimulateDocumentSimpleResult(data); simulateDocumentSimpleResult = new SimulateDocumentSimpleResult(ingestDocument);
} }
BytesStreamOutput out = new BytesStreamOutput(); BytesStreamOutput out = new BytesStreamOutput();

View File

@ -20,7 +20,7 @@
package org.elasticsearch.plugin.ingest.transport.simulate; package org.elasticsearch.plugin.ingest.transport.simulate;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.ingest.Pipeline; import org.elasticsearch.ingest.Pipeline;
import org.elasticsearch.ingest.processor.Processor; import org.elasticsearch.ingest.processor.Processor;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
@ -40,7 +40,7 @@ public class SimulateExecutionServiceTests extends ESTestCase {
private SimulateExecutionService executionService; private SimulateExecutionService executionService;
private Pipeline pipeline; private Pipeline pipeline;
private Processor processor; private Processor processor;
private Data data; private IngestDocument ingestDocument;
@Before @Before
public void setup() { public void setup() {
@ -53,7 +53,7 @@ public class SimulateExecutionServiceTests extends ESTestCase {
processor = mock(Processor.class); processor = mock(Processor.class);
when(processor.getType()).thenReturn("mock"); when(processor.getType()).thenReturn("mock");
pipeline = new Pipeline("_id", "_description", Arrays.asList(processor, processor)); pipeline = new Pipeline("_id", "_description", Arrays.asList(processor, processor));
data = new Data("_index", "_type", "_id", Collections.singletonMap("foo", "bar")); ingestDocument = new IngestDocument("_index", "_type", "_id", Collections.singletonMap("foo", "bar"));
} }
@After @After
@ -62,35 +62,35 @@ public class SimulateExecutionServiceTests extends ESTestCase {
} }
public void testExecuteVerboseItem() throws Exception { public void testExecuteVerboseItem() throws Exception {
SimulateDocumentResult actualItemResponse = executionService.executeVerboseItem(pipeline, data); SimulateDocumentResult actualItemResponse = executionService.executeVerboseItem(pipeline, ingestDocument);
verify(processor, times(2)).execute(data); verify(processor, times(2)).execute(ingestDocument);
assertThat(actualItemResponse, instanceOf(SimulateDocumentVerboseResult.class)); assertThat(actualItemResponse, instanceOf(SimulateDocumentVerboseResult.class));
SimulateDocumentVerboseResult simulateDocumentVerboseResult = (SimulateDocumentVerboseResult) actualItemResponse; SimulateDocumentVerboseResult simulateDocumentVerboseResult = (SimulateDocumentVerboseResult) actualItemResponse;
assertThat(simulateDocumentVerboseResult.getProcessorResults().size(), equalTo(2)); assertThat(simulateDocumentVerboseResult.getProcessorResults().size(), equalTo(2));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(0).getProcessorId(), equalTo("processor[mock]-0")); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(0).getProcessorId(), equalTo("processor[mock]-0"));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(0).getData(), not(sameInstance(data))); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(0).getData(), not(sameInstance(ingestDocument)));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(0).getData(), equalTo(data)); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(0).getData(), equalTo(ingestDocument));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(0).getFailure(), nullValue()); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(0).getFailure(), nullValue());
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getProcessorId(), equalTo("processor[mock]-1")); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getProcessorId(), equalTo("processor[mock]-1"));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getData(), not(sameInstance(data))); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getData(), not(sameInstance(ingestDocument)));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getData(), equalTo(data)); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getData(), equalTo(ingestDocument));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getFailure(), nullValue()); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getFailure(), nullValue());
} }
public void testExecuteItem() throws Exception { public void testExecuteItem() throws Exception {
SimulateDocumentResult actualItemResponse = executionService.executeItem(pipeline, data); SimulateDocumentResult actualItemResponse = executionService.executeItem(pipeline, ingestDocument);
verify(processor, times(2)).execute(data); verify(processor, times(2)).execute(ingestDocument);
assertThat(actualItemResponse, instanceOf(SimulateDocumentSimpleResult.class)); assertThat(actualItemResponse, instanceOf(SimulateDocumentSimpleResult.class));
SimulateDocumentSimpleResult simulateDocumentSimpleResult = (SimulateDocumentSimpleResult) actualItemResponse; SimulateDocumentSimpleResult simulateDocumentSimpleResult = (SimulateDocumentSimpleResult) actualItemResponse;
assertThat(simulateDocumentSimpleResult.getData(), equalTo(data)); assertThat(simulateDocumentSimpleResult.getData(), equalTo(ingestDocument));
assertThat(simulateDocumentSimpleResult.getFailure(), nullValue()); assertThat(simulateDocumentSimpleResult.getFailure(), nullValue());
} }
public void testExecuteVerboseItemWithFailure() throws Exception { public void testExecuteVerboseItemWithFailure() throws Exception {
Exception e = new RuntimeException("processor failed"); Exception e = new RuntimeException("processor failed");
doThrow(e).doNothing().when(processor).execute(data); doThrow(e).doNothing().when(processor).execute(ingestDocument);
SimulateDocumentResult actualItemResponse = executionService.executeVerboseItem(pipeline, data); SimulateDocumentResult actualItemResponse = executionService.executeVerboseItem(pipeline, ingestDocument);
verify(processor, times(2)).execute(data); verify(processor, times(2)).execute(ingestDocument);
assertThat(actualItemResponse, instanceOf(SimulateDocumentVerboseResult.class)); assertThat(actualItemResponse, instanceOf(SimulateDocumentVerboseResult.class));
SimulateDocumentVerboseResult simulateDocumentVerboseResult = (SimulateDocumentVerboseResult) actualItemResponse; SimulateDocumentVerboseResult simulateDocumentVerboseResult = (SimulateDocumentVerboseResult) actualItemResponse;
assertThat(simulateDocumentVerboseResult.getProcessorResults().size(), equalTo(2)); assertThat(simulateDocumentVerboseResult.getProcessorResults().size(), equalTo(2));
@ -100,8 +100,8 @@ public class SimulateExecutionServiceTests extends ESTestCase {
RuntimeException runtimeException = (RuntimeException) simulateDocumentVerboseResult.getProcessorResults().get(0).getFailure(); RuntimeException runtimeException = (RuntimeException) simulateDocumentVerboseResult.getProcessorResults().get(0).getFailure();
assertThat(runtimeException.getMessage(), equalTo("processor failed")); assertThat(runtimeException.getMessage(), equalTo("processor failed"));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getProcessorId(), equalTo("processor[mock]-1")); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getProcessorId(), equalTo("processor[mock]-1"));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getData(), not(sameInstance(data))); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getData(), not(sameInstance(ingestDocument)));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getData(), equalTo(data)); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getData(), equalTo(ingestDocument));
assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getFailure(), nullValue()); assertThat(simulateDocumentVerboseResult.getProcessorResults().get(1).getFailure(), nullValue());
runtimeException = (RuntimeException) simulateDocumentVerboseResult.getProcessorResults().get(0).getFailure(); runtimeException = (RuntimeException) simulateDocumentVerboseResult.getProcessorResults().get(0).getFailure();
assertThat(runtimeException.getMessage(), equalTo("processor failed")); assertThat(runtimeException.getMessage(), equalTo("processor failed"));
@ -109,9 +109,9 @@ public class SimulateExecutionServiceTests extends ESTestCase {
public void testExecuteItemWithFailure() throws Exception { public void testExecuteItemWithFailure() throws Exception {
Exception e = new RuntimeException("processor failed"); Exception e = new RuntimeException("processor failed");
doThrow(e).when(processor).execute(data); doThrow(e).when(processor).execute(ingestDocument);
SimulateDocumentResult actualItemResponse = executionService.executeItem(pipeline, data); SimulateDocumentResult actualItemResponse = executionService.executeItem(pipeline, ingestDocument);
verify(processor, times(1)).execute(data); verify(processor, times(1)).execute(ingestDocument);
assertThat(actualItemResponse, instanceOf(SimulateDocumentSimpleResult.class)); assertThat(actualItemResponse, instanceOf(SimulateDocumentSimpleResult.class));
SimulateDocumentSimpleResult simulateDocumentSimpleResult = (SimulateDocumentSimpleResult) actualItemResponse; SimulateDocumentSimpleResult simulateDocumentSimpleResult = (SimulateDocumentSimpleResult) actualItemResponse;
assertThat(simulateDocumentSimpleResult.getData(), nullValue()); assertThat(simulateDocumentSimpleResult.getData(), nullValue());

View File

@ -21,7 +21,7 @@ package org.elasticsearch.plugin.ingest.transport.simulate;
import org.elasticsearch.common.io.stream.BytesStreamOutput; import org.elasticsearch.common.io.stream.BytesStreamOutput;
import org.elasticsearch.common.io.stream.StreamInput; import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
import java.io.IOException; import java.io.IOException;
@ -42,7 +42,7 @@ public class SimulatePipelineResponseTests extends ESTestCase {
List<SimulateDocumentResult> results = new ArrayList<>(numResults); List<SimulateDocumentResult> results = new ArrayList<>(numResults);
for (int i = 0; i < numResults; i++) { for (int i = 0; i < numResults; i++) {
boolean isFailure = randomBoolean(); boolean isFailure = randomBoolean();
Data data = new Data(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), IngestDocument ingestDocument = new IngestDocument(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10),
Collections.singletonMap(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10))); Collections.singletonMap(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10)));
if (isVerbose) { if (isVerbose) {
int numProcessors = randomIntBetween(1, 10); int numProcessors = randomIntBetween(1, 10);
@ -53,18 +53,18 @@ public class SimulatePipelineResponseTests extends ESTestCase {
if (isFailure) { if (isFailure) {
processorResult = new SimulateProcessorResult(processorId, new IllegalArgumentException("test")); processorResult = new SimulateProcessorResult(processorId, new IllegalArgumentException("test"));
} else { } else {
processorResult = new SimulateProcessorResult(processorId, data); processorResult = new SimulateProcessorResult(processorId, ingestDocument);
} }
processorResults.add(processorResult); processorResults.add(processorResult);
} }
results.add(new SimulateDocumentVerboseResult(processorResults)); results.add(new SimulateDocumentVerboseResult(processorResults));
} else { } else {
results.add(new SimulateDocumentSimpleResult(data)); results.add(new SimulateDocumentSimpleResult(ingestDocument));
SimulateDocumentSimpleResult simulateDocumentSimpleResult; SimulateDocumentSimpleResult simulateDocumentSimpleResult;
if (isFailure) { if (isFailure) {
simulateDocumentSimpleResult = new SimulateDocumentSimpleResult(new IllegalArgumentException("test")); simulateDocumentSimpleResult = new SimulateDocumentSimpleResult(new IllegalArgumentException("test"));
} else { } else {
simulateDocumentSimpleResult = new SimulateDocumentSimpleResult(data); simulateDocumentSimpleResult = new SimulateDocumentSimpleResult(ingestDocument);
} }
results.add(simulateDocumentSimpleResult); results.add(simulateDocumentSimpleResult);
} }

View File

@ -21,7 +21,7 @@ package org.elasticsearch.plugin.ingest.transport.simulate;
import org.elasticsearch.common.io.stream.BytesStreamOutput; import org.elasticsearch.common.io.stream.BytesStreamOutput;
import org.elasticsearch.common.io.stream.StreamInput; import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.ingest.Data; import org.elasticsearch.ingest.IngestDocument;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
import java.io.IOException; import java.io.IOException;
@ -39,9 +39,9 @@ public class SimulateProcessorResultTests extends ESTestCase {
if (isFailure) { if (isFailure) {
simulateProcessorResult = new SimulateProcessorResult(processorId, new IllegalArgumentException("test")); simulateProcessorResult = new SimulateProcessorResult(processorId, new IllegalArgumentException("test"));
} else { } else {
Data data = new Data(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), IngestDocument ingestDocument = new IngestDocument(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10),
Collections.singletonMap(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10))); Collections.singletonMap(randomAsciiOfLengthBetween(1, 10), randomAsciiOfLengthBetween(1, 10)));
simulateProcessorResult = new SimulateProcessorResult(processorId, data); simulateProcessorResult = new SimulateProcessorResult(processorId, ingestDocument);
} }
BytesStreamOutput out = new BytesStreamOutput(); BytesStreamOutput out = new BytesStreamOutput();