Details
-
Bug
-
Status: Closed
-
Minor
-
Resolution: Fixed
-
3.4, 4.0-ALPHA
-
None
-
4.0 trunk, snapshot taken 09/08/2011.
Description
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)
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);