JUNIT 5自定义JSON数据源类

本文介绍了如何在JUNIT 5中创建自定义注解以使用JSON数据源进行测试。通过加入相关依赖,定义注解并实现其逻辑,可以将复杂的JSON数据解析为实体类参数,用于测试类的参数化测试。
摘要由CSDN通过智能技术生成

Junit file 普遍能自定义数据源比如org.junit.jupiter.params.provider.CsvFileSource能自定义输入CSV,并将CSV每一行传入参数,实现参数自由。

那么如果我们的测试数据是复杂的数据,需要用JSON来解析,让测试类传值用实体类呢

加入依赖

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

定义注解

@Target({
   ElementType.ANNOTATION_TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@API(
    status = Status.EXPERIMENTAL,
    since 
如果你想让程序在测试过程中能够动态接收来自测试人员的数据,而不是硬编码在程序里,你可以考虑以下几种方法: 1. **命令行参数**:允许测试人员通过命令行传参,例如在运行测试时指定一个包含数据的文件路径。你可以使用`System.getProperty`或`args`获取这些参数。例如,在Java中,可以使用`args`来读取命令行参数: ```java public static void main(String[] args) { String filePath = args[0]; // 假设第一个参数是数据文件路径 List<Double> data = readDataFromExcel(filePath); // 自定义方法从Excel中读取数据 // 进行数据分析和判断 } ``` 2. **文件输入**:创建一个读取文本文件或CSV文件的工具,测试人员可以把数据导出到这样的文件中,然后程序读取这个文件。可以使用Java的`Scanner`或第三方库如`Apache Commons CSV`来解析文件。 3. **Excel API**:如果你的应用支持,可以利用像`Apache POI`这样的库来读取Excel文件,测试人员可以直接将数据填入Excel表格,然后程序加载整个工作表进行操作。 4. **数据驱动测试**:如果你正在使用测试框架如JUnit或TestNG,它们通常提供数据驱动测试的能力,比如使用`@DataProvider`注解,通过外部数据源(如XML或JSON文件)为每个测试案例提供数据。 无论是哪种方法,都需要为读取数据的部分编写健壮的异常处理,以应对文件不存在、格式错误等情况。同时,为了方便测试人员,最好提供清晰的文档说明如何准备和提交数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值