简介
Spring-test技术结合junit,可以说测试项目非常迅速。
我们传统的技术是写好代码,放在本地的tomcat服务器或者是其他服务器中运行,然后拿浏览器访问。这里面就一个问题,烦。具体将来有两个缺点。
一 流程复杂,效率低下
二 不能保存测试数据,进行反复测试
为此,spring-test结合junit提供了mock对象,完美地解决了上诉两个问题。
核心类
SpringJUnit4ClassRunner
这个类是spring的单元测试执行类,使用junit的@RunWith注解可以改变默认的单元测试执行类。
@WebAppConfiguration
这个注解是spring webmvc测试必要的一个注解。这个注解就是使得spring单元测试的ApplicationContext的实现为WebApplicationContext类型。WebApplicationContext作为ApplicationContext的其中一个实现,它的独特性在于包含了ServletContext对象。
@ContextConfiguration
这个注解是配置spring的配置文件地址或者spring的配置类的类名。有了这个注解SpringJUnit4ClassRunner才能读取spring配置,从而构建spring的ApplicationContext实例,也就是初始化spring容器。
MockMvc
只有在进行web项目的单元测试才需要这个类。这个类的作用就是判断,它接收一个URL和一个你预测的结果,然后MockMvc去请求虚拟web服务器,并将虚拟服务器返回的结果与预测结果进行对比,以达到测试的目的。
代码案例
package springtest;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
import org.springframework.test.web.servlet.result.MockMvcResultMatchers;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
@RunWith(SpringJUnit4ClassRunner.class)
@WebAppConfiguration
@ContextConfiguration(classes = { MyInitializer.class, WebConfig.class })
public class TestController {
private MockMvc mockMvc;
@Autowired
private IndexController indexController;
@Before
public void setup() {
mockMvc = MockMvcBuilders.standaloneSetup(indexController).build();
}
@Test
public void test() throws Exception {
mockMvc.perform(MockMvcRequestBuilders.post("/"))
.andExpect(MockMvcResultMatchers.content().string("Hello, 1orld!"));
}
}
测试结果
java.lang.AssertionError: Response content expected:<Hello, 1orld!> but was:<Hello, world!>