单元测试Junit使用与详解

  • Post author:
  • Post category:其他


一、什么是单元测试

在平时的开发当中,一个项目往往包含了大量的方法,可能有成千上万个。如何去保证这些方法产生的结果是我们想要的呢?当然了,最容易想到的一个方式,就是我们通过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对方法进行测试,但是具体需要测试的业务和逻辑要根据实际情况来编写。



版权声明:本文为qq_36448800原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。