Merge branch '6.2.x'
This commit is contained in:
commit
b89c48e714
|
@ -19,6 +19,7 @@ package org.springframework.http.converter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import java.lang.reflect.Type;
|
import java.lang.reflect.Type;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import kotlin.reflect.KFunction;
|
import kotlin.reflect.KFunction;
|
||||||
|
@ -76,6 +77,11 @@ public abstract class AbstractKotlinSerializationHttpMessageConverter<T extends
|
||||||
this.format = format;
|
this.format = format;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<MediaType> getSupportedMediaTypes(Class<?> clazz) {
|
||||||
|
return getSupportedMediaTypes();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean supports(Class<?> clazz) {
|
protected boolean supports(Class<?> clazz) {
|
||||||
return serializer(ResolvableType.forClass(clazz)) != null;
|
return serializer(ResolvableType.forClass(clazz)) != null;
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
description = "Spring Web MVC"
|
description = "Spring Web MVC"
|
||||||
|
|
||||||
apply plugin: "kotlin"
|
apply plugin: "kotlin"
|
||||||
|
apply plugin: "kotlinx-serialization"
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
api(project(":spring-aop"))
|
api(project(":spring-aop"))
|
||||||
|
|
|
@ -0,0 +1,133 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2025 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.web.servlet.mvc.method.annotation
|
||||||
|
|
||||||
|
import kotlinx.serialization.Serializable
|
||||||
|
import org.assertj.core.api.Assertions
|
||||||
|
import org.junit.jupiter.api.Test
|
||||||
|
import org.springframework.http.converter.StringHttpMessageConverter
|
||||||
|
import org.springframework.http.converter.json.KotlinSerializationJsonHttpMessageConverter
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping
|
||||||
|
import org.springframework.web.bind.annotation.ResponseBody
|
||||||
|
import org.springframework.web.context.request.NativeWebRequest
|
||||||
|
import org.springframework.web.context.request.ServletWebRequest
|
||||||
|
import org.springframework.web.method.HandlerMethod
|
||||||
|
import org.springframework.web.method.support.ModelAndViewContainer
|
||||||
|
import org.springframework.web.testfixture.servlet.MockHttpServletRequest
|
||||||
|
import org.springframework.web.testfixture.servlet.MockHttpServletResponse
|
||||||
|
import kotlin.reflect.jvm.javaMethod
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Kotlin tests for [RequestResponseBodyMethodProcessor].
|
||||||
|
*/
|
||||||
|
class RequestResponseBodyMethodProcessorKotlinTests {
|
||||||
|
|
||||||
|
private val container = ModelAndViewContainer()
|
||||||
|
|
||||||
|
private val servletRequest = MockHttpServletRequest()
|
||||||
|
|
||||||
|
private val servletResponse = MockHttpServletResponse()
|
||||||
|
|
||||||
|
private val request: NativeWebRequest = ServletWebRequest(servletRequest, servletResponse)
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun writeWithKotlinSerializationJsonMessageConverter() {
|
||||||
|
val method = SampleController::writeMessage::javaMethod.get()!!
|
||||||
|
val handlerMethod = HandlerMethod(SampleController(), method)
|
||||||
|
val methodReturnType = handlerMethod.returnType
|
||||||
|
|
||||||
|
val converters = listOf(KotlinSerializationJsonHttpMessageConverter())
|
||||||
|
val processor = RequestResponseBodyMethodProcessor(converters, null, null)
|
||||||
|
|
||||||
|
val returnValue: Any = SampleController().writeMessage()
|
||||||
|
processor.handleReturnValue(returnValue, methodReturnType, this.container, this.request)
|
||||||
|
|
||||||
|
Assertions.assertThat(this.servletResponse.contentAsString)
|
||||||
|
.contains("\"value\":\"foo\"")
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun writeGenericTypeWithKotlinSerializationJsonMessageConverter() {
|
||||||
|
val method = SampleController::writeMessages::javaMethod.get()!!
|
||||||
|
val handlerMethod = HandlerMethod(SampleController(), method)
|
||||||
|
val methodReturnType = handlerMethod.returnType
|
||||||
|
|
||||||
|
val converters = listOf(KotlinSerializationJsonHttpMessageConverter())
|
||||||
|
val processor = RequestResponseBodyMethodProcessor(converters, null, null)
|
||||||
|
|
||||||
|
val returnValue: Any = SampleController().writeMessages()
|
||||||
|
processor.handleReturnValue(returnValue, methodReturnType, this.container, this.request)
|
||||||
|
|
||||||
|
Assertions.assertThat(this.servletResponse.contentAsString)
|
||||||
|
.contains("\"value\":\"foo\"")
|
||||||
|
.contains("\"value\":\"bar\"")
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun readWithKotlinSerializationJsonMessageConverter() {
|
||||||
|
val method = SampleController::readMessage::javaMethod.get()!!
|
||||||
|
val handlerMethod = HandlerMethod(SampleController(), method)
|
||||||
|
val methodReturnType = handlerMethod.returnType
|
||||||
|
|
||||||
|
val converters = listOf(StringHttpMessageConverter(), KotlinSerializationJsonHttpMessageConverter())
|
||||||
|
val processor = RequestResponseBodyMethodProcessor(converters, null, null)
|
||||||
|
|
||||||
|
val returnValue: Any = SampleController().readMessage(Message("foo"))
|
||||||
|
processor.handleReturnValue(returnValue, methodReturnType, this.container, this.request)
|
||||||
|
|
||||||
|
Assertions.assertThat(this.servletResponse.contentAsString).isEqualTo("foo")
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun readGenericTypeWithKotlinSerializationJsonMessageConverter() {
|
||||||
|
val method = SampleController::readMessages::javaMethod.get()!!
|
||||||
|
val handlerMethod = HandlerMethod(SampleController(), method)
|
||||||
|
val methodReturnType = handlerMethod.returnType
|
||||||
|
|
||||||
|
val converters = listOf(StringHttpMessageConverter(), KotlinSerializationJsonHttpMessageConverter())
|
||||||
|
val processor = RequestResponseBodyMethodProcessor(converters, null, null)
|
||||||
|
|
||||||
|
val returnValue: Any = SampleController().readMessages(listOf(Message("foo"), Message("bar")))
|
||||||
|
processor.handleReturnValue(returnValue, methodReturnType, this.container, this.request)
|
||||||
|
|
||||||
|
Assertions.assertThat(this.servletResponse.contentAsString)
|
||||||
|
.isEqualTo("foo bar")
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private class SampleController {
|
||||||
|
|
||||||
|
@RequestMapping
|
||||||
|
@ResponseBody
|
||||||
|
fun writeMessage() = Message("foo")
|
||||||
|
|
||||||
|
@RequestMapping
|
||||||
|
@ResponseBody
|
||||||
|
fun writeMessages() = listOf(Message("foo"), Message("bar"))
|
||||||
|
|
||||||
|
@RequestMapping
|
||||||
|
@ResponseBody
|
||||||
|
fun readMessage(message: Message) = message.value
|
||||||
|
|
||||||
|
@RequestMapping
|
||||||
|
@ResponseBody fun readMessages(messages: List<Message>) = messages.map { it.value }.reduce { acc, string -> "$acc $string" }
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Serializable
|
||||||
|
data class Message(val value: String)
|
||||||
|
}
|
Loading…
Reference in New Issue