From 1579e491d8f1d77d97b3df6af3b4328364353448 Mon Sep 17 00:00:00 2001 From: Jason Tedor Date: Fri, 21 Aug 2015 07:57:27 -0400 Subject: [PATCH] Limit type name length This commit will limit type name length to be at most 255 characters. Closes #13021 --- .../index/mapper/MapperService.java | 3 ++ .../index/mapper/MapperServiceTest.java | 41 +++++++++++++++++++ 2 files changed, 44 insertions(+) diff --git a/core/src/main/java/org/elasticsearch/index/mapper/MapperService.java b/core/src/main/java/org/elasticsearch/index/mapper/MapperService.java index 8386932465f..db2d0b20390 100755 --- a/core/src/main/java/org/elasticsearch/index/mapper/MapperService.java +++ b/core/src/main/java/org/elasticsearch/index/mapper/MapperService.java @@ -261,6 +261,9 @@ public class MapperService extends AbstractIndexComponent implements Closeable { if (mapper.type().length() == 0) { throw new InvalidTypeNameException("mapping type name is empty"); } + if (Version.indexCreated(indexSettings).onOrAfter(Version.V_2_0_0_beta1) && mapper.type().length() > 255) { + throw new InvalidTypeNameException("mapping type name [" + mapper.type() + "] is too long; limit is length 255 but was [" + mapper.type().length() + "]"); + } if (mapper.type().charAt(0) == '_') { throw new InvalidTypeNameException("mapping type name [" + mapper.type() + "] can't start with '_'"); } diff --git a/core/src/test/java/org/elasticsearch/index/mapper/MapperServiceTest.java b/core/src/test/java/org/elasticsearch/index/mapper/MapperServiceTest.java index 21f6fc8bebf..d1c78c6b9f9 100644 --- a/core/src/test/java/org/elasticsearch/index/mapper/MapperServiceTest.java +++ b/core/src/test/java/org/elasticsearch/index/mapper/MapperServiceTest.java @@ -19,12 +19,18 @@ package org.elasticsearch.index.mapper; +import org.elasticsearch.Version; +import org.elasticsearch.action.admin.indices.create.CreateIndexResponse; import org.elasticsearch.test.ESSingleNodeTestCase; import org.junit.Rule; import org.junit.Test; import org.junit.rules.ExpectedException; +import static org.elasticsearch.test.VersionUtils.getFirstVersion; +import static org.elasticsearch.test.VersionUtils.getPreviousVersion; +import static org.elasticsearch.test.VersionUtils.randomVersionBetween; import static org.hamcrest.CoreMatchers.containsString; +import static org.hamcrest.CoreMatchers.is; import static org.hamcrest.Matchers.hasToString; public class MapperServiceTest extends ESSingleNodeTestCase { @@ -46,4 +52,39 @@ public class MapperServiceTest extends ESSingleNodeTestCase { .execute() .actionGet(); } + + @Test + public void testThatLongTypeNameIsNotRejectedOnPreElasticsearchVersionTwo() { + String index = "text-index"; + String field = "field"; + String type = new String(new char[256]).replace("\0", "a"); + + CreateIndexResponse response = + client() + .admin() + .indices() + .prepareCreate(index) + .setSettings(settings(randomVersionBetween(random(), getFirstVersion(), getPreviousVersion(Version.V_2_0_0_beta1)))) + .addMapping(type, field, "type=string") + .execute() + .actionGet(); + assertNotNull(response); + } + + @Test + public void testTypeNameTooLong() { + String index = "text-index"; + String field = "field"; + String type = new String(new char[256]).replace("\0", "a"); + + expectedException.expect(MapperParsingException.class); + expectedException.expect(hasToString(containsString("mapping type name [" + type + "] is too long; limit is length 255 but was [256]"))); + client() + .admin() + .indices() + .prepareCreate(index) + .addMapping(type, field, "type=string") + .execute() + .actionGet(); + } }