Junit5单元测试框架详解

简介: 前面我们学习了Selenium自动化测试框架,但是有的时候测试用例会很多,我们需要一个工具来管理这些测试用例,而Junit就是一个很好的管理工具,简单点来说,Junit就是一个针对Java的单元测试框架;

一. 关于Junit5


Java 语言的单元测试框架相对统一,JUnit 和TestNG 几乎始终处于市场前两位。其中 JUnit 以较长的发展历史和源源不断的功能演进,得到了大多数用户的青睐;


Junit5 由 JUnit Platform + JUnit Jupiter + JUnit Vintage3 部分构成,借用 IBM Developer 的一张图来说明 JUnit 5 的架构 :

a3d1a630307d824191682417d2c42e8d.png

JUnit Platform :


其主要作用是在 JVM 上启动测试框架。它定义了一个抽象的 TestEngine API 来定义运行在平台上的测试框架;也就是说其他的自动化测试引擎或开发人员自己定制的引擎都可以接入 Junit 实现对接和执行。同时还支持通过命令行、Gradle 和 Maven 来运行;


JUnit Jupiter :


这是 Junit5 的核心,可以看作是承载 Junit4 原有功能的演进,包含了 JUnit 5 最新的编程模型和扩展机制;很多丰富的新特性使 JUnit ⾃动化测试更加方便、功能更加丰富和强大。也是测试需要重点学习的地方;Jupiter 本身也是⼀一个基于 Junit Platform 的引擎实现,对 JUnit 5 而言,JUnit Jupiter API 只是另一个 API;


JUnit Vintage :


Junit 发展了10数年,Junit 3 和 Junit 4 都积累了大量的⽤用户,作为新一代框 架,这个模块是对 JUnit3,JUnit4 版本兼容的测试引擎,使旧版本 junit 的⾃动化测试脚本也可以顺畅运行在 Junit5 下,它也可以看作是基于 Junit Platform 实现的引擎范例;


JUnit 5 对 Java 运行环境的最低要求是 Java 8;


二. Junit使用


2.1 添加Maven依赖

我们在操作 Junit 的时候要添加相应的依赖,可以去Maven仓库自行下载,这里给出一段代码:


<!-- 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>

2.2 注解

1)Test


表示方法是测试方法,与Junit4的@Test不同,不能声明任何属性,因为JUnit Jupiter中的测试扩展需要通过专用的注解;


public class Junit_Test {
    @Test
    void Test01(){
        System.out.println("测试用例1");
    }
    @Test
    void Test02(){
        System.out.println("测试用例2");
    }
}


5de75d64df674a11afbefba6ae7fa7c5.png


2)Disable


用于禁用一个测试类或测试方法;类似于JUnit 4的' @Ignore '。即执行单元测试时,会忽略对应的测试类或者测试方法;


public class Junit_Test {
    @Test
    void Test01(){
        System.out.println("测试用例1");
    }
    @Test
    void Test02(){
        System.out.println("测试用例2");
    }
    @Disabled
    void Test03(){
        System.out.println("测试用例3");
    }
}


119781ef5dc04dee8410ac12b616a1d4.png


3) BeforeAll 和 AfterAll


BeforeAll:表示方法在所有测试方法之前运行;


AfterAll:表示方法在所有测试方法之后运行;

public class Junit_Test {
    @AfterAll
    // 需要添加一个关键字static,是针对这个类的
    static void Test05(){
        System.out.println("测试用例AfterAll");
    }
    @Test
    void Test01(){
        System.out.println("测试用例1");
    }
    @Test
    void Test02(){
        System.out.println("测试用例2");
    }
    @Disabled
    void Test03(){
        System.out.println("测试用例3");
    }
    @BeforeAll
    // 需要添加一个关键字static,是针对这个类的
    static void Test04(){
        System.out.println("测试用例BeforeAll");
    }

119781ef5dc04dee8410ac12b616a1d4.png

针对这个操作,通常情况下,创建驱动,打开网页,都放到BeforeAll里面,关闭浏览器放到AfterAll里;


4)BeforeEach 和 AfterEach


BeforeEach:表示方法应该在当前类中每个 @Test, @RepeatedTest, @ParameterizedTest 或 @TestFactory 方法之前执行;类似于Junit4的@Before 。即在每个单元测试之前执行,如果测试类有n个测试方法,则被执行n次;


AfterEach:


表示方法应该在当前类中每个 @Test, @RepeatedTest, @ParameterizedTest 或 @TestFactory 方法之后执行;类似于Junit4的@After 。即在每个单元测试之后执行,如果测试类有n个测试方法,则被执行n次;


public class Junit_Test {
    @AfterAll
    // 需要添加一个关键字static,是针对这个类的
    static void Test05(){
        System.out.println("测试用例AfterAll");
    }
    @Test
    void Test01(){
        System.out.println("测试用例1");
    }
    @Test
    void Test02(){
        System.out.println("测试用例2");
    }
    @Disabled
    void Test03(){
        System.out.println("测试用例3");
    }
    @BeforeAll
    // 需要添加一个关键字static,是针对这个类的
    static void Test04(){
        System.out.println("测试用例BeforeAll");
    }
    @BeforeEach
    void Test06(){
        System.out.println("测试用例BeforeEach");
    }
    @AfterEach
    void Test07(){
        System.out.println("测试用例AfterEach");
    }
}


9efd99c0b35943749480f2eb4c66f439.png


5)ParameterizedTest


表示方法是参数化测试,这里我们需要引入对应的依赖,这里和Junit的版本保持一致:


<!-- https://mvnrepository.com/artifact/org.junit.jupiter/junit-jupiter-params -->
<dependency>
    <groupId>org.junit.jupiter</groupId>
    <artifactId>junit-jupiter-params</artifactId>
    <version>5.9.1</version>
    <scope>test</scope>
</dependency>
@ParameterizedTest
    // 传入整形参数
    @ValueSource(ints = {1,2,3})
    void Test08(int num){
        System.out.println(num);
    }
    @ParameterizedTest
    // 传入字符串
    @ValueSource(strings ={"1","2","3"})
    void Test09(String nums){
        System.out.println(nums);
    }


ce03fb31e97a401ab59e94a43a7e7dec.png



CSV获取参数:


@ParameterizedTest
    @CsvFileSource(resources = "test01.csv")
    void Test10(String name){
        System.out.println(name);
    }


8705c2957d3d4343a2e4493fc29cbd2f.png


方法获取参数,可传入不同类型的参数:


// 通过方法名获取参数
    @ParameterizedTest
    @MethodSource("method")
    void Test11(int num, String name) {
        System.out.println(num + ":" + name);
    }
    // 输出不同类型的参数
    public static Stream<Arguments> method() {
        return Stream.of(Arguments.arguments(1, "张三"),
                Arguments.arguments(2, "李四"),
                Arguments.arguments(3, "王五"));
    }

e33a170fe17e41e19b8076851d8d1aad.png

6)TestMethodOrder


按照指定顺序来执行测试用例


// 按照指定顺序
//@TestMethodOrder(MethodOrderer.OrderAnnotation.class)
// 按照随机顺序
@TestMethodOrder(MethodOrderer.Random.class)
public class Junit_Test1 {
    // 第三个执行
    @Order(3)
    @Test
    void Test01() {
        System.out.println("测试用例1");
    }
    // 第一个执行
    @Order(1)
    @Test
    void Test02() {
        System.out.println("测试用例2");
    }
    // 第二个执行
    @Order(2)
    @Test
    void Test03() {
        System.out.println("测试用例3");
    }
}


2.3 断言

断言(assertions)是测试方法中的核心部分,用来对测试需要满足的条件进行验证。这些断言方法都是 orgjuiit.jupiter.api.Assertions的静态方法。JUnit5内置的断言可以分成如下几个类别:检查业务逻辑返回的数据是否合理;


1)assertEquals :判断两个对象或两个原始类型是否相等


@ParameterizedTest
    @ValueSource(ints = {1})
    void Test04(int num){
        // 第一个参数是预期的,第二个参数是实际的
        Assertions.assertEquals(1,num);
        System.out.println(num);
    }

2)assertNotEquals:判断两个对象或两个原始类型是否不相等


@ParameterizedTest
    @ValueSource(ints = {1})
    void Test04(int num){
        // 第一个参数是预期的,第二个参数是实际的
        // 判断是否相等
        //Assertions.assertEquals(1,num);
        // 判断不相等
        Assertions.assertNotEquals(2,num);
        System.out.println(num);
    }

3)assertSame:判断两个对象引用是否指向同一个对象


@ParameterizedTest
    @ValueSource(ints = {1})
    void Test04(int num) {
        // 判断是否指向同一个对象
        Object obj1 = new Object();
        Object obj2 = new Object();
        Assertions.assertSame(obj1, obj2, "不是同一个对象");
    }

4)assertNotNull:判断给定的对象引用是否不为null


@ParameterizedTest
    @ValueSource(ints = {1})
    void Test04(int num){
        // 判断是否为空
        String str = null;
        Assertions.assertNull(str);
    }

2.4 套件

使用 JUnit5 测试套件,您可以运行分散到多个测试类和不同包中的测试;


1)SelectClasses指定通过class运行测试套件时要选择的类


@Suite
// 先执行Junit_Test.class,再执行Junit_Test1.class
@SelectClasses({Junit_Test.class,Junit_Test1.class})
public class RunSuite {
}

1)SelectPackages指定通过包运行测试套件时要选择的类


@Suite
@SelectPackages(value = {"Pack1","Pack2"})
public class RunSuite {
}

到这里关于Junit常用的操作就介绍完了,有问题的小伙伴可以私信我,感觉有帮助的,希望可以留下你们的小赞~~

目录
相关文章
|
2月前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
153 11
|
2天前
|
人工智能 自然语言处理 测试技术
AxBench:斯坦福大学推出评估语言模型控制方法的基准测试框架
AxBench 是由斯坦福大学推出,用于评估语言模型可解释性方法的基准测试框架,支持概念检测和模型转向任务,帮助研究者系统地比较不同控制技术的有效性。
29 5
AxBench:斯坦福大学推出评估语言模型控制方法的基准测试框架
|
24天前
|
小程序 前端开发 关系型数据库
uniapp跨平台框架,陪玩系统并发性能测试,小程序源码搭建开发解析
多功能一体游戏陪练、语音陪玩系统的开发涉及前期准备、技术选型、系统设计与开发及测试优化。首先,通过目标用户分析和竞品分析明确功能需求,如注册登录、预约匹配、实时语音等。技术选型上,前端采用Uni-app支持多端开发,后端选用PHP框架确保稳定性能,数据库使用MySQL保证数据一致性。系统设计阶段注重UI/UX设计和前后端开发,集成WebSocket实现语音聊天。最后,通过功能、性能和用户体验测试,确保系统的稳定性和用户满意度。
|
1月前
|
存储 测试技术 API
pytest接口自动化测试框架搭建
通过上述步骤,我们成功搭建了一个基于 `pytest`的接口自动化测试框架。这个框架具备良好的扩展性和可维护性,能够高效地管理和执行API测试。通过封装HTTP请求逻辑、使用 `conftest.py`定义共享资源和前置条件,并利用 `pytest.ini`进行配置管理,可以大幅提高测试的自动化程度和执行效率。希望本文能为您的测试工作提供实用的指导和帮助。
109 15
|
2月前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
500 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
2月前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
89 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
2月前
|
安全 Ubuntu Linux
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
60 9
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
|
2月前
|
Java 测试技术 API
探索软件测试中的自动化测试框架
本文深入探讨了自动化测试在软件开发中的重要性,并详细介绍了几种流行的自动化测试框架。通过比较它们的优缺点和适用场景,旨在为读者提供选择合适自动化测试工具的参考依据。
|
2月前
|
数据管理 jenkins 测试技术
自动化测试框架的设计与实现
在软件开发周期中,测试是确保产品质量的关键步骤。本文通过介绍自动化测试框架的设计原则、组件构成以及实现方法,旨在指导读者构建高效、可靠的自动化测试系统。文章不仅探讨了自动化测试的必要性和优势,还详细描述了框架搭建的具体步骤,包括工具选择、脚本开发、执行策略及结果分析等。此外,文章还强调了持续集成环境下自动化测试的重要性,并提供了实际案例分析,以帮助读者更好地理解和应用自动化测试框架。
|
2月前
|
敏捷开发 测试技术 持续交付
自动化测试之美:从零开始搭建你的Python测试框架
在软件开发的马拉松赛道上,自动化测试是那个能让你保持节奏、避免跌宕起伏的神奇小助手。本文将带你走进自动化测试的世界,用Python这把钥匙,解锁高效、可靠的测试框架之门。你将学会如何步步为营,构建属于自己的测试庇护所,让代码质量成为晨跑时清新的空气,而不是雾霾中的忧虑。让我们一起摆脱手动测试的繁琐枷锁,拥抱自动化带来的自由吧!