コントローラーが非同期サーブレットの性質を持つ場合、MockMvc で 500 内部サーバー エラーを検証/テストするにはどうすればよいですか?
サーバーが 500 内部エラーを http コードとして適切なエラー メッセージと共に送信することを検証する必要があるテスト ケースの一部として、REST エンドポイントの単体テスト ケースを作成しています。
これが私のスプリングブートベースのアプリです:(読みやすくするためにすべてのインポートは省略されています)
@RestController
@RequestMapping("/user")
@EnableAutoConfiguration
@SpringBootApplication
public class App
{
@RequestMapping(method = RequestMethod.GET, value = "/{name}",
produces = MediaType.APPLICATION_JSON_VALUE)
private DeferredResult<String> greetByJson(@PathVariable("name") final String name){
DeferredResult<String> dResult = new DeferredResult<String>();
new Thread(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(5000);
dResult.setErrorResult(new RuntimeException("Boom!!! time for Internal server error"));
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
return dResult;
}
public static void main( String[] args )
{
SpringApplication.run(App.class);
}
}
これが私の MovkMvc JUnit テスト ケースです。
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = MockServletContext.class)
@WebAppConfiguration
public class AppTest {
private final MockMvc mockMvc = MockMvcBuilders.standaloneSetup(new App())
.build();
@Test
public void testAsyncInternalServerError() {
try {
MvcResult mvcResult = mockMvc.perform(
get("/user/naveen").accept(MediaType.APPLICATION_JSON_VALUE))
.andExpect(request().asyncStarted())
.andReturn();
System.out.println("Http Response Content = " + mvcResult.getAsyncResult());
System.out.println("Http Response Status Code = " + mvcResult.getResponse().getStatus());
} catch (Exception e) {
e.printStackTrace();
}
}
}
以下はコンソールの出力です。
2015-08-08 18:11:51.494 INFO 10224 --- [ main] o.s.w.c.s.GenericWebApplicationContext : Refreshing org.springframework.web.context.support.GenericWebApplicationContext@a82c5f1: startup date [Sat Aug 08 18:11:51 IST 2015]; root of context hierarchy
2015-08-08 18:11:51.526 INFO 10224 --- [ main] o.e.j.i.junit.runner.RemoteTestRunner : Started RemoteTestRunner in 0.258 seconds (JVM running for 1.131)
Http Response Content = java.lang.RuntimeException: Boom!!! time for Internal server error
Http Response Status Code = 200
2015-08-08 18:11:56.584 INFO 10224 --- [ Thread-1] o.s.w.c.s.GenericWebApplicationContext : Closing org.springframework.web.context.support.GenericWebApplicationContext@a82c5f1: startup date [Sat Aug 08 18:11:51 IST 2015]; root of context hierarchy
上記のログから、MockMvc が http ステータス コードを 500 ではなく 200 として返していることが明らかです。エラー メッセージは問題ありません。
Chrome postman を使用してエンドポイントを呼び出すと、画像に添付されているように 500 内部サーバー エラーが表示されます