使用Mock 對spring mvc 的controller層進行單元測試

整體目標:達到自動化測試接口的目的 java

項目組成:spring mvc + hibernate + mysql mysql

如何使用mock進行接口的單元測試? web

實現思路:將mysql替換成h2數據庫,以前hibernate 的datesource配置的是mysql,如今配置成h2,這樣測試的數據庫是乾淨的,由於在內存中。每次進行junit mock測試以前清空一下內存中的數據庫便可 spring

實現代碼: sql

package cn.edu.hebtu.www.onemeet.client.controller;


import cn.edu.hebtu.www.onemeet.client.model.Company;
import cn.edu.hebtu.www.onemeet.client.model.Department;
import cn.edu.hebtu.www.onemeet.client.model.Me;
import cn.edu.hebtu.www.onemeet.common.model.Reply;
import cn.edu.hebtu.www.onemeet.common.web.filter.EncodeFilter;
import cn.edu.hebtu.www.onemeet.utils.TestUtils;
import org.apache.log4j.Logger;
import org.junit.Before;
import org.junit.FixMethodOrder;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.MethodSorters;
import org.springframework.beans.factory.annotation.Autowired;


import org.springframework.core.io.Resource;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.orm.hibernate4.support.OpenSessionInViewFilter;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;
import org.springframework.test.jdbc.JdbcTestUtils;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.MvcResult;
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
import org.springframework.web.context.WebApplicationContext;


import static org.junit.Assert.assertEquals;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print;


import javax.sql.DataSource;
import java.util.List;




/**
 * mock測試,使用mock測試來保證接口的正確性
 * Created by chenzhibing on 15-10-30.
 */
@FixMethodOrder(MethodSorters.NAME_ASCENDING)
@RunWith(SpringJUnit4ClassRunner.class)
@WebAppConfiguration(value = "src/main/webapp")
@ContextConfiguration(locations = {"classpath:spring.xml", "classpath:spring-hibernate-h2.xml"})
public class MockTest {
    private static Logger logger = Logger.getLogger(MockTest.class);
    @Autowired
    private WebApplicationContext wac;
    private MockMvc mockMvc;
    private JdbcTemplate template;
    @Autowired
    private EncodeFilter encodeFilter;
    @Autowired
    private OpenSessionInViewFilter openSessionInViewFilter;




    @Autowired
    public void setDataSource(DataSource dataSource) {
        template = new JdbcTemplate(dataSource);
    }


    @Before
    public void setUp() {
        mockMvc = MockMvcBuilders.webAppContextSetup(wac).addFilters(this.encodeFilter, this.openSessionInViewFilter).build();
    }


    @Before
    public void cleanData() {
        String script = "classpath:H2_Init.sql";
        Resource resource = wac.getResource(script);
        JdbcTestUtils.executeSqlScript(template, resource, true);
    }




    @Test
    public void hello() throws Exception {
        MvcResult result = mockMvc.perform(MockMvcRequestBuilders.post("/user/hello"))
                .andDo(print())
                .andReturn();
        String response = result.getResponse().getContentAsString();
        Reply reply = TestUtils.getStringReply(response);
        assertEquals(reply.getCode(), 1);
    }


    @Test
    public void getCompanylist() throws Exception {
        MvcResult result = mockMvc.perform(MockMvcRequestBuilders.post("/user/get_companylist"))
                .andDo(print())
                .andReturn();
        String response = result.getResponse().getContentAsString();
        Reply<List<Company>> reply = TestUtils.getCompanyListReply(response);
        assertEquals(reply.getCode(), 1);
        assertEquals(reply.getMsg().size(), 3);
        // assertEquals(reply.getMsg().get(0).getDepartList().size(), 4);
    }
  } 數據庫

} apache

相關文章
相關標籤/搜索