JUnit单元测试之旅

这篇具有很好参考价值的文章主要介绍了JUnit单元测试之旅。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 什么是单元测试和JUnit

单元测试(Unit Testing)是对软件中的最小可测试单元进行检查和验证。它主要包括:

  • 测试单元:软件中的最小可测试功能模块,如方法、类等。
  • 测试用例:用于验证测试单元的输入、执行和输出是否正确的测试脚本。
  • 测试套件:包含多个测试用例的集合。

JUnit是Java语言中最广泛使用的单元测试框架。它允许编写和运行可以重复执行的测试,并且可以自动化测试过程。
JUnit主要功能包括:

  • 测试套件(Test Suite)控制多个测试用例;
  • 断言(Assertions)验证测试结果;
  • 设置超时时间;
  • 忽略测试(Ignored Tests );
  • 提供测试结果报告等。

JUnit是Java语言中最广泛使用的单元测试框架

2. JUnit入门与基本注解

2.1测试类的定义:

使用@Test注解标注测试方法
按照以往的经验,我们想运行一个程序必须在main方法运行,但是junit给了我们一个注解,我们只需要在方法上注解之后,就可以直接点击运行,以下是代码实例

    @Test
    public void Test01(){
        System.out.println("这是第一个注解");

    }
    @Test
    public void Test02(){
        System.out.println("这是我们的Test02");
    }

JUnit单元测试之旅
标识测试方法:@Test告诉JUnit这个方法是一个测试方法,需要运行并验证。没有@Test注解的方法不会被认为是测试方法,不会运行。

2.2 生命周期注解:

@BeforeAll,@AfterAll,@BeforeEach,@AfterEach
解释完@Test之后我们来看看这四个注解的意思,再看看他们的执行顺序,话不多说,我们直接上代码

public class JunitTest02 {
    @BeforeAll
    static void SetUp() {
        System.out.println("这是我们BeforeAll里面的语句");
    }

    @AfterAll
    static void TearDown() {
        System.out.println("这是AfterAll的语句");
    }


    @BeforeEach
    void BeforeEachTest() {
        System.out.println("这是BeforeEach里面的语句");
    }

    @AfterEach
    void AfterEachTest() {
        System.out.println("这是AfterEach里面的语句");
    }
    @Test
    void Test01() {
        System.out.println("这是JunitTest里面的Test01");
    }

    @Test
    void Test02() {
        System.out.println("这是JunitTest里面的Test02");
    }

}

执行结果:
JUnit单元测试之旅
具体的解释过程:

  1. @BeforeAll:在所有的测试执行之前执行一次
  2. @BeforeEach:每个测试方法执行之前执行
  3. 测试方法:test1()和test2()被执行
  4. @AfterEach:每个测试方法执行之后执行
  5. @AfterAll:在所有的测试执行之后执行一次
    所以具体的生命周期如下:
    BeforeAll在所有的测试用例运行之前跑对应的方法
    BeforeEach在每一个测试用例执行之前跑对应的方法
    AfterAll在所有的测试用例运行之前跑对应的方法
    AfterEach在每一个测试用例执行之前跑对应的方法

2.3断言注解:

具体来解释一下:
在JUnit5中,断言(Assertions)注解用来验证测试结果是否正确。主要的断言注解有:

  • @AssertEquals:判断两个对象或两个原始类型是否相等。
  • @AssertTrue:判断给定的布尔值是否为 true。
  • @AssertFalse:判断给定的布尔值是否为 false。
  • @AssertNull:判断给定的对象引用是否为 null。
  • @AssertNotNull:判断给定的对象引用是否不为 null。
  • @AssertSame:判断两个对象引用是否指向同一个对象。
  • @AssertNotSame:判断两个对象引用是否指向不同的对象。

具体例子如下:

 @ParameterizedTest
    @ValueSource(strings = {"null1"})
    void Test02(String  num){
        Assertions.assertNull(num);
    }

出现的运行情况
JUnit单元测试之旅

** @ParameterizedTest
    // @ValueSource(ints = {1})注解提供测试参数1。
    @ValueSource(ints = {1})
    //方法Test01()有一个int类型参数num。由于@ParameterizedTest的存在,该方法会使用@ValueSource提供的测试参数1执行一次。
    void Test01(int num) {
        System.out.println(num);
        /*
        - assertEquals(1, num):判断num是否等于1,通过。

         */
        Assertions.assertEquals(1, num);
    }**

运行效果如下:
JUnit单元测试之旅

 @ParameterizedTest
    // @ValueSource(ints = {1})注解提供测试参数1。
    @ValueSource(ints = {1})
    void Test03( int num){
        Assertions.assertNotEquals(1, num);
    }

运行结果如下:
JUnit单元测试之旅
我这里只是列举了一些操作,大家可以下去自己尝试一下,看看其他的,是怎么样的情况.

2.4 参数化

单参数

这里我们使用但参数的引入注解是@ValueSource,下面就是这个参数的具体解释。
@ValueSource是一个JUnit的参数化测试注解。它允许使用不同的参数多次运行同一个测试方法。
基本用法是:

  1. 在测试方法上使用@ValueSource(ints = {…})注解,指定测试参数数组。
  2. 测试方法必须只有一个参数,这个参数会在不同测试 iterations 中使用 @ValueSource 指定的不同值。
  3. JUnit 会根据指定的参数数组,多次运行此测试方法,实现参数化。
    具体的例子如下:
    @ParameterizedTest
    @ValueSource(ints = {1, 2, 3})
    void Test04(int num) {
        System.out.println(num);
    }

    @ParameterizedTest
    @ValueSource(strings = {"1", "2", "3"})
    void Test05(String number) {
        System.out.println(number);
    }

多参数

我们使用csv的方式.
@CsvFileSource是一个JUnit的参数化测试注解,用于从CSV文件中读取测试参数.
具体的步骤如下:

  1. 创建一个CSV文件
  2. 在测试方法上使用@CsvFileSource注解,指定CSV文件的路径

具体例子如下:

//使用Csv文件
    @ParameterizedTest
    @CsvFileSource(resources = "test02.csv")
    public void Test06(int id,String name){
        System.out.println("学号:" + id + ",姓名:" + name);
        
    }
   @ParameterizedTest
    @CsvFileSource(resources = "test01.csv")
    void Test07(String name){
        System.out.println(name);
    }

最终的输出结果:
JUnit单元测试之旅
JUnit单元测试之旅

test01和test02的内容格式如下:
JUnit单元测试之旅

其实大家看到上面的例子,或许大家还有一个东西没有明白,什么是.CSV文件,我这里来带大家认识一下:
什么是CSV?
CSV(Comma-Separated Values,逗号分隔的值)是一种简单、实用的文件格式,用于存储和表示包括文本、数值等各种类型的数据。CSV 文件通常以 .csv 作为文件扩展名。这种文件格式的一个显著特点是:文件内的数据以逗号 , 分隔,呈现一个表格形式。CSV 文件已广泛应用于存储、传输和编辑数据。
CSV文件的结构
每行表示一条记录:CSV 文件中的每一行代表一条记录,相当于数据库中的一行数据。
逗号分隔:每行数据中,使用逗号 , 进行数据分隔,代表不同的数据。
引号包围:当数据单元格中的内容含有逗号时,为避免混淆,需要引号 (单引号 ’ 或双引号 ")将这个数据包围起来,防止误认为是两个不同数据。

具体格式如下:

姓名,年龄,性别
张三,25,男
李四,28,男
王五,22,女

通过方法获取参数

在JUnit5中,@MethodSource注解用于从指定方法中获取测试参数。其基本用法如下:

  1. 定义一个返回Stream或Iterable的参数提供方法.
public static Stream<Arguments> Generator() {
        return Stream.of(Arguments.arguments(
                "1,张三",
                "2,李四"
        ));
    }
  1. 在测试方法上使用@MethodSource注解引用此方法
 @ParameterizedTest
    @MethodSource("Generator")
    void Test07(String num, String name) {
        System.out.println(num + ":" + name);
    }

具体的运行结果:

JUnit单元测试之旅

  1. JUnit会调用stringProvider()方法获取参数,并使用这些参数重复执行testWithStringArgument()方法,实现参数化测试。

2.5 测试套件

测试套件(Test Suite)是一组组织在一起的测试案例。它允许您将单元测试组合在一起,以匹配整个功能或模块。
测试套件的主要优点是:

  1. 组织测试:可以按功能、类别等组织管理相关测试,提高可维护性。
  2. 批量执行:可以一次性执行套件中的全部测试,方便回归测试等场景。
  3. 层次清晰:套件可以嵌套套件,形成层次结构,mirror应用的结构。
  4. 管理测试顺序:可以控制套件中测试的执行顺序。
  5. 测试报告:套件执行会生成汇总报告,使得测试结果更加直观全面。

这里我们使用的是使用@Suite注解定义一个用于存储测试的容器类.
具体对@Suite做出解释:
@Suite是JUnit中的一个注解,用于定义测试套件。
具体的使用步骤:
1.加入@Suite注解
2.在类上添加@Suite.SelectPackages或者 @SelectClasses注解列出该套件包含的测试:

具体的包目录
JUnit单元测试之旅

具体的包里面的类

public class Test07 {
    @Test
    void Test007() {
        System.out.println("Test08 pacage Test007");
    }
}
public class Test09 {
    @Test
    void Test01() {
        System.out.println("package test09 test01");
    }
}
import org.junit.jupiter.api.Test;

public class JunitTest01 {

    @Test
    public void Test01(){
        System.out.println("这是第一个注解");

    }
    @Test
    public void Test02(){
        System.out.println("这是我们的Test02");
    }
}

这里提供俩种方式:

通过class运行测试用例

@Suite
@SelectClasses({JunitTest01.class})
    public class RunSuite {
    }

具体运行结果

JUnit单元测试之旅

通过包运行测试用例

@Suite
@SelectPackages(value = {"Test08","Test09"})
    public class RunSuite {
    }

具体的运行结果
JUnit单元测试之旅文章来源地址https://www.toymoban.com/news/detail-470367.html

三.用到的依赖包

 <dependencies>
        <!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-java -->
        <dependency>
            <groupId>org.seleniumhq.selenium</groupId>
            <artifactId>selenium-java</artifactId>
            <version>3.141.59</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.11.0</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.junit.jupiter/junit-jupiter-api -->
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-api</artifactId>
            <version>5.9.1</version>
        </dependency>
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-params</artifactId>
            <version>5.9.1</version>
        </dependency>
 
        <dependency>
            <groupId>org.junit.platform</groupId>
            <artifactId>junit-platform-suite</artifactId>
            <version>1.9.1</version>
            <scope>test</scope>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.junit.platform/junit-platform-suite -->
    </dependencies>

到了这里,关于JUnit单元测试之旅的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 软件测试实验:Junit单元测试

    目录 前言 实验目的 实验内容 实验要求 实验过程 题目一 题目一测试结果 题目二 题目二实验结果 总结 软件测试是软件开发过程中不可缺少的一个环节,它可以保证软件的质量和功能,发现并修复软件的缺陷和错误。软件测试分为多种类型,其中一种是单元测试,即对软件

    2024年02月02日
    浏览(51)
  • 单元测试 —— JUnit 5 参数化测试

    目录 设置 我们的第一个参数化测试 参数来源 @ValueSource @NullSource @EmptySource @MethodSource @CsvSource @CsvFileSource @EnumSource @ArgumentsSource 参数转换 参数聚合 奖励 总结 如果您正在阅读这篇文章,说明您已经熟悉了JUnit。让我为您概括一下JUnit——在软件开发中,我们开发人员编写的代

    2024年02月03日
    浏览(46)
  • 【单元测试】Junit 4(三)--Junit4断言

    ​ **断言(assertion)**是一种在程序中的一阶逻辑(如:一个结果为真或假的逻辑判断式),目的为了表示与验证软件开发者预期的结果——当程序执行到断言的位置时,对应的断言应该为真。若断言不为真时,程序会中止执行,并给出错误信息。 这里我们直接上例子 接下来我们

    2024年02月08日
    浏览(51)
  • 单元测试及其工具Junit

    单元测试是开发者编写的一小段代码,用于检验被测代码的一个很小的、很明确的功能是否正确,通常而言,一个单元测试是用于判断某个特定条件(或者场景)下某个特定函数的行为。 单元测试是软件测试的一种类型,测试对象是最基础的代码单元(函数、类、模块),属

    2024年02月10日
    浏览(41)
  • 测开 (Junit 单元测试框架)

    目录 了解 Junit 引入相关依赖 1、Junit注解 @Test @BeforeEach、@BeforeAll @AfterEach @AfterAll 2、断言 1、Assertions - assertEquals 方法 2、Assertions - assertNotEquals 方法 3、Assertions - assertTrue assertFalse方法 4、Assertions - assertNull assertNotNull 小结 3、用例的执行顺序 - 方法排序( @Order 注解) 4、测试套

    2024年02月07日
    浏览(50)
  • 【Junit 单元测试】

    1.导入依赖

    2024年02月11日
    浏览(22)
  • Junit单元测试(笔记)

    Junit是一个Java语言的单元测试框架,简单理解为可以用于取代java的( 部分 )main方法。Junit属于 第三方 工具,需要 导入jar包 后使用。 a.在当前模块下创建lib文件夹 b.把junit的jar包,拷贝到lib的文件夹中 c.把jar包添加到图书馆中 执行的结果: 备注: Junit常用注解(Junit5.x版本) @Befor

    2023年04月26日
    浏览(38)
  • 单元测试junit+mock

    单元测试(unit testing),是指对软件中的最小可测试单元进行检查和验证。至于“单元”的大小或范围,并没有一个明确的标准,“单元”可以是一个方法、类、功能模块或者子系统。 单元测试通常和白盒测试联系到一起 ,如果单从概念上来讲两者是有区别的,不过我们通

    2024年02月08日
    浏览(67)
  • Junit 单元测试(详解)

    本博主将用CSDN记录软件开发求学之路上亲身所得与所学的心得与知识,有兴趣的小伙伴可以关注博主!也许一个人独行,可以走的很快,但是一群人结伴而行,才能走的更远! JUnit 是一种流行的单元测试框架,它可以帮助开发人员编写、运行和调试单元测试,以确保代码的

    2023年04月15日
    浏览(37)
  • 使用JUnit单元测试

    前提:   测试题目: 根据输入的年份和月份判断月份的天数。若月份不在有效范围之内,应提示:“月份输入不正确。”。月份不为2月,根据输入月份输出对应的月份天数。月份为2月,根据年份判断如为普通闰年,输出2月份正确天数;如为世纪闰年,输出2月份正确天数;

    2024年02月04日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包