From 83c80376fa57f7218b45735dd39316684f68db4c Mon Sep 17 00:00:00 2001 From: noble Date: Sat, 12 Oct 2019 15:27:41 +1100 Subject: [PATCH] SOLR-13787: Better error logging --- .../src/java/org/apache/solr/api/AnnotatedApi.java | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/solr/core/src/java/org/apache/solr/api/AnnotatedApi.java b/solr/core/src/java/org/apache/solr/api/AnnotatedApi.java index 964af8587a3..e9073ae7bb1 100644 --- a/solr/core/src/java/org/apache/solr/api/AnnotatedApi.java +++ b/solr/core/src/java/org/apache/solr/api/AnnotatedApi.java @@ -18,6 +18,7 @@ package org.apache.solr.api; +import java.lang.invoke.MethodHandles; import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; @@ -44,6 +45,8 @@ import org.apache.solr.request.SolrQueryRequest; import org.apache.solr.response.SolrQueryResponse; import org.apache.solr.security.AuthorizationContext; import org.apache.solr.security.PermissionNameProvider; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; /** * This class implements an Api just from an annotated java class @@ -56,6 +59,9 @@ import org.apache.solr.security.PermissionNameProvider; */ public class AnnotatedApi extends Api implements PermissionNameProvider { + private static final Logger log = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass()); + + public static final String ERR ="Error executing commands :"; private EndPoint endPoint; private Map commands = new HashMap<>(); private final Api fallback; @@ -155,7 +161,8 @@ public class AnnotatedApi extends Api implements PermissionNameProvider { List errs = CommandOperation.captureErrors(cmds); if (!errs.isEmpty()) { - throw new ApiBag.ExceptionWithErrObject(SolrException.ErrorCode.BAD_REQUEST, "Error in executing commands", errs); + log.error(ERR+ Utils.toJSONString(errs)); + throw new ApiBag.ExceptionWithErrObject(SolrException.ErrorCode.BAD_REQUEST, ERR , errs); } } @@ -220,7 +227,6 @@ public class AnnotatedApi extends Api implements PermissionNameProvider { } if (isWrappedInPayloadObj) { PayloadObj payloadObj = new PayloadObj<>(cmd.name, cmd.getCommandData(), o); - cmd = payloadObj; method.invoke(obj, req, rsp, payloadObj); } else { method.invoke(obj, req, rsp, o); @@ -260,7 +266,6 @@ public class AnnotatedApi extends Api implements PermissionNameProvider { public static Map createSchema(Method m) { Type[] types = m.getGenericParameterTypes(); - Map result; if (types.length == 3) { return createSchemaFromType(types[2]); @@ -297,8 +302,6 @@ public class AnnotatedApi extends Api implements PermissionNameProvider { JsonProperty p = fld.getAnnotation(JsonProperty.class); if (p == null) continue; props.put(p.value(), createSchemaFromType(fld.getGenericType())); - - } }