JUnit单元测试学习笔记
1 junit简介
1.1 软件测试简介
测试:是软件开发中一个非常重要的过程
目标:检测软件的bug
测试:黑盒测试、白盒测试
黑盒测试:功能测试 功能测试,给输入值,看程序是否能够输出期望的值
白盒测试:单元测试 —由程序员自己来完成 junit 关注程序具体的执行流程
压力测试: jmeter
覆盖率测试:
性能测试: postman
单元测试工具—postman,junit
1.2 什么是单元测试
? 。单元测试是针对最小的功能单元编写测试代码
? 。Java程序最小的功能单元是方法
? 。单元测试就是针对单个Java方法的测试
1.3 为什么要单元测试
1.使用main方法测试的缺点:
? --只能有一个main()方法,不能把测试代码分类
? --没有打印出测试结果和期望结果
? --需要一种测试框架,帮助我们编写测试
2.单元测试的好处:
? --确保单个方法运行正常
? --如果修改了代码,只需要确保其对应的单元测试通过
? --测试代码本身就可以作为实例代码
? --可以自动化运行所有测试并获得报告
1.4 junit单元测试框架
1.JUnit是一个开源的Java语言的单元测试框架
? --专门针对java语言设计,使用广泛
? --JUnit是事实上的标准单元测试框架
2.JUnit的特点
? 。使用断言(Assertion)测试期望结果
? 。可以方便地组织和运行测试
? 。可以方便地查看测试结果
? 。常用IDE(如Intellij Idea、Eclipse)都集成了JUnit
? 。可以方便地集成到Maven
3.JUnit设计
? TestCase: 一个TestCase表示一个测试
? TestSuite: 一个TestSuite包含一组TestCase,表示一组测试
? TestFixture: 一个TestFixture表示一个测试环境
? TestResult: 用于收集测试结果
? TestRunner:用于运行测试
? TestListener: 用于监听测试过程,收集测试数据
? Assert: 用于断言测试结果是否正确
4.Assert断言常用方法
Assert.assertEquals(期望的结果,实际运行的结果);
?
2 环境搭建
2.1 junit
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
2.2 struts2整合junit
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-junit-plugin</artifactId>
<version>2.1.8</version>
</dependency>
2.3 spring整合junit
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>4.2.1.RELEASE</version>
</dependency>
3.4 springboot整合junit
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
3 Java工程junit测试
3.1 搭建步骤
? 1.导入junit依赖环境
? 2.定义一个测试类(测试用例)
? 。测试类名: 被测试的类名Test calculatorTest
? 。包名: xxx.xxx.xxx.test cn.itcast.test
3.定义测试方法:可以独立运行
? 。方法名: test测试的方法名 testAdd()
? 。返回值:void
? 。参数列表:空参
4.给方法加@test
3.2 判定结果
? 。红色:失败
? 。绿色:成功
? 。一般我们会使用断言操作来处理结果
Assert.assertEquals(期望的结果,实际运行的结果);
3.3 手工搭建
Calculator.java 计算类
package com.tangguanlin.junit;
public class Calculator {
public int add(int a,int b){
int sum = a + b;
return sum;
}
public int sub(int a,int b){
int sub = a - b;
return sub;
}
}
1.导入junit依赖环境
? 在pom.xml文件中添加:
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
2.定义测试类CalculatorTest
在test/java目录下新建com.tangguanlin.junit包,新建CalculatorTest类,
?
3.定义测试方法testAdd,testSub
package com.tangguanlin.junit;
import org.junit.Assert;
import org.junit.Test;
public class CalculatorTest {
public void testAdd() {
Calculator demo1 = new Calculator();
int result = demo1.add(2,5);
System.out.println(result);
Assert.assertEquals(7,result);
}
public void testSub() {
Calculator demo1 = new Calculator();
int result = demo1.sub(5,2);
Assert.assertEquals(3,result);
}
}
4.给方法加 @test
5.右键左侧的绿色箭头点击“Run ‘testAdd() ”
左下角是junit测试的类和方法名称,右边是junit测试的运行结果。
3.4 自动搭建
1.在被测试的类Calculator中右键选择“Generate…”
2.在接下来的界面中界面中选择“Test…”
3.在接下来的界面中,勾选要测试的方法,add()方法和sub()方法,点击“OK”
4.这样就在test/java/com/tangguanlin/junit目录下生成了CalculatorTest测试类
4 spring mvc junit测试
(省略)
5 spring boot junit测试
5.1 测试service
1.在被测试的类中右键选择“Generate…”
2.在接下来的界面中界面中选择“Test…”
3.在接下来的界面中,勾选要测试的方法,queryDataBase()方法和createCollection()方法,点击“OK”
4.样就在test/java/com/tangguanlin/controller目录下生成了MongoDBControllerTest测试类
5.加上注解==@SpringBootTest==,写上测试代码,
右键左侧的绿色箭头点击“Run ‘queryDataBase() ”
5.2 测试controller
springboot测试controller要借助MockMvc。
package com.sendiyang.xiyeming;
@RunWith(SpringRunner.class)
@SpringBootTest
@WebAppConfiguration
class XiyemingApplicationTests {
@Autowired
private WebApplicationContext webApplicationContext;
private MockMvc mockMvc;
@BeforeEach
public void setUp() throws Exception {
mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).build();
}
@Test
void contextLoads() throws Exception {
MvcResult mvcResult = mockMvc.perform(MockMvcRequestBuilders.get("/hello")
.accept(MediaType.APPLICATION_JSON))
.andExpect(MockMvcResultMatchers.status().isOk())
.andExpect(MockMvcResultMatchers.content().string("hello world!"))
.andDo(MockMvcResultHandlers.print())
.andReturn();
int status = mvcResult.getResponse().getStatus();
String content = mvcResult.getResponse().getContentAsString();
Assert.assertEquals(200, status);
Assert.assertEquals("hello world!", content);
}
}
@RunWith(SpringRunner.class)
@SpringBootTest
public class HelloControllerTest {
private MockMvc mvc;
@Before
public void setUp() throws Exception {
mvc = MockMvcBuilders.standaloneSetup(new HelloController()).build();
}
@Test
public void getHello() throws Exception {
mvc.perform(MockMvcRequestBuilders.get("/hello").accept(MediaType.APPLICATION_JSON))
.andExpect(MockMvcResultMatchers.status().isOk())
.andDo(MockMvcResultHandlers.print())
.andReturn();
}
}
|