2016-12-15 69 views
0

我想測試此控制器: java.lang.AssertionError:沒有使用的ModelAndView發現webAppContextSetup

@Controller 
@RequestMapping(value = "/bookmanagement") 
public class BookManagementController { 

    @RequestMapping(value = "") 
    public String bookManagement(HttpSession session, HttpServletRequest request, Model model, Authentication auth) { 

     // does stuff 
     return "bookManagement"; 
    } 

    @RequestMapping(value = "edit") 
    public String edit(HttpSession session, HttpServletRequest request, Model model, Authentication auth, 
      @RequestParam(value = "id", required = true) String id) { 

     // does stuff 

     return "editBook"; 
    } 

    @RequestMapping(value = "fileUpload", method = RequestMethod.POST) 
    public String fileUpload(@RequestParam("coverFile") MultipartFile file, 
      @RequestParam(value = "type", required = true) String type, 
      @RequestParam(value = "id", required = true) String id, 
      @RequestParam(value = "pages", required = true) String pages, HttpServletResponse response, Model model) 
      throws JSONException { 

     // writes file 

     return "editBook_File"; 

    } 


} 

請注意RequestMapping。所以這是我的JUnit測試:

@RunWith(SpringJUnit4ClassRunner.class) 
@WebAppConfiguration("file:application/webapp") 
@ContextConfiguration("file:application/webapp/WEB-INF/dispatcher-servlet.xml") 
public class BookManagementControllerTest { 

    private MockMvc mockMvc; 

    @Autowired 
    private UsersRepository usersCollection; 

    @Resource 
    private FilterChainProxy springSecurityFilterChain; 

    @Resource 
    private WebApplicationContext webApplicationContext; 

    private MockHttpSession session; 

    @InjectMocks 
    private BookManagementController bookManagementController; 

    @Before 
    public void setup() { 

     MockitoAnnotations.initMocks(this); 

     this.mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext) 
       .addFilter(springSecurityFilterChain) 
       .build(); 

     this.session = getSessionWithAuthentication(); 

    } 

    @Test 
    public void editTestView() throws Exception { 

     this.mockMvc.perform(get("/bookmanagement/edit?id=58385d39bd7f3513c83faa65").session(session)) 
       .andExpect(view().name("editBook")).andExpect(status().isOk()).andReturn(); 

    } 

    @Test 
    public void uploadCoverFile() throws Exception { 

     MockMultipartFile jsonFile = new MockMultipartFile("json", "", "application/json", 
       "{\"json\": \"someValue\"}".getBytes()); 

     mockMvc.perform(MockMvcRequestBuilders.fileUpload("/bookmanagement/fileUpload").file(jsonFile)) 
       .andExpect(view().name("editBook_File")).andExpect(status().isOk()).andReturn(); 

    } 

    private MockHttpSession getSessionWithAuthentication() { 
     Users testPodUser = usersCollection.findByEmail("[email protected]"); 
     SecUserDetails principal = new SecUserDetails(testPodUser); 
     SecurityContext secContext = SecurityContextHolder.getContext(); 
     secContext.setAuthentication(new UsernamePasswordAuthenticationToken(principal, principal.getPassword(), 
       principal.getAuthorities())); 

     MockHttpSession session = new MockHttpSession(); 
     session.setAttribute(HttpSessionSecurityContextRepository.SPRING_SECURITY_CONTEXT_KEY, secContext); 

     return session; 
    } 

} 

調度員-servlet.xml中包含在其中控制器在封裝組件掃描當我手動測試控制器,一切工作正常。

所以第一個測試(editTestView())返回綠色。但第二個失敗,此錯誤:

java.lang.AssertionError: No ModelAndView found 
    at org.springframework.test.util.AssertionErrors.fail(AssertionErrors.java:39) 
    at org.springframework.test.util.AssertionErrors.assertTrue(AssertionErrors.java:72) 
    at org.springframework.test.web.servlet.result.ViewResultMatchers$2.match(ViewResultMatchers.java:68) 
    at org.springframework.test.web.servlet.MockMvc$1.andExpect(MockMvc.java:171) 
    at de.mypackage.prod.controller.BookManagementControllerTest.uploadCoverFile(BookManagementControllerTest.java:85) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) 
    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:75) 
    at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86) 
    at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84) 
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:254) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:89) 
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) 
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) 
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) 
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) 
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) 
    at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61) 
    at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363) 
    at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:193) 
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86) 
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382) 
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192) 

我不明白,爲什麼get("/bookmanagement/edit?id=58385d39bd7f3513c83faa65")呼叫另一方面不會正常工作,但fileUpload("/bookmanagement/fileUpload")

我在這裏錯過了什麼?

回答

1

它失敗的原因,

預期的文件名是coverFile

@RequestMapping(value = "fileUpload", method = RequestMethod.POST) 
    public String fileUpload(@RequestParam("coverFile") MultipartFile file, 
      @RequestParam(value = "type", required = true) String type, 
      @RequestParam(value = "id", required = true) String id, 
      @RequestParam(value = "pages", required = true) String pages, HttpServletResponse response, Model model) 
      throws JSONException { 

但是你逝去的名稱爲json

MockMultipartFile jsonFile = new MockMultipartFile("json", "", "application/json", 
       "{\"json\": \"someValue\"}".getBytes()); 

你需要修復的,

MockMultipartFile jsonFile = new MockMultipartFile("coverFile", "", "application/json", 
        "{\"json\": \"someValue\"}".getBytes()); 

另請檢查處理程序方法的其他必需參數。

+0

感謝您的答案,但我不認爲這是問題所在。在[本文](http://stackoverflow.com/a/21805186/3986952)中顯示'MockMvcRequestBuilders.fileUpload'也適用於'POST'方法。 – Erando

+0

@Erando嘗試我更新的答案。我懷疑它是你的文件名和其他請求中缺少的參數。這就是爲什麼你的觀點與請求不符。 – ScanQR

+0

就是這樣!該死!這樣一個愚蠢的錯誤......花了太多時間在這個我應該有的。但是,非常感謝你!我幾乎確定這個問題是一些RequestMapping問題......但是這個。謝謝! – Erando