Junit测试框架

简介: Junit测试框架

一、简介

Junit框架是一个开源的Java语言单元测试框架,Java方向使用最广泛的单元测试框架,使用Java开发者都应该学习Junit并能掌握单元测试的编写。

对于Junit和Selenium的关系:通俗点来说Selenium如果比喻为灯泡,那么Junit就是电源。

二、常见使用方法

注解

在Junit框架中使用注解可以实现单元测试。

@Test

在方法前加上@Test注解就不用编写main方法,是直接可以运行该方法的。

@Test
public  void test01(){
   System.out.println("简单测试");
}

@BeforeEach

在方法前加上BeforeEach表示在每执行一个测试方法之前,都要执行该方法一次。

    @Test
    public  void test01(){
        System.out.println("简单测试");
    }
    @Test
    public  void test02(){
        System.out.println("简单测试2");
    }
    @BeforeEach
    public  void test00(){
        System.out.println("测试");
    }

@BeforeAll

在方法前加上BeforeEach表示在每执行测试之前都会执行该测试方法,但只执行一次,该方法必须用static修饰

    @org.junit.jupiter.api.Test
    public  void test01(){
        System.out.println("简单测试");
    }
    @org.junit.jupiter.api.Test
    public  void test02(){
        System.out.println("简单测试2");
    }
    @BeforeAll
    public  static void test00(){
        System.out.println("测试");
    }

 

@AfterEach:表示在每执行一个测试方法之前,都要执行该方法一次。

@AfterAll:表示在执行测试之后执行该方法一次,也要求是静态方法。

这两种注解与@BeforeEach和@BeforeAll用法相似,便不再进行演示。

断言

assertEquals和assertNotEquals

assertEquals:比较要测试的是否与预期的一致。

assertNotEquals:比较要测试的是否与预期的不一致。

    ChromeDriver driver = new ChromeDriver();
    @org.junit.jupiter.api.Test
    public void assertTest(){
        driver.get("https://www.baidu.com");
        String str = driver.findElement(By.xpath("//*[@id=\"su\"]")).getAttribute("value");
        Assertions.assertEquals("百度一下",str);
    }

assertTrue和assertFalse

参数为布尔表达式用于判断真假。

assertTrue:参数中布尔表达式为真时,测试通过。

assertFalse:参数中布尔表达式为假时,测试通过。

    @org.junit.jupiter.api.Test
    public void assertTest(){
        driver.get("https://www.baidu.com");
        String str = driver.findElement(By.xpath("//*[@id=\"su\"]")).getAttribute("value");
        Assertions.assertTrue("百度一下".equals(str));
    }

assertNull 和assertNotNull

assertNull 和assertNotNull这两个方法来判断参数是否为空。

    @org.junit.jupiter.api.Test
    public void assertTest(){
        driver.get("https://www.baidu.com");
        String str = driver.findElement(By.xpath("//*[@id=\"su\"]")).getAttribute("value");
        Assertions.assertNotNull(str);
        driver.quit();
    }

测试用例的执行顺序

Junit的默认的执行顺序是不确定的,官方的用例并没有明确指出,如果测试之间有关联,这就需要使用Junit提供的方法来手动设置测试用例的执行顺序,在类前加上TestMethodOrder注解,标注当前类使用方法进行排序,在类中的方法前使用order注解注明顺序。

但是在编写测试用例时尽量保持其独立性。

@TestMethodOrder(MethodOrderer.OrderAnnotation.class)
public class Test {
    @org.junit.jupiter.api.Test
    @Order(1)
    public void test1(){
        System.out.println("测试1");
    }
    @org.junit.jupiter.api.Test
    @Order(2)
    public void test2(){
        System.out.println("测试2");
    }
    @org.junit.jupiter.api.Test
    @Order(3)
    public void test3(){
        System.out.println("测试3");
    }
}

测试套件

测试套件Suite,可以将指定文件添加到套件执行。可以使用@SelectClasses()注解,以及@SelectPackages()注解。

@Suite
@SelectClasses(Test.class)
public class AutoTest {
}

参数化

在测试方法中可以添加参数进行测试,使用@Parameterizedtest来标注方法类型为参数化,并且不需要再添加@Test注解,否则就会再多执行一次。

单参数

使用@ValueSource(类型={参数1,参数2……},在指明类型时需要使用原生类型,在基本数据类型之后加上s,例如:ints、floats。

    @ParameterizedTest
    @ValueSource(ints = {1,23,0,9})
    public void test1(int a){
        System.out.println(a);
    }

多参数

使用@CSVSource(Value={"小明,98","张三,100",……}

多参数之间默认使用,如果修改需要使用delimeterString指定分隔字符。

@ParameterizedTest
    @CsvSource(value = {"小明-100","刘洋-99"},delimiterString = "-")
    public void test2(String name,int score){
        System.out.println("姓名:"+name+" 成绩:"+score);
    }

当参数过多的话就可以使用文件进行处理,使用CSVFileSource注解

    @ParameterizedTest
    @CsvFileSource (files = "D:\\test.txt")
    public void test2(String name,int score){
        System.out.println("姓名:"+name+" 成绩:"+score);
    }

动态参数

单参数

使用@MethodSource()进行注解,参数为数据来源的方法名,如果不指定参数,就默认找跟用例同名的静态方法。

 @ParameterizedTest
    @MethodSource("dataSource")
    public void test0(String str){
        System.out.println(str);
    }
   public static Set<String> dataSource(){
       Set<String> set = new HashSet<>();
       set.add("小明,90");
       set.add("张强,98");
       set.add("王志,100");
       return set;
   }

多参数

@ParameterizedTest
    @MethodSource("dataSource")
    public void test0(String name,int score){
        System.out.println(name+":"+score);
    }
   public static Stream<Arguments> dataSource(){
        return Stream.of(Arguments.arguments("jim",90),Arguments.arguments("lucy",99));
   }

7ee0270c88e14ed7aa7f2d55fd3a1ded.png

目录
相关文章
|
4天前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
39 8
|
10天前
|
人工智能 JavaScript 前端开发
自动化测试框架的演进与实践###
本文深入探讨了自动化测试框架从诞生至今的发展历程,重点分析了当前主流框架的优势与局限性,并结合实际案例,阐述了如何根据项目需求选择合适的自动化测试策略。文章还展望了未来自动化测试领域的技术趋势,为读者提供了宝贵的实践经验和前瞻性思考。 ###
|
17天前
|
人工智能 监控 测试技术
探索软件测试中的自动化框架选择与优化策略####
【10月更文挑战第21天】 本文深入剖析了软件测试领域面临的挑战,聚焦于自动化测试框架的选择与优化这一核心议题。不同于传统摘要的概述方式,本文将以一个虚拟案例“X项目”为线索,通过该项目从手动测试困境到自动化转型的成功历程,生动展现如何根据项目特性精准匹配自动化工具(如Selenium、Appium等),并结合CI/CD流程进行深度集成与持续优化,最终实现测试效率与质量的双重飞跃。读者将跟随“X项目”团队的视角,直观感受自动化框架选型的策略性思考及实践中的优化技巧,获得可借鉴的实战经验。 ####
28 0
|
5天前
|
安全 Ubuntu Linux
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
26 9
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
|
13天前
|
Java 测试技术 API
探索软件测试中的自动化框架选择####
在当今快节奏的软件开发周期中,自动化测试已成为确保产品质量与加速产品迭代的关键策略。本文深入剖析了自动化测试的核心价值,对比分析了市场上主流的自动化测试框架,旨在为项目团队提供选型时的考量因素及实践指南,助力高效构建适应未来变化的自动化测试体系。 ####
|
9天前
|
Java 测试技术 API
探索软件测试中的自动化测试框架
本文深入探讨了自动化测试在软件开发中的重要性,并详细介绍了几种流行的自动化测试框架。通过比较它们的优缺点和适用场景,旨在为读者提供选择合适自动化测试工具的参考依据。
|
12天前
|
jenkins 测试技术 持续交付
自动化测试框架的搭建与实践
在软件开发领域,自动化测试是提升开发效率、确保软件质量的关键手段。本文将引导读者理解自动化测试的重要性,并介绍如何搭建一个基本的自动化测试框架。通过具体示例和步骤,我们将探索如何有效实施自动化测试策略,以实现软件开发流程的优化。
39 7
|
9天前
|
数据管理 jenkins 测试技术
自动化测试框架的设计与实现
在软件开发周期中,测试是确保产品质量的关键步骤。本文通过介绍自动化测试框架的设计原则、组件构成以及实现方法,旨在指导读者构建高效、可靠的自动化测试系统。文章不仅探讨了自动化测试的必要性和优势,还详细描述了框架搭建的具体步骤,包括工具选择、脚本开发、执行策略及结果分析等。此外,文章还强调了持续集成环境下自动化测试的重要性,并提供了实际案例分析,以帮助读者更好地理解和应用自动化测试框架。
|
10天前
|
监控 测试技术 定位技术
探索软件测试中的自动化测试框架选择与实施###
本文不概述传统意义上的摘要内容,而是直接以一段对话形式引入,旨在激发读者兴趣。想象一下,你是一名勇敢的探险家,面前摆满了各式各样的自动化测试工具地图,每张地图都指向未知的宝藏——高效、精准的软件测试领域。我们将一起踏上这段旅程,探讨如何根据项目特性选择合适的自动化测试框架,并分享实施过程中的关键步骤与避坑指南。 ###
22 4
|
9天前
|
敏捷开发 测试技术 持续交付
自动化测试之美:从零开始搭建你的Python测试框架
在软件开发的马拉松赛道上,自动化测试是那个能让你保持节奏、避免跌宕起伏的神奇小助手。本文将带你走进自动化测试的世界,用Python这把钥匙,解锁高效、可靠的测试框架之门。你将学会如何步步为营,构建属于自己的测试庇护所,让代码质量成为晨跑时清新的空气,而不是雾霾中的忧虑。让我们一起摆脱手动测试的繁琐枷锁,拥抱自动化带来的自由吧!