利用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

相关推荐
数据库幼崽18 分钟前
MySQL 8.0 OCP 1Z0-908 51-60题
数据库·mysql·ocp
我叫珂蛋儿吖32 分钟前
[redis进阶六]详解redis作为缓存&&分布式锁
运维·c语言·数据库·c++·redis·分布式·缓存
小L爱科研1 小时前
4.7/Q1,GBD数据库最新文章解读
数据库·机器学习·数据分析·回归·健康医疗
GUIQU.1 小时前
【MySQL】函数
数据库·mysql
chennalC#c.h.JA Ptho1 小时前
kubuntu系统详解
linux·数据库·经验分享·postgresql·系统安全
DavieLau2 小时前
Python开发后端InfluxDB数据库测试接口
服务器·数据库·python·时序数据库
悟能不能悟2 小时前
关于 javax.validation.constraints的详细说明
数据库·mysql
.生产的驴2 小时前
Docker 部署Nexus仓库 搭建Maven私服仓库 公司内部仓库
java·运维·数据库·spring·docker·容器·maven
知行022 小时前
MySQL的Docker版本,部署在ubantu系统
数据库·mysql·docker