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:
Daniel Mitterdorfer 2016-12-09 12:48:28 +01:00
parent 37b0d52882
commit 8153d2ca69
3 changed files with 11 additions and 11 deletions

View File

@ -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'"));
} }
} }

View File

@ -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()) {

View File

@ -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);
} }