Merge branch '5.1.x'
This commit is contained in:
commit
03a342378a
|
|
@ -100,19 +100,12 @@ public class RequestPartMethodArgumentResolver extends AbstractMessageReaderArgu
|
|||
|
||||
ReactiveAdapter adapter = getAdapterRegistry().getAdapter(parameter.getParameterType());
|
||||
if (adapter != null) {
|
||||
// Mono<Part> or Flux<Part>
|
||||
MethodParameter elementType = parameter.nested();
|
||||
if (Part.class.isAssignableFrom(elementType.getNestedParameterType())) {
|
||||
parts = (adapter.isMultiValue() ? parts : parts.take(1));
|
||||
return Mono.just(adapter.fromPublisher(parts));
|
||||
}
|
||||
// We have to decode the content for each part, one at a time
|
||||
if (adapter.isMultiValue()) {
|
||||
return Mono.just(decodePartValues(parts, elementType, bindingContext, exchange, isRequired));
|
||||
}
|
||||
return Mono.just(adapter.fromPublisher(
|
||||
Part.class.isAssignableFrom(elementType.getNestedParameterType()) ?
|
||||
parts : decodePartValues(parts, elementType, bindingContext, exchange, isRequired)));
|
||||
}
|
||||
|
||||
// <T> or Mono<T>
|
||||
return decodePartValues(parts, parameter, bindingContext, exchange, isRequired)
|
||||
.next().cast(Object.class);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -60,6 +60,7 @@ import static org.springframework.web.method.MvcAnnotationPredicates.requestPart
|
|||
/**
|
||||
* Unit tests for {@link RequestPartMethodArgumentResolver}.
|
||||
* @author Rossen Stoyanchev
|
||||
* @author Ilya Lukyanovich
|
||||
*/
|
||||
public class RequestPartMethodArgumentResolverTests {
|
||||
|
||||
|
|
@ -131,6 +132,15 @@ public class RequestPartMethodArgumentResolverTests {
|
|||
assertThat(actual.get(1).getName()).isEqualTo("James");
|
||||
}
|
||||
|
||||
@Test // gh-23060
|
||||
public void listPersonNotRequired() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart().notRequired()).arg(List.class, Person.class);
|
||||
MultipartBodyBuilder bodyBuilder = new MultipartBodyBuilder();
|
||||
List<Person> actual = resolveArgument(param, bodyBuilder);
|
||||
|
||||
assertThat(actual).isEmpty();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void monoPerson() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart()).arg(Mono.class, Person.class);
|
||||
|
|
@ -141,6 +151,15 @@ public class RequestPartMethodArgumentResolverTests {
|
|||
assertThat(actual.block().getName()).isEqualTo("Jones");
|
||||
}
|
||||
|
||||
@Test // gh-23060
|
||||
public void monoPersonNotRequired() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart().notRequired()).arg(Mono.class, Person.class);
|
||||
MultipartBodyBuilder bodyBuilder = new MultipartBodyBuilder();
|
||||
Mono<Person> actual = resolveArgument(param, bodyBuilder);
|
||||
|
||||
assertThat(actual.block()).isNull();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void fluxPerson() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart()).arg(Flux.class, Person.class);
|
||||
|
|
@ -154,6 +173,15 @@ public class RequestPartMethodArgumentResolverTests {
|
|||
assertThat(persons.get(1).getName()).isEqualTo("James");
|
||||
}
|
||||
|
||||
@Test // gh-23060
|
||||
public void fluxPersonNotRequired() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart().notRequired()).arg(Flux.class, Person.class);
|
||||
MultipartBodyBuilder bodyBuilder = new MultipartBodyBuilder();
|
||||
Flux<Person> actual = resolveArgument(param, bodyBuilder);
|
||||
|
||||
assertThat(actual.collectList().block()).isEmpty();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void part() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart()).arg(Part.class);
|
||||
|
|
@ -177,6 +205,15 @@ public class RequestPartMethodArgumentResolverTests {
|
|||
assertThat(partToUtf8String(actual.get(1))).isEqualTo("{\"name\":\"James\"}");
|
||||
}
|
||||
|
||||
@Test // gh-23060
|
||||
public void listPartNotRequired() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart().notRequired()).arg(List.class, Part.class);
|
||||
MultipartBodyBuilder bodyBuilder = new MultipartBodyBuilder();
|
||||
List<Part> actual = resolveArgument(param, bodyBuilder);
|
||||
|
||||
assertThat(actual).isEmpty();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void monoPart() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart()).arg(Mono.class, Part.class);
|
||||
|
|
@ -188,6 +225,15 @@ public class RequestPartMethodArgumentResolverTests {
|
|||
assertThat(partToUtf8String(part)).isEqualTo("{\"name\":\"Jones\"}");
|
||||
}
|
||||
|
||||
@Test // gh-23060
|
||||
public void monoPartNotRequired() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart().notRequired()).arg(Mono.class, Part.class);
|
||||
MultipartBodyBuilder bodyBuilder = new MultipartBodyBuilder();
|
||||
Mono<Part> actual = resolveArgument(param, bodyBuilder);
|
||||
|
||||
assertThat(actual.block()).isNull();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void fluxPart() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart()).arg(Flux.class, Part.class);
|
||||
|
|
@ -201,6 +247,15 @@ public class RequestPartMethodArgumentResolverTests {
|
|||
assertThat(partToUtf8String(parts.get(1))).isEqualTo("{\"name\":\"James\"}");
|
||||
}
|
||||
|
||||
@Test // gh-23060
|
||||
public void fluxPartNotRequired() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart().notRequired()).arg(Flux.class, Part.class);
|
||||
MultipartBodyBuilder bodyBuilder = new MultipartBodyBuilder();
|
||||
Flux<Part> actual = resolveArgument(param, bodyBuilder);
|
||||
|
||||
assertThat(actual.collectList().block()).isEmpty();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void personRequired() {
|
||||
MethodParameter param = this.testMethod.annot(requestPart()).arg(Person.class);
|
||||
|
|
@ -278,7 +333,13 @@ public class RequestPartMethodArgumentResolverTests {
|
|||
@RequestPart("name") Flux<Part> partFlux,
|
||||
@RequestPart("name") List<Part> partList,
|
||||
@RequestPart(name = "anotherPart", required = false) Person anotherPerson,
|
||||
@RequestPart(name = "name", required = false) Mono<Person> anotherPersonMono,
|
||||
@RequestPart(name = "name", required = false) Flux<Person> anotherPersonFlux,
|
||||
@RequestPart(name = "name", required = false) List<Person> anotherPersonList,
|
||||
@RequestPart(name = "anotherPart", required = false) Part anotherPart,
|
||||
@RequestPart(name = "name", required = false) Mono<Part> anotherPartMono,
|
||||
@RequestPart(name = "name", required = false) Flux<Part> anotherPartFlux,
|
||||
@RequestPart(name = "name", required = false) List<Part> anotherPartList,
|
||||
Person notAnnotated) {}
|
||||
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue