TrieTokenizerFactory should catch NumberFormatException, return 400 (not 500)
-----------------------------------------------------------------------------

                 Key: SOLR-2813
                 URL: https://issues.apache.org/jira/browse/SOLR-2813
             Project: Solr
          Issue Type: Bug
          Components: Schema and Analysis
    Affects Versions: 4.0
         Environment: 4.0 trunk, snapshot taken 09/08/2011.
            Reporter: Jeff Crump
            Priority: Minor


TrieTokenizerFactory is allowing bad user input to result in a 500 error rather 
than a 400.  For a long-valued field, for example, this code in 
TrieTokenizerFactory.reset() will throw a NumberFormatException:

> case LONG:
>          ts.setLongValue(Long.parseLong(v));
>          break;

The NFE gets all the way out to RequestHandlerBase.handleRequest():

> catch (Exception e) {
>      SolrException.log(SolrCore.log,e);
>      if (e instanceof ParseException) {
>        e = new SolrException(SolrException.ErrorCode.BAD_REQUEST, e);
>      }

but is not caught here, and ends up coming out of SolrDispatchFilter.sendError 
as a 500.

Simply catching NFE and turning it into a SolrException does the trick:

==== solr/core/src/java/org/apache/solr/analysis/TrieTokenizerFactory.java#1 - 
/4.0-trunk-09082011/solr/core/src/java/org/apache/solr/analysis/TrieTokenizerFactory.java
 ====
110a111,112
>     } catch (NumberFormatException e) {
>         throw new SolrException(SolrException.ErrorCode.BAD_REQUEST, "Unable 
> to parse input", e);


--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: 
https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to