利用Excel支持JUnit参数化测试

news/2024/7/21 5:50:01 标签: excel, junit, 数据库

在JUnit里面,可以使用CsvFileSource读取csv文件进行参数化测试,可是CSV文件不支持格式,编辑颇为麻烦,尤其是多次编辑,因此自然想到是否可以使用Excel文件,可以有各种格式,支持各类数据。

最新开源组件ExcelBDD提供了此功能,其maven导入代码如下

<dependency>
  <groupId>com.excelbdd</groupId>
  <artifactId>excelbdd-java</artifactId>
  <version>1.4.1</version>
</dependency>

对于如下样子的Excel里面表格

参数化测试代码如下

import java.util.Map;
import org.junit.jupiter.params.ParameterizedTest;

import com.excelbdd.ExcelFileSource;
import com.excelbdd.TestWizard;
import static org.junit.jupiter.api.Assertions.*;
    ......
    @ParameterizedTest
	@ExcelFileSource(file = "excelbdd/DataTable.xlsx", sheet = "DataTable2")
	void testGetDateFromExcelTable(Map<String, String> parameterMap) {
		TestWizard w = new TestWizard(parameterMap);
		assertEquals("Value1", w.get("Header01").substring(0, 6));
		assertEquals("Value2", w.get("Header02").substring(0, 6));
//      ......
		assertEquals("Value8", w.get("Header08").substring(0, 6));
//		real test automation implementation
	}

@ExcelFileSource有五个参数:

file 文件名,缺省以resources为相对基准

brotherFolder 兄弟路径,改变相对基准到此路径的上级,一般不需要用

sheet Excel里面Sheet名称,缺省是第1个

headerRow 标题列,缺省第1行,一般不需要用

startColumn 数据区第1列在哪里,缺省是从第1列开始自动搜索数据区,一般不需要用

ExcelBDD的功能不止于使用Excel作为参数化测试来源,更加主要的功能是支持BDD,也是SBE。

参见 ExcelBDD Python指南icon-default.png?t=N7T8https://blog.csdn.net/zhangmike/article/details/133815589?spm=1001.2014.3001.5501

ExcelBDD Guideline By Java Exampleicon-default.png?t=N7T8https://blog.csdn.net/zhangmike/article/details/118197580


http://www.niftyadmin.cn/n/5124532.html

相关文章

OV5640 低功耗使用说明- PowerDown模式

目录 前言 低功耗模式 硬件设计 软件操作 总结 前言 OV5640在拍照时功耗是很大的&#xff0c;如果不是需要做持续的视频流应用的话&#xff0c;比如间隔一定时间&#xff0c;捕获一帧&#xff0c;可以平时将摄像头睡眠&#xff0c;使用的时候再唤醒&#xff0c;拍完再睡&a…

51单片机实验:数码管动态显示00-99

1、实验要求 利用STC89C52RC单片机开发板实现&#xff1a;使用2位数码管循环显示00-99&#xff0c;每次间隔1s&#xff0c;并且当计数到20时&#xff0c;则蜂鸣器鸣响1次。 2、实验分析 程序实现分析&#xff1a; 1、定义数码管位选引脚&#xff08;P2.4、P2.5、P2.6、…

js 随机生成大小写字母数字16位数

const length 16const characters ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789let result for (let i 0; i < length; i) {result characters.charAt(Math.floor(Math.random() * characters.length))}

华为---DHCP中继代理简介及示例配置

DHCP中继代理简介 IP动态获取过程中&#xff0c;客户端&#xff08;DHCP Client&#xff09;总是以广播&#xff08;广播帧及广播IP报文&#xff09;方式来发送DHCPDISCOVER和DHCPREQUEST消息的。如果服务器&#xff08;DHCP Server&#xff09;和 客户端不在同一个二层网络(二…

NPM / 错误:EACCES:权限被拒绝

项目打包时报错&#xff1a; > fancy-name0.0.0 build:prod > npm run build -- --configuration production --aot --optimizationfalseglob error [Error: EACCES: permission denied, scandir /root/.npm/_logs] {errno: -13,code: EACCES,syscall: scandir,path: /r…

c:变参函数:汇编解析;va_list;marco 宏:__VA_ARGS__

文章目录 参考gcc 内部的宏定义代码汇编调用在 SEI CERT C Coding Standard 这个标准里示例实例宏里的使用 参考 https://git.sr.ht/~gregkh/presentation-security/blob/3547183843399d693c35b502cf4a313e256d0dd8/security-stuff.pdf gcc 内部的宏定义 宏定义&#xff1a;…

提升技能,一触即达!全新在线题库微信小程序等你来挑战!

亲爱的同学们&#xff0c;你是否在准备各种专业认证考试时&#xff0c;感到题目繁多&#xff0c;复习困难&#xff1f;你是否在寻找一个能够提供全方位、各级别认证考试题库的在线学习平台&#xff1f; 今天&#xff0c;我们为你带来了一款全新的在线题库微信小程序——KD蝌蚪阿…

Java 生成和读取JSON文件

下面的demo当中 &#xff0c;是将json文件放到了zip包当中。如果不需要&#xff0c;可以拿掉。 1、生成对象JSON文件 public static void crateJson() {try {String orcPath "D:\\doc\\ts_service_orchestration.json";// 对象集合或者对象都可以List<DataPO>…