2014-01-07 2 views
5

스프링 테스트로 스프링 MVC 웹 애플리케이션을 테스트하려고한다. 그것은 라우팅을 위해 springmvc-router을 사용하며, 이는 내 routes.conf 파일 대신 @RequestMapping을 사용할 때 제대로 작동하는 테스트를 깨는 것으로 보입니다.MockMVC로 스프링 MVC 라우터 테스트하기

나는 valid.jsp이라고하는 .jsp 파일을 가지고 있으며, Jetty에서 개발 사이트를 실행할 때 정상적으로 표시됩니다. 컨트롤러는 다음과 같습니다

@Controller 
@EnableWebMvc 
public class AuthController { 
    public String valid() { 
    return "valid"; 
    } 
} 

routes.conf 파일 GET /valid authController.valid 매핑합니다.

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.NullPointerException 
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:943) 
    at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:822) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:668) 
    at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:807) 
    at org.springframework.test.web.servlet.TestDispatcherServlet.service(TestDispatcherServlet.java:64) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:770) 
    at org.springframework.mock.web.MockFilterChain$ServletFilterProxy.doFilter(MockFilterChain.java:170) 
    at org.springframework.mock.web.MockFilterChain.doFilter(MockFilterChain.java:137) 
    at org.springframework.test.web.servlet.MockMvc.perform(MockMvc.java:141) 
    at com.mypackage.AuthControllerTest.testValid(AuthControllerTest.java:45) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44) 
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) 
    at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:74) 
    at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:83) 
    at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:232) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:89) 
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238) 
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63) 
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236) 
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53) 
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229) 
    at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61) 
    at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:309) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:175) 
    at org.junit.runner.JUnitCore.run(JUnitCore.java:160) 
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:77) 
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:195) 
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:63) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120) 
Caused by: java.lang.NullPointerException 
    at org.resthub.web.springmvc.router.HTTPRequestAdapter.parseRequest(HTTPRequestAdapter.java:196) 
    at org.resthub.web.springmvc.router.RouterHandlerMapping.getHandlerInternal(RouterHandlerMapping.java:166) 
    at org.springframework.web.servlet.handler.AbstractHandlerMapping.getHandler(AbstractHandlerMapping.java:300) 
    at org.springframework.web.servlet.DispatcherServlet.getHandler(DispatcherServlet.java:1101) 
    at org.springframework.test.web.servlet.TestDispatcherServlet.getHandler(TestDispatcherServlet.java:104) 
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:916) 
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:876) 
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:931) 
    ... 41 more 

그래서 질문은 : 다음 mockMvc.perform()가 실행되면

@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration(locations = {"/test-context.xml", 
    "/spring/spring-security.xml", 
    "file:src/main/webapp/WEB-INF/mvc-config.xml"}) 
@WebAppConfiguration 
@Import(RouteConfig.class) 
public class AuthControllerTest { 
    private MockMvc mockMvc; 

    @Autowired 
    private WebApplicationContext webApplicationContext; 

    @Autowired 
    private AuthenticationManager authenticationManager; 

    @Before 
    public void init() { 
    MockitoAnnotations.initMocks(this); 
    mockMvc = 
     MockMvcBuilders.webAppContextSetup(webApplicationContext).dispatchOptions(true).build(); 
    } 

    @Test 
    public void testValid() throws Exception { 
    mockMvc.perform(get("/validation-success")) 
     .andDo(print()) 
     .andExpect(status().isOk()); 
    } 

처럼

지금, 내 테스터는 NullPointerException가 슬로우 보인다는 springmvc와 함께 봄의 테스트 프레임 워크를 사용할 수있다 -라우터?

답변

12

파기를 한 후 HTTPRequestAdapter.parseRequest() 메서드에 MockMVC가 요청하는 방식에 문제가 있음을 발견했습니다. 특히 MockMVC가 보낸 요청에는 요청에 host이라는 헤더가 포함되지 않습니다.

HTTPRequestAdapter은 헤더가 필요하며 null 일 수 있다는 사실을 고려하지 않으므로 NullPointerException을 생성합니다.

mockMvc.perform(get("/validation-success") 
     .header("host", "localhost:80")) 
     .andExpect(status().isOk()); 

host 헤더가 null되지 않습니다 및 테스트를 통과해야합니다

는이 코드의 문제를 해결했습니다.

관련 문제