• 单元测试Junit使用与详解


    一、什么是单元测试
    在平时的开发当中,一个项目往往包含了大量的方法,可能有成千上万个。如何去保证这些方法产生的结果是我们想要的呢?当然了,最容易想到的一个方式,就是我们通过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简单使用

    1. import org.junit.*;
    2. public class Tests {
    3. @Test
    4. public void testAdd(){
    5. System.out.println("test1");
    6. }
    7. }


    左击方法名,点击运行按钮,选择debug模式,运行结果如图

    在这里插入图片描述
    3.对方法进行断言测试
    这里写了三个方法,主要对以下方法用断言进行测试,代码如下

    1. public class Method {
    2. public int add(int a,int b){
    3. return a+b;
    4. }
    5. public int delete(int a,int b){
    6. return a-b;
    7. }
    8. public boolean isTrue(){
    9. return 2==1;
    10. }
    11. }

    - 1、assertEquals
    断言判断是否相等,这个方法里面可以又很多参数,一般根据我们的需要输入相应的参数

    在这里插入图片描述 

    在这里选择assertEquals(Object expected,Object actual),expected指的是期望得到的值,actual指实际返回的结果,如果期望值和实际结果不相等,就会抛异常,即断言失败。我们对add方法进行测试,代码如下

    1. public class Tests {
    2. @Test
    3. public void testAdd(){
    4. Assert.assertEquals(3,new Method().add(3,1));
    5. System.out.println("test1");
    6. }
    7. }

    输入值和期望值不一样,这里抛出异常

    在这里插入图片描述
    - 2、assertTrue/assertFalse
    该断言用来验证给定的布尔型值是否为真,假如结果为假,则验证失败。
    方法: assertTrue ([String message],Boolean condition)
    message是个可选的消息,假如提供,将会在发生错误时报告这个消息。
    这里测试isTrue方法,测试代码如下:

    1. public class Tests {
    2. @Test
    3. public void testTrue(){
    4. Assert.assertTrue("不相等",new Method().isTrue());
    5. System.out.println("test1");
    6. }
    7. }

    很明显,测试代码里面返回的是false,所以会抛出message消息

    assertFalse方法同上,只是判断的结果相反,如果boolean中返回为false则不抛异常,返回为true抛出message消息。

    在这里插入图片描述

    - 3、assertNull
    这个方法很好理解,就不写专用的方法来进行演示。用于判断函数返回是否为空
    方法:assertNotNull([String message],Object object)
    message即返回为空之后的打印的消息,object是判断的方法
    测试代码如下:

    1. public class Tests {
    2. @Test
    3. public void testTrue(){
    4. Assert.assertNull("不为空","abcde");
    5. System.out.println("test1");
    6. }
    7. }


    测试结果:如果判断的对象不为空,则会抛出message消息,为空则通过测试

    在这里插入图片描述
    - 4、assertSame
     该断言用来验证expected参数和actual参数所引用的是否是同一个对象,假如不是,则验证失败。相应地,也存在验证不是同一个对象的断言。(和assertEquals区别在于,这个用于判断实际结果是否与期望结果的引用内存地址相同,类似于==,而assertEquals类似于equals方法)
     方法:assertNotSame ([String message], expected,actual)
     message也是断言失败后打印的消息,expected是期望值,actual是实际值
     测试代码:

    1. public class Tests {
    2. @Test
    3. public void testTrue(){
    4. Assert.assertSame("不相等",2,4-3);
    5. System.out.println("test1");
    6. }
    7. }


    测试结果:2肯定是不等于1的,这个时候会打印错误信息。

    在这里插入图片描述
    4.运行流程
    如果我们要在每个测试之前打开数据库,又关闭数据库,这样如果在每个方法里面写流程会非常麻烦,这个时候就有专有的测试方法运行前后进行操作的方法。其中beforeClass和afterClass方法必须是静态方法。
    @BeforeClass (setUpBeforeClass方法):
    注解静态方法;在运行测试类时最先运行且只执行一次。
    @AfterClass (tearDownAfterClass方法):
    注解静态方法;在运行测试类时最后个运行且只执行一次。
    @Before(setUp方法)
    在执行每个@Test之前执行,每个@Test执行前都会执行@Before。
    @Test
    要执行的测试单元
    @After(tearDown方法)
    在执行每个@Test之后执行,每个@Test执行结束后都会执行@After

    1. public class Tests {
    2. @Test
    3. public void testAdd(){
    4. System.out.println("test1");
    5. }
    6. @Test
    7. public void testDelete(){
    8. System.out.println("test2");
    9. }
    10. @BeforeClass
    11. public static void beforeClass(){
    12. System.out.println("beforeClass.....");
    13. }
    14. @After
    15. public void after(){
    16. System.out.println("after......");
    17. }
    18. @AfterClass
    19. public static void afterClass(){
    20. System.out.println("afterClass....");
    21. }
    22. @Before
    23. public void before(){
    24. System.out.println("before.....");
    25. }
    26. }

    打印结果:

    在这里插入图片描述

    这里我们可以看到它的运行流程是这样的:

    在这里插入图片描述


    5.junit测试套件(批量测试)
    有的时候我们可能不止要对一个类进行测试,这个时候就要用到测试套件,两个测试类如下
    Tests:

    1. public class Tests {
    2. @Test
    3. public void testAdd(){
    4. System.out.println("test1");
    5. }
    6. }

    Tests1

    1. import org.junit.Test;
    2. public class Tests1 {
    3. @Test
    4. public void testDelete(){
    5. System.out.println("test2");
    6. }
    7. }

    套件类Combine:

    1. import org.junit.runner.RunWith;
    2. import org.junit.runners.Suite;
    3. @RunWith(Suite.class)//用于更改测试运行器
    4. @Suite.SuiteClasses({Tests.class,Tests1.class})//将要测试的类作为数组传入到@Suite.SuiteClasses({})中
    5. public class Combine {
    6. /**
    7. 注意,该类中不要写任何代码
    8. **/
    9. }


    直接点击类名进行Debug
    运行结果如图:

    在这里插入图片描述 

    是不是特别方便呢,可以多个类一起进行测试,学会以上这些可以使用junit对方法进行测试,但是具体需要测试的业务和逻辑要根据实际情况来编写。

  • 相关阅读:
    微服务的拆分策略
    耗时半月,终于把牛客网上的Java面试八股文整理成了PDF合集
    LVGL_基础空间圆弧arc
    ElasticSearch ( 一 ) 安装启动
    【Leetcode合集】13. 罗马数字转整数
    SpringCloudGateway--谓词(断言)
    2023/09/17
    网络通信:http协议
    机器学习必修课 - 如何处理缺失数据
    C++ 类和对象篇(三) 空类和6个默认成员函数
  • 原文地址:https://blog.csdn.net/qq_36448800/article/details/126438339