Enable strict duplicate checks for JSON content
With this commit we enable the Jackson feature 'STRICT_DUPLICATE_DETECTION' by default. This ensures that JSON keys are always unique. While this has a performance impact, benchmarking has indicated that the typical drop in indexing throughput is around 1 - 2%. As a last resort, we allow users to still disable strict duplicate checks by setting `-Des.json.strict_duplicate_detection=false` which is intentionally undocumented. Relates elastic/elasticsearchelastic/elasticsearch#19614 Original commit: elastic/x-pack-elasticsearch@cced57b884
This commit is contained in:
parent
37b0d52882
commit
8153d2ca69
|
@ -5,6 +5,7 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.xpack.notification.email.attachment;
|
package org.elasticsearch.xpack.notification.email.attachment;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonParseException;
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.ParseField;
|
import org.elasticsearch.common.ParseField;
|
||||||
import org.elasticsearch.common.xcontent.ToXContent;
|
import org.elasticsearch.common.xcontent.ToXContent;
|
||||||
|
@ -143,8 +144,8 @@ public class EmailAttachmentParsersTests extends ESTestCase {
|
||||||
|
|
||||||
parser.parse(xContentParser);
|
parser.parse(xContentParser);
|
||||||
fail("Expected parser to fail but did not happen");
|
fail("Expected parser to fail but did not happen");
|
||||||
} catch (ElasticsearchParseException e) {
|
} catch (JsonParseException e) {
|
||||||
assertThat(e.getMessage(), is("Attachment with id [my-name.json] has already been created, must be renamed"));
|
assertThat(e.getMessage(), is("Duplicate field 'my-name.json'"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -263,9 +263,7 @@ public class EmailActionTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
builder.endObject();
|
builder.endObject();
|
||||||
}
|
}
|
||||||
}
|
} else if (textBody != null || htmlBody != null) {
|
||||||
|
|
||||||
if (textBody != null || htmlBody != null) {
|
|
||||||
builder.startObject("body");
|
builder.startObject("body");
|
||||||
if (textBody != null) {
|
if (textBody != null) {
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.xpack.watcher.condition;
|
package org.elasticsearch.xpack.watcher.condition;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonParseException;
|
||||||
import org.elasticsearch.ElasticsearchParseException;
|
import org.elasticsearch.ElasticsearchParseException;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
import org.elasticsearch.common.xcontent.XContentParser;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
@ -215,8 +216,8 @@ public class ArrayCompareConditionTests extends ESTestCase {
|
||||||
XContentParser parser = JsonXContent.jsonXContent.createParser(builder.bytes());
|
XContentParser parser = JsonXContent.jsonXContent.createParser(builder.bytes());
|
||||||
parser.nextToken();
|
parser.nextToken();
|
||||||
|
|
||||||
expectedException.expect(ElasticsearchParseException.class);
|
expectedException.expect(JsonParseException.class);
|
||||||
expectedException.expectMessage("duplicate comparison operator");
|
expectedException.expectMessage("Duplicate field '" + op.id() + "'");
|
||||||
|
|
||||||
ArrayCompareCondition.parse(ClockMock.frozen(), "_id", parser);
|
ArrayCompareCondition.parse(ClockMock.frozen(), "_id", parser);
|
||||||
}
|
}
|
||||||
|
@ -263,8 +264,8 @@ public class ArrayCompareConditionTests extends ESTestCase {
|
||||||
XContentParser parser = JsonXContent.jsonXContent.createParser(builder.bytes());
|
XContentParser parser = JsonXContent.jsonXContent.createParser(builder.bytes());
|
||||||
parser.nextToken();
|
parser.nextToken();
|
||||||
|
|
||||||
expectedException.expect(ElasticsearchParseException.class);
|
expectedException.expect(JsonParseException.class);
|
||||||
expectedException.expectMessage("duplicate field \"value\"");
|
expectedException.expectMessage("Duplicate field 'value'");
|
||||||
|
|
||||||
ArrayCompareCondition.parse(ClockMock.frozen(), "_id", parser);
|
ArrayCompareCondition.parse(ClockMock.frozen(), "_id", parser);
|
||||||
}
|
}
|
||||||
|
@ -288,8 +289,8 @@ public class ArrayCompareConditionTests extends ESTestCase {
|
||||||
XContentParser parser = JsonXContent.jsonXContent.createParser(builder.bytes());
|
XContentParser parser = JsonXContent.jsonXContent.createParser(builder.bytes());
|
||||||
parser.nextToken();
|
parser.nextToken();
|
||||||
|
|
||||||
expectedException.expect(ElasticsearchParseException.class);
|
expectedException.expect(JsonParseException.class);
|
||||||
expectedException.expectMessage("duplicate field \"quantifier\"");
|
expectedException.expectMessage("Duplicate field 'quantifier'");
|
||||||
|
|
||||||
ArrayCompareCondition.parse(ClockMock.frozen(), "_id", parser);
|
ArrayCompareCondition.parse(ClockMock.frozen(), "_id", parser);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue