better server error messages in case of $format errors
Change-Id: If4495f5c91086618ee7d3824339aa5e7b99ff76c Signed-off-by: Christian Amend <chrisam@apache.org>
This commit is contained in:
parent
f947afc108
commit
788036db25
|
@ -52,11 +52,10 @@ public class ODataExceptionHelper {
|
||||||
|
|
||||||
public static ODataServerError createServerErrorObject(UriParserSyntaxException e, Locale requestedLocale) {
|
public static ODataServerError createServerErrorObject(UriParserSyntaxException e, Locale requestedLocale) {
|
||||||
ODataServerError serverError = basicTranslatedError(e, requestedLocale);
|
ODataServerError serverError = basicTranslatedError(e, requestedLocale);
|
||||||
if(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE.equals(e.getMessageKey())){
|
serverError.setStatusCode(
|
||||||
serverError.setStatusCode(HttpStatusCode.NOT_ACCEPTABLE.getStatusCode());
|
UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT.equals(e.getMessageKey()) ?
|
||||||
}else{
|
HttpStatusCode.NOT_ACCEPTABLE.getStatusCode() :
|
||||||
serverError.setStatusCode(HttpStatusCode.BAD_REQUEST.getStatusCode());
|
HttpStatusCode.BAD_REQUEST.getStatusCode());
|
||||||
}
|
|
||||||
return serverError;
|
return serverError;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -188,8 +188,7 @@ public class Parser {
|
||||||
formatOption.setFormat(option.value);
|
formatOption.setFormat(option.value);
|
||||||
} else {
|
} else {
|
||||||
throw new UriParserSyntaxException("Illegal value of $format option!",
|
throw new UriParserSyntaxException("Illegal value of $format option!",
|
||||||
UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE,
|
UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT, option.value);
|
||||||
option.name, option.value);
|
|
||||||
}
|
}
|
||||||
context.contextUriInfo.setSystemQueryOption(formatOption);
|
context.contextUriInfo.setSystemQueryOption(formatOption);
|
||||||
|
|
||||||
|
|
|
@ -28,7 +28,7 @@ public class UriParserSyntaxException extends UriParserException {
|
||||||
/** parameters: query-option name, query-option value */ WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION,
|
/** parameters: query-option name, query-option value */ WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION,
|
||||||
SYNTAX,
|
SYNTAX,
|
||||||
SYSTEM_QUERY_OPTION_LEVELS_NOT_ALLOWED_HERE,
|
SYSTEM_QUERY_OPTION_LEVELS_NOT_ALLOWED_HERE,
|
||||||
/** parameter: query-option value */ WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE;
|
/** parameter: $format option value */ WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getKey() {
|
public String getKey() {
|
||||||
|
|
|
@ -26,7 +26,7 @@ ODataHandlerException.ODATA_VERSION_NOT_SUPPORTED=OData version '%1$s' is not su
|
||||||
|
|
||||||
UriParserSyntaxException.UNKNOWN_SYSTEM_QUERY_OPTION=The system query option '%1$s' is not defined.
|
UriParserSyntaxException.UNKNOWN_SYSTEM_QUERY_OPTION=The system query option '%1$s' is not defined.
|
||||||
UriParserSyntaxException.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION=The system query option '%1$s' has the not-allowed value '%2$s'.
|
UriParserSyntaxException.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION=The system query option '%1$s' has the not-allowed value '%2$s'.
|
||||||
UriParserSyntaxException.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE=The system query option $value must be either json, xml, atom or a valid content-type. The value '%1$s' is neither.
|
UriParserSyntaxException.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT=The system query option '$format' must be either 'json', 'xml', 'atom', or a valid content type; the value '%1$s' is neither.
|
||||||
UriParserSyntaxException.SYNTAX=The URI is malformed.
|
UriParserSyntaxException.SYNTAX=The URI is malformed.
|
||||||
UriParserSyntaxException.SYSTEM_QUERY_OPTION_LEVELS_NOT_ALLOWED_HERE=The system query option '$levels' is not allowed here.
|
UriParserSyntaxException.SYSTEM_QUERY_OPTION_LEVELS_NOT_ALLOWED_HERE=The system query option '$levels' is not allowed here.
|
||||||
|
|
||||||
|
|
|
@ -2553,15 +2553,15 @@ public class TestFullResourcePath {
|
||||||
.isKind(UriInfoKind.resource).goPath()
|
.isKind(UriInfoKind.resource).goPath()
|
||||||
.isFormatText(HttpContentType.APPLICATION_ATOM_XML_ENTRY_UTF8);
|
.isFormatText(HttpContentType.APPLICATION_ATOM_XML_ENTRY_UTF8);
|
||||||
testUri.runEx("ESKeyNav(1)?$format=noSlash")
|
testUri.runEx("ESKeyNav(1)?$format=noSlash")
|
||||||
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE);
|
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT);
|
||||||
testUri.runEx("ESKeyNav(1)?$format=slashAtEnd/")
|
testUri.runEx("ESKeyNav(1)?$format=slashAtEnd/")
|
||||||
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE);
|
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT);
|
||||||
testUri.runEx("ESKeyNav(1)?$format=/startsWithSlash")
|
testUri.runEx("ESKeyNav(1)?$format=/startsWithSlash")
|
||||||
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE);
|
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT);
|
||||||
testUri.runEx("ESKeyNav(1)?$format=two/Slashes/tooMuch")
|
testUri.runEx("ESKeyNav(1)?$format=two/Slashes/tooMuch")
|
||||||
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE);
|
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT);
|
||||||
testUri.runEx("ESKeyNav(1)?$format=")
|
testUri.runEx("ESKeyNav(1)?$format=")
|
||||||
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_VALUE);
|
.isExSyntax(UriParserSyntaxException.MessageKeys.WRONG_VALUE_FOR_SYSTEM_QUERY_OPTION_FORMAT);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
Loading…
Reference in New Issue