Merge pull request #1106 from darklynx/streaming_response_test
This commit is contained in:
commit
e91c1cd5a7
|
@ -17,6 +17,8 @@
|
||||||
package org.springframework.test.web.servlet.samples.standalone;
|
package org.springframework.test.web.servlet.samples.standalone;
|
||||||
|
|
||||||
import java.io.StringWriter;
|
import java.io.StringWriter;
|
||||||
|
import java.nio.charset.Charset;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.concurrent.Callable;
|
import java.util.concurrent.Callable;
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
@ -26,6 +28,7 @@ import org.junit.Test;
|
||||||
|
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.http.MediaType;
|
import org.springframework.http.MediaType;
|
||||||
|
import org.springframework.http.ResponseEntity;
|
||||||
import org.springframework.test.web.Person;
|
import org.springframework.test.web.Person;
|
||||||
import org.springframework.test.web.servlet.MockMvc;
|
import org.springframework.test.web.servlet.MockMvc;
|
||||||
import org.springframework.test.web.servlet.MvcResult;
|
import org.springframework.test.web.servlet.MvcResult;
|
||||||
|
@ -36,7 +39,9 @@ import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
import org.springframework.web.bind.annotation.ResponseStatus;
|
import org.springframework.web.bind.annotation.ResponseStatus;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
import org.springframework.web.context.request.async.DeferredResult;
|
import org.springframework.web.context.request.async.DeferredResult;
|
||||||
|
import org.springframework.web.servlet.mvc.method.annotation.StreamingResponseBody;
|
||||||
|
|
||||||
|
import static java.nio.charset.StandardCharsets.UTF_8;
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*;
|
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*;
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.*;
|
import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.*;
|
||||||
|
@ -71,6 +76,34 @@ public class AsyncTests {
|
||||||
.andExpect(content().string("{\"name\":\"Joe\",\"someDouble\":0.0,\"someBoolean\":false}"));
|
.andExpect(content().string("{\"name\":\"Joe\",\"someDouble\":0.0,\"someBoolean\":false}"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void streaming() throws Exception {
|
||||||
|
this.mockMvc.perform(get("/1").param("streaming", "true"))
|
||||||
|
.andExpect(request().asyncStarted())
|
||||||
|
.andDo(MvcResult::getAsyncResult) // fetch async result similar to "asyncDispatch" builder
|
||||||
|
.andExpect(status().isOk())
|
||||||
|
.andExpect(content().string("name=Joe"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void streamingSlow() throws Exception {
|
||||||
|
this.mockMvc.perform(get("/1").param("streamingSlow", "true"))
|
||||||
|
.andExpect(request().asyncStarted())
|
||||||
|
.andDo(MvcResult::getAsyncResult)
|
||||||
|
.andExpect(status().isOk())
|
||||||
|
.andExpect(content().string("name=Joe&someBoolean=true"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void streamingJson() throws Exception {
|
||||||
|
this.mockMvc.perform(get("/1").param("streamingJson", "true"))
|
||||||
|
.andExpect(request().asyncStarted())
|
||||||
|
.andDo(MvcResult::getAsyncResult)
|
||||||
|
.andExpect(status().isOk())
|
||||||
|
.andExpect(content().contentType(MediaType.APPLICATION_JSON_UTF8_VALUE))
|
||||||
|
.andExpect(content().string("{\"name\":\"Joe\",\"someDouble\":0.5}"));
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void deferredResult() throws Exception {
|
public void deferredResult() throws Exception {
|
||||||
MvcResult mvcResult = this.mockMvc.perform(get("/1").param("deferredResult", "true"))
|
MvcResult mvcResult = this.mockMvc.perform(get("/1").param("deferredResult", "true"))
|
||||||
|
@ -98,10 +131,7 @@ public class AsyncTests {
|
||||||
.andExpect(content().string("{\"name\":\"Joe\",\"someDouble\":0.0,\"someBoolean\":false}"));
|
.andExpect(content().string("{\"name\":\"Joe\",\"someDouble\":0.0,\"someBoolean\":false}"));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
@Test // SPR-13079
|
||||||
* SPR-13079
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
public void deferredResultWithDelayedError() throws Exception {
|
public void deferredResultWithDelayedError() throws Exception {
|
||||||
MvcResult mvcResult = this.mockMvc.perform(get("/1").param("deferredResultWithDelayedError", "true"))
|
MvcResult mvcResult = this.mockMvc.perform(get("/1").param("deferredResultWithDelayedError", "true"))
|
||||||
.andExpect(request().asyncStarted())
|
.andExpect(request().asyncStarted())
|
||||||
|
@ -170,6 +200,7 @@ public class AsyncTests {
|
||||||
|
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping(path = "/{id}", produces = "application/json")
|
@RequestMapping(path = "/{id}", produces = "application/json")
|
||||||
|
@SuppressWarnings("unused")
|
||||||
private static class AsyncController {
|
private static class AsyncController {
|
||||||
|
|
||||||
private final Collection<DeferredResult<Person>> deferredResults =
|
private final Collection<DeferredResult<Person>> deferredResults =
|
||||||
|
@ -184,6 +215,31 @@ public class AsyncTests {
|
||||||
return () -> new Person("Joe");
|
return () -> new Person("Joe");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@RequestMapping(params = "streaming")
|
||||||
|
public StreamingResponseBody getStreaming() {
|
||||||
|
return os -> os.write("name=Joe".getBytes(UTF_8));
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping(params = "streamingSlow")
|
||||||
|
public StreamingResponseBody getStreamingSlow() {
|
||||||
|
return os -> {
|
||||||
|
os.write("name=Joe".getBytes());
|
||||||
|
try {
|
||||||
|
Thread.sleep(200);
|
||||||
|
os.write("&someBoolean=true".getBytes(UTF_8));
|
||||||
|
}
|
||||||
|
catch (InterruptedException e) {
|
||||||
|
/* no-op */
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping(params = "streamingJson")
|
||||||
|
public ResponseEntity<StreamingResponseBody> getStreamingJson() {
|
||||||
|
return ResponseEntity.ok().contentType(MediaType.APPLICATION_JSON_UTF8)
|
||||||
|
.body(os -> os.write("{\"name\":\"Joe\",\"someDouble\":0.5}".getBytes(UTF_8)));
|
||||||
|
}
|
||||||
|
|
||||||
@RequestMapping(params = "deferredResult")
|
@RequestMapping(params = "deferredResult")
|
||||||
public DeferredResult<Person> getDeferredResult() {
|
public DeferredResult<Person> getDeferredResult() {
|
||||||
DeferredResult<Person> deferredResult = new DeferredResult<>();
|
DeferredResult<Person> deferredResult = new DeferredResult<>();
|
||||||
|
@ -235,7 +291,7 @@ public class AsyncTests {
|
||||||
return e.getMessage();
|
return e.getMessage();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onMessage(String name) {
|
void onMessage(String name) {
|
||||||
for (DeferredResult<Person> deferredResult : this.deferredResults) {
|
for (DeferredResult<Person> deferredResult : this.deferredResults) {
|
||||||
deferredResult.setResult(new Person(name));
|
deferredResult.setResult(new Person(name));
|
||||||
this.deferredResults.remove(deferredResult);
|
this.deferredResults.remove(deferredResult);
|
||||||
|
|
Loading…
Reference in New Issue