|
@@ -20,8 +20,11 @@
|
|
|
package org.elasticsearch.index.mapper.boost;
|
|
|
|
|
|
import org.apache.lucene.index.IndexableField;
|
|
|
+import org.elasticsearch.Version;
|
|
|
+import org.elasticsearch.cluster.metadata.IndexMetaData;
|
|
|
import org.elasticsearch.common.bytes.BytesReference;
|
|
|
import org.elasticsearch.common.compress.CompressedXContent;
|
|
|
+import org.elasticsearch.common.settings.Settings;
|
|
|
import org.elasticsearch.common.xcontent.XContentFactory;
|
|
|
import org.elasticsearch.index.mapper.DocumentMapper;
|
|
|
import org.elasticsearch.index.mapper.MapperParsingException;
|
|
@@ -33,7 +36,10 @@ import static org.hamcrest.Matchers.closeTo;
|
|
|
/**
|
|
|
*/
|
|
|
public class FieldLevelBoostTests extends ESSingleNodeTestCase {
|
|
|
- public void testFieldLevelBoost() throws Exception {
|
|
|
+
|
|
|
+ private static final Settings BW_SETTINGS = Settings.builder().put(IndexMetaData.SETTING_VERSION_CREATED, Version.V_2_0_0).build();
|
|
|
+
|
|
|
+ public void testBackCompatFieldLevelBoost() throws Exception {
|
|
|
String mapping = XContentFactory.jsonBuilder().startObject().startObject("person").startObject("properties")
|
|
|
.startObject("str_field").field("type", "string").endObject()
|
|
|
.startObject("int_field").field("type", "integer").startObject("norms").field("enabled", true).endObject().endObject()
|
|
@@ -45,7 +51,7 @@ public class FieldLevelBoostTests extends ESSingleNodeTestCase {
|
|
|
.startObject("short_field").field("type", "short").startObject("norms").field("enabled", true).endObject().endObject()
|
|
|
.string();
|
|
|
|
|
|
- DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("person", new CompressedXContent(mapping));
|
|
|
+ DocumentMapper docMapper = createIndex("test", BW_SETTINGS).mapperService().documentMapperParser().parse("person", new CompressedXContent(mapping));
|
|
|
BytesReference json = XContentFactory.jsonBuilder().startObject()
|
|
|
.startObject("str_field").field("boost", 2.0).field("value", "some name").endObject()
|
|
|
.startObject("int_field").field("boost", 3.0).field("value", 10).endObject()
|
|
@@ -83,7 +89,7 @@ public class FieldLevelBoostTests extends ESSingleNodeTestCase {
|
|
|
assertThat((double) f.boost(), closeTo(9.0, 0.001));
|
|
|
}
|
|
|
|
|
|
- public void testInvalidFieldLevelBoost() throws Exception {
|
|
|
+ public void testBackCompatInvalidFieldLevelBoost() throws Exception {
|
|
|
String mapping = XContentFactory.jsonBuilder().startObject().startObject("person").startObject("properties")
|
|
|
.startObject("str_field").field("type", "string").endObject()
|
|
|
.startObject("int_field").field("type", "integer").startObject("norms").field("enabled", true).endObject().endObject()
|
|
@@ -95,7 +101,7 @@ public class FieldLevelBoostTests extends ESSingleNodeTestCase {
|
|
|
.startObject("short_field").field("type", "short").startObject("norms").field("enabled", true).endObject().endObject()
|
|
|
.string();
|
|
|
|
|
|
- DocumentMapper docMapper = createIndex("test").mapperService().documentMapperParser().parse("person", new CompressedXContent(mapping));
|
|
|
+ DocumentMapper docMapper = createIndex("test", BW_SETTINGS).mapperService().documentMapperParser().parse("person", new CompressedXContent(mapping));
|
|
|
try {
|
|
|
docMapper.parse("test", "person", "1", XContentFactory.jsonBuilder().startObject()
|
|
|
.startObject("str_field").field("foo", "bar")
|