利用Excel支持JUnit参数化测试

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

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

XML 复制代码
<dependency>
  <groupId>com.excelbdd</groupId>
  <artifactId>excelbdd-java</artifactId>
  <version>1.4.1</version>
</dependency>

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

参数化测试代码如下

java 复制代码
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指南https://blog.csdn.net/zhangmike/article/details/133815589?spm=1001.2014.3001.5501

ExcelBDD Guideline By Java Examplehttps://blog.csdn.net/zhangmike/article/details/118197580

相关推荐
樱花味的小奶牛8 分钟前
DECLARE CURSOR 才允许使用 FOR UPDATE 子句
数据库·sql
雁凡彡10 分钟前
mybatis-plus中sqlserver 查询数组中指定位置前的数据
数据库·sqlserver·mybatis
问今域中28 分钟前
Spring Security登录认证
数据库·sql·oracle
开开心心_Every29 分钟前
免费进销存管理软件:云端本地双部署
java·游戏·微信·eclipse·pdf·excel·语音识别
JOEH601 小时前
🚀 数据库插入 1000 万数据?别再傻傻用 for 循环了!实测 5 种方式效率对比
数据库·后端
lllsure1 小时前
【MySQL】数据分片
数据库·mysql
语落心生1 小时前
深入doris查询计划以及io调度(五)列式存储结构 - 分析Segment格式、列数据编码
数据库
Kasen's experience1 小时前
Excel 怎么快速合并同一个ID不同行的大量相同单元格
excel
DBA小马哥1 小时前
金仓数据库 vs 达梦:MySQL迁移谁更胜一筹?
数据库·mysql·金仓数据库·kes
Luna-player2 小时前
那个在DG数据库中将多行指定字段的文本替换操作
数据库