mirror of https://github.com/apache/lucene.git
SOLR-5010: switch to lists for copy fields
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1501715 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
46e83f7e60
commit
f007cde66d
|
@ -136,21 +136,11 @@ public class CopyFieldCollectionResource extends BaseFieldResource implements GE
|
||||||
log.error(message);
|
log.error(message);
|
||||||
throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, message);
|
throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, message);
|
||||||
}
|
}
|
||||||
String destinations = (String)map.get(IndexSchema.DESTINATION);
|
List<String> destinations = (List<String>)map.get(IndexSchema.DESTINATION);
|
||||||
if (destinations == null) {
|
if (destinations == null) {
|
||||||
String message = "Missing '" + IndexSchema.DESTINATION + "' mapping.";
|
|
||||||
log.error(message);
|
|
||||||
throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, message);
|
|
||||||
}
|
|
||||||
String [] splits = destinations.split(",");
|
|
||||||
Set<String> destinationSet = new HashSet<>();
|
|
||||||
if (splits != null && splits.length > 0){
|
|
||||||
for (int i = 0; i < splits.length; i++) {
|
|
||||||
destinationSet.add(splits[i].trim());
|
|
||||||
}
|
|
||||||
fieldsToCopy.put(fieldName, destinationSet);
|
|
||||||
} else {
|
|
||||||
malformed.add(fieldName);
|
malformed.add(fieldName);
|
||||||
|
} else {
|
||||||
|
fieldsToCopy.put(fieldName, destinations);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (malformed.size() > 0){
|
if (malformed.size() > 0){
|
||||||
|
|
|
@ -155,33 +155,13 @@ public class FieldCollectionResource extends BaseFieldResource implements GETabl
|
||||||
throw new SolrException(ErrorCode.BAD_REQUEST, message);
|
throw new SolrException(ErrorCode.BAD_REQUEST, message);
|
||||||
}
|
}
|
||||||
// copyFields:"comma separated list of destination fields"
|
// copyFields:"comma separated list of destination fields"
|
||||||
String copyTo = (String) map.get(IndexSchema.COPY_FIELDS);
|
List<String> copyTo = (List<String>) map.get(IndexSchema.COPY_FIELDS);
|
||||||
if (copyTo != null) {
|
if (copyTo != null) {
|
||||||
map.remove(IndexSchema.COPY_FIELDS);
|
map.remove(IndexSchema.COPY_FIELDS);
|
||||||
String[] splits = copyTo.split(",");
|
copyFields.put(fieldName, copyTo);
|
||||||
Set<String> destinations = new HashSet<>();
|
|
||||||
if (splits != null && splits.length > 0) {
|
|
||||||
for (int i = 0; i < splits.length; i++) {
|
|
||||||
destinations.add(splits[i].trim());
|
|
||||||
}
|
|
||||||
copyFields.put(fieldName, destinations);
|
|
||||||
} else{
|
|
||||||
malformed.add(fieldName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
newFields.add(oldSchema.newField(fieldName, fieldType, map));
|
newFields.add(oldSchema.newField(fieldName, fieldType, map));
|
||||||
}
|
}
|
||||||
if (malformed.size() > 0){
|
|
||||||
StringBuilder message = new StringBuilder("Malformed destination(s) for: ");
|
|
||||||
for (String s : malformed) {
|
|
||||||
message.append(s).append(", ");
|
|
||||||
}
|
|
||||||
if (message.length() > 2) {
|
|
||||||
message.setLength(message.length() - 2);//drop the last ,
|
|
||||||
}
|
|
||||||
log.error(message.toString().trim());
|
|
||||||
throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, message.toString().trim());
|
|
||||||
}
|
|
||||||
IndexSchema newSchema = oldSchema.addFields(newFields, copyFields);
|
IndexSchema newSchema = oldSchema.addFields(newFields, copyFields);
|
||||||
|
|
||||||
getSolrCore().setLatestSchema(newSchema);
|
getSolrCore().setLatestSchema(newSchema);
|
||||||
|
|
|
@ -34,6 +34,7 @@ import java.io.UnsupportedEncodingException;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -145,22 +146,9 @@ public class FieldResource extends BaseFieldResource implements GETable, PUTable
|
||||||
throw new SolrException(ErrorCode.BAD_REQUEST, message);
|
throw new SolrException(ErrorCode.BAD_REQUEST, message);
|
||||||
} else {
|
} else {
|
||||||
ManagedIndexSchema oldSchema = (ManagedIndexSchema) getSchema();
|
ManagedIndexSchema oldSchema = (ManagedIndexSchema) getSchema();
|
||||||
String copyTo = (String) map.get(IndexSchema.COPY_FIELDS);
|
List<String> copyFieldNames = (List<String>) map.get(IndexSchema.COPY_FIELDS);
|
||||||
Collection<String> copyFieldNames = Collections.emptySet();
|
if (copyFieldNames != null) {
|
||||||
if (copyTo != null) {
|
|
||||||
map.remove(IndexSchema.COPY_FIELDS);
|
map.remove(IndexSchema.COPY_FIELDS);
|
||||||
String [] tmp = copyTo.split(",");
|
|
||||||
if (tmp != null && tmp.length > 0) {
|
|
||||||
copyFieldNames = new HashSet<>(tmp.length);
|
|
||||||
for (int i = 0; i < tmp.length; i++) {
|
|
||||||
copyFieldNames.add(tmp[i].trim());
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
//the user specified copy fields, but then passed in something invalid
|
|
||||||
String msg = "Invalid " + IndexSchema.COPY_FIELDS + " for field: " + fieldName;
|
|
||||||
log.error(msg);
|
|
||||||
throw new SolrException(ErrorCode.BAD_REQUEST, msg);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
SchemaField newField = oldSchema.newField(fieldName, fieldType, map);
|
SchemaField newField = oldSchema.newField(fieldName, fieldType, map);
|
||||||
IndexSchema newSchema = oldSchema.addField(newField, copyFieldNames);
|
IndexSchema newSchema = oldSchema.addField(newField, copyFieldNames);
|
||||||
|
|
|
@ -113,7 +113,7 @@ public class TestManagedSchemaFieldResource extends RestTestBase {
|
||||||
"{\"type\":\"text\",\"stored\":\"false\"}",
|
"{\"type\":\"text\",\"stored\":\"false\"}",
|
||||||
"/responseHeader/status==0");
|
"/responseHeader/status==0");
|
||||||
assertJPut("/schema/fields/fieldB",
|
assertJPut("/schema/fields/fieldB",
|
||||||
"{\"type\":\"text\",\"stored\":\"false\", \"copyFields\":\"fieldA\"}",
|
"{\"type\":\"text\",\"stored\":\"false\", \"copyFields\":[\"fieldA\"]}",
|
||||||
"/responseHeader/status==0");
|
"/responseHeader/status==0");
|
||||||
|
|
||||||
assertQ("/schema/fields/fieldB?indent=on&wt=xml",
|
assertQ("/schema/fields/fieldB?indent=on&wt=xml",
|
||||||
|
@ -122,12 +122,13 @@ public class TestManagedSchemaFieldResource extends RestTestBase {
|
||||||
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldB",
|
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldB",
|
||||||
"count(/response/arr[@name='copyFields']/lst) = 1"
|
"count(/response/arr[@name='copyFields']/lst) = 1"
|
||||||
);
|
);
|
||||||
|
//fine to pass in empty list, just won't do anything
|
||||||
|
assertJPut("/schema/fields/fieldD",
|
||||||
|
"{\"type\":\"text\",\"stored\":\"false\", \"copyFields\":[]}",
|
||||||
|
"/responseHeader/status==0");
|
||||||
//some bad usages
|
//some bad usages
|
||||||
assertJPut("/schema/fields/fieldB",
|
|
||||||
"{\"type\":\"text\",\"stored\":\"false\", \"copyFields\":\",,,\"}",
|
|
||||||
"/error/msg==\"Invalid copyFields for field: fieldB\"");
|
|
||||||
assertJPut("/schema/fields/fieldC",
|
assertJPut("/schema/fields/fieldC",
|
||||||
"{\"type\":\"text\",\"stored\":\"false\", \"copyFields\":\"some_nonexistent_field_ignore_exception\"}",
|
"{\"type\":\"text\",\"stored\":\"false\", \"copyFields\":[\"some_nonexistent_field_ignore_exception\"]}",
|
||||||
"/error/msg==\"copyField dest :\\'some_nonexistent_field_ignore_exception\\' is not an explicit field and doesn\\'t match a dynamicField.\"");
|
"/error/msg==\"copyField dest :\\'some_nonexistent_field_ignore_exception\\' is not an explicit field and doesn\\'t match a dynamicField.\"");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -177,7 +178,7 @@ public class TestManagedSchemaFieldResource extends RestTestBase {
|
||||||
assertJPost("/schema/fields",
|
assertJPost("/schema/fields",
|
||||||
"[{\"name\":\"fieldA\",\"type\":\"text\",\"stored\":\"false\"},"
|
"[{\"name\":\"fieldA\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ "{\"name\":\"fieldB\",\"type\":\"text\",\"stored\":\"false\"},"
|
+ "{\"name\":\"fieldB\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ " {\"name\":\"fieldC\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":\"fieldB\"}]",
|
+ " {\"name\":\"fieldC\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":[\"fieldB\"]}]",
|
||||||
"/responseHeader/status==0");
|
"/responseHeader/status==0");
|
||||||
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldC",
|
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldC",
|
||||||
"count(/response/arr[@name='copyFields']/lst) = 1"
|
"count(/response/arr[@name='copyFields']/lst) = 1"
|
||||||
|
@ -185,30 +186,23 @@ public class TestManagedSchemaFieldResource extends RestTestBase {
|
||||||
assertJPost("/schema/fields",
|
assertJPost("/schema/fields",
|
||||||
"[{\"name\":\"fieldD\",\"type\":\"text\",\"stored\":\"false\"},"
|
"[{\"name\":\"fieldD\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ "{\"name\":\"fieldE\",\"type\":\"text\",\"stored\":\"false\"},"
|
+ "{\"name\":\"fieldE\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ " {\"name\":\"fieldF\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":\"fieldD,fieldE\"}]",
|
+ " {\"name\":\"fieldF\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":[\"fieldD\",\"fieldE\"]}]",
|
||||||
"/responseHeader/status==0");
|
"/responseHeader/status==0");
|
||||||
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldF",
|
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldF",
|
||||||
"count(/response/arr[@name='copyFields']/lst) = 2"
|
"count(/response/arr[@name='copyFields']/lst) = 2"
|
||||||
);
|
);
|
||||||
assertJPost("/schema/fields",
|
//passing in an empty list is perfectly acceptable, it just won't do anything
|
||||||
"[{\"name\":\"fieldG\",\"type\":\"text\",\"stored\":\"false\"},"
|
|
||||||
+ "{\"name\":\"fieldH\",\"type\":\"text\",\"stored\":\"false\"},"
|
|
||||||
+ " {\"name\":\"fieldI\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":\"fieldG, fieldH \"}]",
|
|
||||||
"/responseHeader/status==0");
|
|
||||||
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldF",
|
|
||||||
"count(/response/arr[@name='copyFields']/lst) = 2"
|
|
||||||
);
|
|
||||||
//some bad usages
|
|
||||||
assertJPost("/schema/fields",
|
assertJPost("/schema/fields",
|
||||||
"[{\"name\":\"fieldX\",\"type\":\"text\",\"stored\":\"false\"},"
|
"[{\"name\":\"fieldX\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ "{\"name\":\"fieldY\",\"type\":\"text\",\"stored\":\"false\"},"
|
+ "{\"name\":\"fieldY\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ " {\"name\":\"fieldZ\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":\",,,\"}]",
|
+ " {\"name\":\"fieldZ\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":[]}]",
|
||||||
"/error/msg==\"Malformed destination(s) for: fieldZ\"");
|
"/responseHeader/status==0");
|
||||||
|
//some bad usages
|
||||||
|
|
||||||
assertJPost("/schema/fields",
|
assertJPost("/schema/fields",
|
||||||
"[{\"name\":\"fieldX\",\"type\":\"text\",\"stored\":\"false\"},"
|
"[{\"name\":\"fieldH\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ "{\"name\":\"fieldY\",\"type\":\"text\",\"stored\":\"false\"},"
|
+ "{\"name\":\"fieldI\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ " {\"name\":\"fieldZ\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":\"some_nonexistent_field_ignore_exception\"}]",
|
+ " {\"name\":\"fieldJ\",\"type\":\"text\",\"stored\":\"false\", \"copyFields\":[\"some_nonexistent_field_ignore_exception\"]}]",
|
||||||
"/error/msg==\"copyField dest :\\'some_nonexistent_field_ignore_exception\\' is not an explicit field and doesn\\'t match a dynamicField.\"");
|
"/error/msg==\"copyField dest :\\'some_nonexistent_field_ignore_exception\\' is not an explicit field and doesn\\'t match a dynamicField.\"");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -221,14 +215,13 @@ public class TestManagedSchemaFieldResource extends RestTestBase {
|
||||||
+ "{\"name\":\"fieldD\",\"type\":\"text\",\"stored\":\"false\"},"
|
+ "{\"name\":\"fieldD\",\"type\":\"text\",\"stored\":\"false\"},"
|
||||||
+ " {\"name\":\"fieldE\",\"type\":\"text\",\"stored\":\"false\"}]",
|
+ " {\"name\":\"fieldE\",\"type\":\"text\",\"stored\":\"false\"}]",
|
||||||
"/responseHeader/status==0");
|
"/responseHeader/status==0");
|
||||||
assertJPost("/schema/copyfields", "[{\"source\":\"fieldA\", \"dest\":\"fieldB\"},{\"source\":\"fieldD\", \"dest\":\"fieldC, fieldE\"}]", "/responseHeader/status==0");
|
assertJPost("/schema/copyfields", "[{\"source\":\"fieldA\", \"dest\":[\"fieldB\"]},{\"source\":\"fieldD\", \"dest\":[\"fieldC\", \"fieldE\"]}]", "/responseHeader/status==0");
|
||||||
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldA",
|
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldA",
|
||||||
"count(/response/arr[@name='copyFields']/lst) = 1");
|
"count(/response/arr[@name='copyFields']/lst) = 1");
|
||||||
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldD",
|
assertQ("/schema/copyfields/?indent=on&wt=xml&source.fl=fieldD",
|
||||||
"count(/response/arr[@name='copyFields']/lst) = 2");
|
"count(/response/arr[@name='copyFields']/lst) = 2");
|
||||||
assertJPost("/schema/copyfields", "[{\"source\":\"fieldD\", \"dest\":\",,,\"}]", "/error/msg==\"Malformed destination(s) for: fieldD\"");
|
assertJPost("/schema/copyfields", "[{\"source\":\"some_nonexistent_field_ignore_exception\", \"dest\":[\"fieldA\"]}]", "/error/msg==\"copyField source :\\'some_nonexistent_field_ignore_exception\\' is not a glob and doesn\\'t match any explicit field or dynamicField.\"");
|
||||||
assertJPost("/schema/copyfields", "[{\"source\":\"some_nonexistent_field_ignore_exception\", \"dest\":\"fieldA\"}]", "/error/msg==\"copyField source :\\'some_nonexistent_field_ignore_exception\\' is not a glob and doesn\\'t match any explicit field or dynamicField.\"");
|
assertJPost("/schema/copyfields", "[{\"source\":\"fieldD\", \"dest\":[\"some_nonexistent_field_ignore_exception\"]}]", "/error/msg==\"copyField dest :\\'some_nonexistent_field_ignore_exception\\' is not an explicit field and doesn\\'t match a dynamicField.\"");
|
||||||
assertJPost("/schema/copyfields", "[{\"source\":\"fieldD\", \"dest\":\"some_nonexistent_field_ignore_exception\"}]", "/error/msg==\"copyField dest :\\'some_nonexistent_field_ignore_exception\\' is not an explicit field and doesn\\'t match a dynamicField.\"");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue