Browse Source

DATACMNS-1827 - Consider Qualifier meta-annotated Sort method parameters.

Original pull request: #474.
2.4.x
Vedran Pavic 5 years ago committed by Mark Paluch
parent
commit
f9a776ba1d
No known key found for this signature in database
GPG Key ID: 4406B84C1661DCD1
  1. 25
      src/main/java/org/springframework/data/web/SortHandlerMethodArgumentResolverSupport.java
  2. 14
      src/test/java/org/springframework/data/web/PageableHandlerMethodArgumentResolverUnitTests.java
  3. 11
      src/test/java/org/springframework/data/web/SortHandlerMethodArgumentResolverUnitTests.java
  4. 37
      src/test/java/org/springframework/data/web/TestQualifier.java

25
src/main/java/org/springframework/data/web/SortHandlerMethodArgumentResolverSupport.java

@ -22,14 +22,15 @@ import java.util.List; @@ -22,14 +22,15 @@ import java.util.List;
import java.util.Optional;
import java.util.function.Consumer;
import javax.annotation.Nullable;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.core.MethodParameter;
import org.springframework.core.annotation.MergedAnnotation;
import org.springframework.core.annotation.MergedAnnotations;
import org.springframework.data.domain.Sort;
import org.springframework.data.domain.Sort.Direction;
import org.springframework.data.domain.Sort.Order;
import org.springframework.data.web.SortDefault.SortDefaults;
import org.springframework.lang.Nullable;
import org.springframework.util.Assert;
import org.springframework.util.StringUtils;
@ -41,6 +42,7 @@ import org.springframework.util.StringUtils; @@ -41,6 +42,7 @@ import org.springframework.util.StringUtils;
* @see SortHandlerMethodArgumentResolver
* @see ReactiveSortHandlerMethodArgumentResolver
* @author Mark Paluch
* @author Vedran Pavic
*/
public abstract class SortHandlerMethodArgumentResolverSupport {
@ -184,10 +186,10 @@ public abstract class SortHandlerMethodArgumentResolverSupport { @@ -184,10 +186,10 @@ public abstract class SortHandlerMethodArgumentResolverSupport {
StringBuilder builder = new StringBuilder();
Qualifier qualifier = parameter != null ? parameter.getParameterAnnotation(Qualifier.class) : null;
String value = getQualifier(parameter);
if (qualifier != null && StringUtils.hasLength(qualifier.value())) {
builder.append(qualifier.value());
if (StringUtils.hasLength(value)) {
builder.append(value);
builder.append(qualifierDelimiter);
}
@ -293,6 +295,19 @@ public abstract class SortHandlerMethodArgumentResolverSupport { @@ -293,6 +295,19 @@ public abstract class SortHandlerMethodArgumentResolverSupport {
return StringUtils.hasText(source.replace(".", ""));
}
@Nullable
private static String getQualifier(@Nullable MethodParameter parameter) {
if (parameter == null) {
return null;
}
MergedAnnotations annotations = MergedAnnotations.from(parameter.getParameter());
MergedAnnotation<Qualifier> qualifier = annotations.get(Qualifier.class);
return qualifier.isPresent() ? qualifier.getString("value") : null;
}
/**
* Helper to easily build request parameter expressions for {@link Sort} instances.
*

14
src/test/java/org/springframework/data/web/PageableHandlerMethodArgumentResolverUnitTests.java

@ -257,6 +257,18 @@ class PageableHandlerMethodArgumentResolverUnitTests extends PageableDefaultUnit @@ -257,6 +257,18 @@ class PageableHandlerMethodArgumentResolverUnitTests extends PageableDefaultUnit
assertSupportedAndResult(parameter, PageRequest.of(2, 10), request);
}
@Test // DATACMNS-1827
void mergedQualifierIsUsedInParameterLookup() throws Exception {
MethodParameter parameter = new MethodParameter(Sample.class.getMethod("mergedQualifier", Pageable.class), 0);
MockHttpServletRequest request = new MockHttpServletRequest();
request.addParameter("merged_page", "2");
request.addParameter("merged_size", "10");
assertSupportedAndResult(parameter, PageRequest.of(2, 10), request);
}
@Override
protected PageableHandlerMethodArgumentResolver getResolver() {
PageableHandlerMethodArgumentResolver resolver = new PageableHandlerMethodArgumentResolver();
@ -298,5 +310,7 @@ class PageableHandlerMethodArgumentResolverUnitTests extends PageableDefaultUnit @@ -298,5 +310,7 @@ class PageableHandlerMethodArgumentResolverUnitTests extends PageableDefaultUnit
void noQualifiers(Pageable first, Pageable second);
void emptyQualifier(@Qualifier Pageable pageable);
void mergedQualifier(@TestQualifier Pageable pageable);
}
}

11
src/test/java/org/springframework/data/web/SortHandlerMethodArgumentResolverUnitTests.java

@ -251,6 +251,15 @@ class SortHandlerMethodArgumentResolverUnitTests extends SortDefaultUnitTests { @@ -251,6 +251,15 @@ class SortHandlerMethodArgumentResolverUnitTests extends SortDefaultUnitTests {
assertSupportedAndResolvedTo(getRequestWithSort(reference, ""), parameter, reference);
}
@Test // DATACMNS-1827
void mergedQualifierIsUsedInParameterLookup() {
MethodParameter parameter = getParameterOfMethod("mergedQualifier");
Sort reference = Sort.by("bar", "foo");
assertSupportedAndResolvedTo(getRequestWithSort(reference, "merged"), parameter, reference);
}
private static Sort resolveSort(HttpServletRequest request, MethodParameter parameter) throws Exception {
SortHandlerMethodArgumentResolver resolver = new SortHandlerMethodArgumentResolver();
@ -318,5 +327,7 @@ class SortHandlerMethodArgumentResolverUnitTests extends SortDefaultUnitTests { @@ -318,5 +327,7 @@ class SortHandlerMethodArgumentResolverUnitTests extends SortDefaultUnitTests {
void invalid(@SortDefaults(@SortDefault({ "foo", "bar" })) @SortDefault({ "bar", "foo" }) Sort sort);
void emptyQualifier(@Qualifier Sort sort);
void mergedQualifier(@TestQualifier Sort sort);
}
}

37
src/test/java/org/springframework/data/web/TestQualifier.java

@ -0,0 +1,37 @@ @@ -0,0 +1,37 @@
/*
* Copyright 2020 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.springframework.data.web;
import org.springframework.beans.factory.annotation.Qualifier;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* @author Vedran Pavic
* @see PageableHandlerMethodArgumentResolverUnitTests
* @see SortHandlerMethodArgumentResolverUnitTests
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.PARAMETER)
@Qualifier("merged")
@interface TestQualifier {
}
Loading…
Cancel
Save