一、什么是单元测试
在平时的开发当中,一个项目往往包含了大量的方法,可能有成千上万个。如何去保证这些方法产生的结果是我们想要的呢?当然了,最容易想到的一个方式,就是我们通过System.out来输出我们的结果,看看是不是满足我们的需求,但是项目中这些成千上万个方法,我们总不能在每一个方法中都去输出一遍嘛。这也太枯燥了。这时候用我们的单元测试框架junit就可以很好地解决这个问题。Junit是一个单元测试框架。
二、使用
注意:用Junit进行单元测试必须满足以下条件:
1、每一个测试方法上使用@Test进行修饰
2、每一个测试方法必须使用public void 进行修饰
3、每一个测试方法不能携带参数
4、测试代码和源代码在两个不同的项目路径下
5、测试类的包应该和被测试类保持一致
6、测试单元中的每个方法必须可以独立测试
1.Junit的jar包导入
如果不是maven项目,直接网上下载junit的jar包,如果是maven项目,直接导入maven依赖,版本改成自己需要。但是要注意,4.10以上版本的junit要配合hamcrest-core的jar包使用。
2.Junit简单使用
import org.junit.*;
public class Tests {
@Test
public void testAdd(){
System.out.println("test1");
}
}
左击方法名,点击运行按钮,选择debug模式,运行结果如图
3.对方法进行断言测试
这里写了三个方法,主要对以下方法用断言进行测试,代码如下
public class Method {
public int add(int a,int b){
return a+b;
}
public int delete(int a,int b){
return a-b;
}
public boolean isTrue(){
return 2==1;
}
}
- 1、assertEquals
断言判断是否相等,这个方法里面可以又很多参数,一般根据我们的需要输入相应的参数
在这里选择assertEquals(Object expected,Object actual),expected指的是期望得到的值,actual指实际返回的结果,如果期望值和实际结果不相等,就会抛异常,即断言失败。我们对add方法进行测试,代码如下
public class Tests {
@Test
public void testAdd(){
Assert.assertEquals(3,new Method().add(3,1));
System.out.println("test1");
}
}
输入值和期望值不一样,这里抛出异常
- 2、assertTrue/assertFalse
该断言用来验证给定的布尔型值是否为真,假如结果为假,则验证失败。
方法: assertTrue ([String message],Boolean condition)
message是个可选的消息,假如提供,将会在发生错误时报告这个消息。
这里测试isTrue方法,测试代码如下:
public class Tests {
@Test
public void testTrue(){
Assert.assertTrue("不相等",new Method().isTrue());
System.out.println("test1");
}
}
很明显,测试代码里面返回的是false,所以会抛出message消息
assertFalse方法同上,只是判断的结果相反,如果boolean中返回为false则不抛异常,返回为true抛出message消息。
- 3、assertNull
这个方法很好理解,就不写专用的方法来进行演示。用于判断函数返回是否为空
方法:assertNotNull([String message],Object object)
message即返回为空之后的打印的消息,object是判断的方法
测试代码如下:
public class Tests {
@Test
public void testTrue(){
Assert.assertNull("不为空","abcde");
System.out.println("test1");
}
}
测试结果:如果判断的对象不为空,则会抛出message消息,为空则通过测试
- 4、assertSame
该断言用来验证expected参数和actual参数所引用的是否是同一个对象,假如不是,则验证失败。相应地,也存在验证不是同一个对象的断言。(和assertEquals区别在于,这个用于判断实际结果是否与期望结果的引用内存地址相同,类似于==,而assertEquals类似于equals方法)
方法:assertNotSame ([String message], expected,actual)
message也是断言失败后打印的消息,expected是期望值,actual是实际值
测试代码:
public class Tests {
@Test
public void testTrue(){
Assert.assertSame("不相等",2,4-3);
System.out.println("test1");
}
}
测试结果:2肯定是不等于1的,这个时候会打印错误信息。
4.运行流程
如果我们要在每个测试之前打开数据库,又关闭数据库,这样如果在每个方法里面写流程会非常麻烦,这个时候就有专有的测试方法运行前后进行操作的方法。其中beforeClass和afterClass方法必须是静态方法。
@BeforeClass (setUpBeforeClass方法):
注解静态方法;在运行测试类时最先运行且只执行一次。
@AfterClass (tearDownAfterClass方法):
注解静态方法;在运行测试类时最后个运行且只执行一次。
@Before(setUp方法)
在执行每个@Test之前执行,每个@Test执行前都会执行@Before。
@Test
要执行的测试单元
@After(tearDown方法)
在执行每个@Test之后执行,每个@Test执行结束后都会执行@After
public class Tests {
@Test
public void testAdd(){
System.out.println("test1");
}
@Test
public void testDelete(){
System.out.println("test2");
}
@BeforeClass
public static void beforeClass(){
System.out.println("beforeClass.....");
}
@After
public void after(){
System.out.println("after......");
}
@AfterClass
public static void afterClass(){
System.out.println("afterClass....");
}
@Before
public void before(){
System.out.println("before.....");
}
}
打印结果:
这里我们可以看到它的运行流程是这样的:
5.junit测试套件(批量测试)
有的时候我们可能不止要对一个类进行测试,这个时候就要用到测试套件,两个测试类如下
Tests:
public class Tests {
@Test
public void testAdd(){
System.out.println("test1");
}
}
Tests1
import org.junit.Test;
public class Tests1 {
@Test
public void testDelete(){
System.out.println("test2");
}
}
套件类Combine:
import org.junit.runner.RunWith;
import org.junit.runners.Suite;
@RunWith(Suite.class)//用于更改测试运行器
@Suite.SuiteClasses({Tests.class,Tests1.class})//将要测试的类作为数组传入到@Suite.SuiteClasses({})中
public class Combine {
/**
注意,该类中不要写任何代码
**/
}
直接点击类名进行Debug
运行结果如图:
是不是特别方便呢,可以多个类一起进行测试,学会以上这些可以使用junit对方法进行测试,但是具体需要测试的业务和逻辑要根据实际情况来编写。
版权归原作者 熊與猫v 所有, 如有侵权,请联系我们删除。