Skip to content

Commit

Permalink
Merge pull request liyifeng1994#25 from meiwen1111/master
Browse files Browse the repository at this point in the history
add test for BookController
  • Loading branch information
liyifeng1994 authored Mar 11, 2018
2 parents 660a9b1 + 0925054 commit 4a8433c
Show file tree
Hide file tree
Showing 2 changed files with 79 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package com.soecode.lyf.web;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.web.WebAppConfiguration;
import org.springframework.web.context.WebApplicationContext;

@WebAppConfiguration
@ContextConfiguration({ "classpath:spring/spring-web.xml", "classpath:spring/spring-service.xml",
"classpath:spring/spring-dao.xml" })
public class AbstractContextControllerTests {

@Autowired
protected WebApplicationContext wac;
}
64 changes: 64 additions & 0 deletions src/test/java/com/soecode/lyf/web/BookControllerTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
package com.soecode.lyf.web;

import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.forwardedUrl;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.model;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.view;
import static org.springframework.test.web.servlet.setup.MockMvcBuilders.webAppContextSetup;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.http.MediaType;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.transaction.TransactionConfiguration;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.transaction.annotation.Transactional;

/**
*
* @author Kemin
*/
@RunWith(SpringJUnit4ClassRunner.class)
// 配置事务的回滚,对数据库的增删改都会回滚,便于测试用例的循环利用
@TransactionConfiguration(transactionManager = "transactionManager", defaultRollback = true)
@Transactional
public class BookControllerTest extends AbstractContextControllerTests {

private MockMvc mockMvc;
private String listUrl = "/book/list";
private String detailUrl = "/book/{bookId}/detail";
private String appointUrl = "/book/{bookId}/appoint";
private long bookId = 1000;

@Before
public void setup() {
this.mockMvc = webAppContextSetup(this.wac).alwaysExpect(status().isOk()).alwaysDo(print()).build();
}

@Test
public void list() throws Exception {
this.mockMvc.perform(get(listUrl)).andExpect(view().name("list"));
}

@Test
public void existDetail() throws Exception {
this.mockMvc.perform(get(detailUrl, bookId)).andExpect(view().name("detail"))
.andExpect(model().attributeExists("book"));
}

@Test
public void notExistDetail() throws Exception {
this.mockMvc.perform(get(detailUrl, 1100)).andExpect(forwardedUrl("/book/list"));
}

@Test
public void appointTest() throws Exception {
this.mockMvc.perform(post(appointUrl, bookId).param("studentId", "1").accept(MediaType.APPLICATION_JSON))
.andExpect(content().contentType("application/json;charset=utf-8"));
}
}

0 comments on commit 4a8433c

Please sign in to comment.