[OLINGO-669] Fix: Dispatching of reference delete requests to collection-valued navigation properties
This commit is contained in:
parent
f182fd20c1
commit
93031e4889
|
@ -273,40 +273,42 @@ public class ODataDispatcher {
|
||||||
throws ODataHandlerException, ContentNegotiatorException, ODataApplicationException,
|
throws ODataHandlerException, ContentNegotiatorException, ODataApplicationException,
|
||||||
SerializerException, DeserializerException {
|
SerializerException, DeserializerException {
|
||||||
final HttpMethod method = request.getMethod();
|
final HttpMethod method = request.getMethod();
|
||||||
if (((UriResourcePartTyped) uriInfo.getUriResourceParts().get(lastPathSegmentIndex - 1)).isCollection()) {
|
final boolean isCollection = ((UriResourcePartTyped) uriInfo.getUriResourceParts()
|
||||||
if (method == HttpMethod.GET) {
|
.get(lastPathSegmentIndex - 1))
|
||||||
|
.isCollection();
|
||||||
|
|
||||||
|
if(isCollection && method == HttpMethod.GET) {
|
||||||
final ContentType responseFormat = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
final ContentType responseFormat = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
||||||
request, handler.getCustomContentTypeSupport(), RepresentationType.COLLECTION_REFERENCE);
|
request, handler.getCustomContentTypeSupport(), RepresentationType.COLLECTION_REFERENCE);
|
||||||
handler.selectProcessor(ReferenceCollectionProcessor.class)
|
handler.selectProcessor(ReferenceCollectionProcessor.class)
|
||||||
.readReferenceCollection(request, response, uriInfo, responseFormat);
|
.readReferenceCollection(request, response, uriInfo, responseFormat);
|
||||||
} else if (method == HttpMethod.POST) {
|
|
||||||
|
} else if(isCollection && method == HttpMethod.POST ) {
|
||||||
final ContentType requestFormat = ContentType.parse(request.getHeader(HttpHeader.CONTENT_TYPE));
|
final ContentType requestFormat = ContentType.parse(request.getHeader(HttpHeader.CONTENT_TYPE));
|
||||||
checkContentTypeSupport(requestFormat, RepresentationType.REFERENCE);
|
checkContentTypeSupport(requestFormat, RepresentationType.REFERENCE);
|
||||||
handler.selectProcessor(ReferenceProcessor.class)
|
handler.selectProcessor(ReferenceProcessor.class)
|
||||||
.createReference(request, response, uriInfo, requestFormat);
|
.createReference(request, response, uriInfo, requestFormat);
|
||||||
} else {
|
|
||||||
throw new ODataHandlerException("HTTP method " + method + " is not allowed.",
|
} else if(!isCollection && method == HttpMethod.GET) {
|
||||||
ODataHandlerException.MessageKeys.HTTP_METHOD_NOT_ALLOWED, method.toString());
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (method == HttpMethod.GET) {
|
|
||||||
final ContentType responseFormat = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
final ContentType responseFormat = ContentNegotiator.doContentNegotiation(uriInfo.getFormatOption(),
|
||||||
request, handler.getCustomContentTypeSupport(), RepresentationType.REFERENCE);
|
request, handler.getCustomContentTypeSupport(), RepresentationType.REFERENCE);
|
||||||
handler.selectProcessor(ReferenceProcessor.class).readReference(request, response, uriInfo, responseFormat);
|
handler.selectProcessor(ReferenceProcessor.class).readReference(request, response, uriInfo, responseFormat);
|
||||||
} else if (method == HttpMethod.PUT || method == HttpMethod.PATCH) {
|
|
||||||
|
} else if(!isCollection && (method == HttpMethod.PUT || method == HttpMethod.PATCH)) {
|
||||||
final ContentType requestFormat = ContentType.parse(request.getHeader(HttpHeader.CONTENT_TYPE));
|
final ContentType requestFormat = ContentType.parse(request.getHeader(HttpHeader.CONTENT_TYPE));
|
||||||
checkContentTypeSupport(requestFormat, RepresentationType.REFERENCE);
|
checkContentTypeSupport(requestFormat, RepresentationType.REFERENCE);
|
||||||
handler.selectProcessor(ReferenceProcessor.class)
|
handler.selectProcessor(ReferenceProcessor.class)
|
||||||
.updateReference(request, response, uriInfo, requestFormat);
|
.updateReference(request, response, uriInfo, requestFormat);
|
||||||
} else if (method == HttpMethod.DELETE) {
|
|
||||||
|
} else if(method == HttpMethod.DELETE) {
|
||||||
handler.selectProcessor(ReferenceProcessor.class)
|
handler.selectProcessor(ReferenceProcessor.class)
|
||||||
.deleteReference(request, response, uriInfo);
|
.deleteReference(request, response, uriInfo);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
throw new ODataHandlerException("HTTP method " + method + " is not allowed.",
|
throw new ODataHandlerException("HTTP method " + method + " is not allowed.",
|
||||||
ODataHandlerException.MessageKeys.HTTP_METHOD_NOT_ALLOWED, method.toString());
|
ODataHandlerException.MessageKeys.HTTP_METHOD_NOT_ALLOWED, method.toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
private void handleValueDispatching(final ODataRequest request, final ODataResponse response,
|
private void handleValueDispatching(final ODataRequest request, final ODataResponse response,
|
||||||
final int lastPathSegmentIndex)
|
final int lastPathSegmentIndex)
|
||||||
|
|
|
@ -29,6 +29,7 @@ import static org.mockito.Mockito.times;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.verifyZeroInteractions;
|
import static org.mockito.Mockito.verifyZeroInteractions;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
@ -649,6 +650,7 @@ public class ODataHandlerTest {
|
||||||
@Test
|
@Test
|
||||||
public void dispatchReference() throws Exception {
|
public void dispatchReference() throws Exception {
|
||||||
final String uri = "ESAllPrim(0)/NavPropertyETTwoPrimOne/$ref";
|
final String uri = "ESAllPrim(0)/NavPropertyETTwoPrimOne/$ref";
|
||||||
|
final String uriDeleteMany = "ESAllPrim(0)/NavPropertyETTwoPrimMany/$ref";
|
||||||
final ReferenceProcessor processor = mock(ReferenceProcessor.class);
|
final ReferenceProcessor processor = mock(ReferenceProcessor.class);
|
||||||
|
|
||||||
dispatch(HttpMethod.GET, uri, processor);
|
dispatch(HttpMethod.GET, uri, processor);
|
||||||
|
@ -663,13 +665,13 @@ public class ODataHandlerTest {
|
||||||
verify(processor, times(2)).updateReference(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class),
|
verify(processor, times(2)).updateReference(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class),
|
||||||
any(ContentType.class));
|
any(ContentType.class));
|
||||||
|
|
||||||
dispatch(HttpMethod.DELETE, uri, processor);
|
|
||||||
verify(processor).deleteReference(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class));
|
|
||||||
|
|
||||||
dispatch(HttpMethod.POST, uri.replace("One", "Many"), processor);
|
dispatch(HttpMethod.POST, uri.replace("One", "Many"), processor);
|
||||||
verify(processor).createReference(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class),
|
verify(processor).createReference(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class),
|
||||||
any(ContentType.class));
|
any(ContentType.class));
|
||||||
|
|
||||||
|
dispatch(HttpMethod.DELETE, uriDeleteMany, "$id=ESTwoPrim(1)", null, Arrays.asList(new Processor[] { processor }));
|
||||||
|
verify(processor).deleteReference(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class));
|
||||||
|
|
||||||
dispatchMethodNotAllowed(HttpMethod.POST, uri, processor);
|
dispatchMethodNotAllowed(HttpMethod.POST, uri, processor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -677,14 +679,17 @@ public class ODataHandlerTest {
|
||||||
public void dispatchReferenceCollection() throws Exception {
|
public void dispatchReferenceCollection() throws Exception {
|
||||||
final String uri = "ESAllPrim(0)/NavPropertyETTwoPrimMany/$ref";
|
final String uri = "ESAllPrim(0)/NavPropertyETTwoPrimMany/$ref";
|
||||||
final ReferenceCollectionProcessor processor = mock(ReferenceCollectionProcessor.class);
|
final ReferenceCollectionProcessor processor = mock(ReferenceCollectionProcessor.class);
|
||||||
|
final ReferenceProcessor singleProcessor = mock(ReferenceProcessor.class);
|
||||||
|
|
||||||
dispatch(HttpMethod.GET, uri, processor);
|
dispatch(HttpMethod.GET, uri, processor);
|
||||||
verify(processor).readReferenceCollection(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class),
|
verify(processor).readReferenceCollection(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class),
|
||||||
any(ContentType.class));
|
any(ContentType.class));
|
||||||
|
|
||||||
|
dispatch(HttpMethod.DELETE, uri, singleProcessor);
|
||||||
|
verify(singleProcessor).deleteReference(any(ODataRequest.class), any(ODataResponse.class), any(UriInfo.class));
|
||||||
|
|
||||||
dispatchMethodNotAllowed(HttpMethod.PATCH, uri, processor);
|
dispatchMethodNotAllowed(HttpMethod.PATCH, uri, processor);
|
||||||
dispatchMethodNotAllowed(HttpMethod.PUT, uri, processor);
|
dispatchMethodNotAllowed(HttpMethod.PUT, uri, processor);
|
||||||
dispatchMethodNotAllowed(HttpMethod.DELETE, uri, processor);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
Loading…
Reference in New Issue