自动化测试3:Junit单元测试框架

本文介绍了JUnit5中的关键注解,如@Test、@Disabled、@BeforeAll和@AfterEach,以及如何进行参数化测试,包括单参数、多参数和使用CSV文件及方法来传递参数。还讨论了测试执行的顺序控制,包括按指定顺序和随机执行。此外,文章还涉及到了断言的使用以及如何组织测试套件,包括通过类和包来运行测试用例。
摘要由CSDN通过智能技术生成

目录

1.相关技术

1.1注解

1.1.1@Test

1.1.2@Disables 忽略

1.1.3@BeforeAll @AfterAll

1.1.4@BeforeEach @AfterEach

1.2参数化

1.2.1单参数

1.2.2多参数

1.2.3CSV获取参数

1.2.4方法获取参数

1.3运行顺序

1.3.1问题

1.3.2按指定顺序执行

1.3.3随机执行

1.4.断言

2.测试套件

2.1通过class运行测试用例

2.2通过包运行测试用例


1.相关技术

1.1注解

1.1.1@Test

表示当前的这个方法是一个测试用例

要引入依赖(中央仓库-->junit-->JUnit Jupiter API » 5.9.1)

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

@Test
void Test01(){
    System.out.println("这是Junit中Test01");
}

1.1.2@Disables

忽略不运行这个测试用例

@Disabled
    void Test02(){
        System.out.println("这是Junit中Test01");
    }

1.1.3@BeforeAll @AfterAll

方法前要加static

@BeforeAll:在运行其他所有测试用例之前运行 只运行一次      一般存放连接,开启   

@AfterAll:在运行其他所有测试用例之后运行 只运行一次       一般存放关闭

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

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

 

1.1.4@BeforeEach @AfterEach

@BeforeEach 在运行每一个测试用例之前运行 有几个测试用例运行几次

@AfterEach 在运行每一个测试用例之后运行 有几个测试用例运行几次

@BeforeEach
    void SetUp(){
        System.out.println("这是BeforeAll的语句");
    }

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

 

1.2参数化

 引入依赖 中央仓库-->Parameterized-->JUnit Jupiter Params » 5.9.1

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

1.2.1单参数

@ParameterizedTest

@ValueSource(类型+s={,,,})

@ParameterizedTest
    @ValueSource(ints={1,2,3})
    void Test04(int num){
        System.out.println(num);
    }

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

 

1.2.2多参数

@ParameterizedTest

@CsvSource({,,,})

@ParameterizedTest
    @CsvSource({"1,2,3"})
    void Test06(String x,String y,String z){
        System.out.println(x);
        System.out.println(y);
        System.out.println(z);
    }

 

1.2.3CSV获取参数

@ParameterizedTest

@CsvFileSource(resources="  文件名.csv")

@ParameterizedTest  //运行几次取决于csv有几行
@CsvFileSource(resources = "test01.csv")//这个文件必须以csv结尾
  void Test06(String name){
    System.out.println(name);
}

test01.csv

张三1. 李四1. 王五1
张三2. 李四2. 王五2
张三3. 李四3. 王五3

 

1.2.4方法获取参数

@ParameterizedTest

@MethodSource("Generator")

测试数据:

public static Stream<Arguments> Genertor(){

return Stream.of(Arguments.arguments(),

Arguments.arguments(),

Arguments.arguments(),...

);
}

@ParameterizedTest
@MethodSource("Generator")
//接收
 void Test07(int num,String name){
    System.out.println(num+" : "+name);
}
//测试数据
public static Stream<Arguments> Generator(){
    return Stream.of(Arguments.arguments(1,"张三"),
            Arguments.arguments(2,"李四"),
            Arguments.arguments(3,"王五")
     );
}

 

1.3运行顺序

1.3.1问题

更改代码顺序,不改变运行顺序

执行顺序固定:Junit有自己固定的执行顺序

 

 

1.3.2按指定顺序执行

类前加注解@TestMethodOrder(MethodOrder.OrderAnnotation.class)

每个用例前加@Order(i) 在第i个执行,i从1开始

 

 

1.3.3随机执行

@TestMethodOrder(MethodOrder.Random.class)

 

1.4.断言

//断言相等
Assertions.assertEquals(1,num);
//断言不相等
Assertions.assertNotEquals(2,num);
String str=null;
//断言为空
Assertions.assertNull(str);
//断言不为空
String str1="null1";
Assertions.assertNotNull(str1);

2.测试套件

引入依赖

<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>
        <!-- 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>
        </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 -->
        <dependency>
            <groupId>org.junit.platform</groupId>
            <artifactId>junit-platform-suite</artifactId>
            <version>1.9.1</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.junit.jupiter/junit-jupiter-engine -->
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-engine</artifactId>
            <version>5.9.1</version>
            <scope>test</scope>
        </dependency>

2.1通过class运行测试用例

@Suite
//通过class测试用例执行
@SelectClasses({JunitTest.class,JunitTest01.class,JunitTest02.class})//规定执行顺序
public class RunSuite {
}

 

2.2通过包运行测试用例

@Suite
@SelectPackages(value ={"Package01","Package02"})
public class RunSuite {
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值