您的位置 首页 java

工具推荐:如何通过代码构造Excel测试数据?

项目背景

系统有个Excel导入功能,需要通过Excel来构造 测试 数据,生成测试数据之后,上传Excel并导入验证。

工具推荐:如何通过代码构造Excel测试数据?

如果数据验证出错,需要给出错误提示;如果数据校验通过,则执行导入操作。

我们主要通过 Alibaba 的Easy Excel框架来做。

期望的生成Excel数据模板如下:

工具推荐:如何通过代码构造Excel测试数据?

生成了人员的工号、姓名、证件类型、身份证、民族等等字段。

这里我们使用 Java 语言,用到的工具类如下:

java-faker

构造测试数据时,需要绞尽脑汁浪费时间,JavaFaker可以释放你的生产力。

easy-excel

easy-excel重写了poi对07版Excel的解析,能够原本一个3M的Excel用POI sax依然需要100M左右内存降低到几M,并且再大的Excel不会出现内存溢出。

03版依赖POI的sax模式,在上层做了模型转换的封装,让使用者更加简单方便。

lombok

作用类上,生成所有成员变量的getter/setter方法,作用于成员变量上,生成该成员变量的getter/setter方法,可以设定访问权限及是否懒加载等。

代码解析

代码调用链

工具推荐:如何通过代码构造Excel测试数据?

我们先从最底层的Model层来说:以一个项目模板为例,构建Model,此时一个Excel的sheet,就对应一个model。

这里我们需要注意的是 @ Excel Ignore 和 @ExcelProperty注解:

·@ExcelIgnore表示忽略该字段

·@ExcelProperty表示设置字段名称、第几列

package org.example.excel.model.emp;

import com.alibaba.excel.annotation.ExcelProperty;

import lombok.Data;

//个人信息更新

@Data

public class EmpInformationUpdateModel {

@ExcelProperty(value = “*F00730-工号”, index = 0)

private String empJobNumber;

@ExcelProperty(value = “*F00719-姓名”, index = 1)

private String empName;

@ExcelProperty(value = “*F00721-英文名”, index = 2)

private String foreignName;

@ExcelProperty(value = “F00741-昵称”, index = 3)

private String nickName;

@ExcelProperty(value = “*F00370-性别”, index = 4)

private String gender;

@ExcelProperty(value = “*F00392-国籍”, index = 5)

private String nationality;

@ExcelProperty(value = “*F00720-证件类型”, index = 6)

private String idCardType;

@ExcelProperty(value = “*F00717-证件号码”, index = 7)

private String idCardNumber;

}

Model层和Excel的列是一一对应的,以下面的注解为例子:

@ExcelProperty(value = “*F00730-工号”, index = 0)

第一行是标题头,第一行第一列的位置由0来表示,0,1,2,3,4…依次递增,第一行第一列的标题名称是*F00730-工号。

Service层

package org.example.excel.change;

import com.github.javafaker.Faker;

import org.example.excel.ExceptionTransferImport;

import org.example.excel.constant.ChangeConstant;

import org.example.excel.model.Employee;

import org.example.excel.model.emp.EmpInformationUpdateModel;

import org.example.excel.util.IdCardGenerator;

import java.util.ArrayList;

import java.util.List;

import java.util. Locale ;

import java.util.Random;

import java.util.logging.Logger;

import static org.example.excel.util.RandomDateUtil.randomDate;

//个人信息更新

public class EmpInformationUpdate {

//日志 记录

static java .util.logging.Logger logger = Logger.getLogger(“com.hongtao.flywheel”);

//调用Model层的函数

public static List<EmpInformationUpdateModel> empInformationUpdateData(List<Employee> empList) {

//构建一个List来存放数据

List<EmpInformationUpdateModel> list = new ArrayList<EmpInformationUpdateModel>();

//使用java-faker框架,来生成随机姓名,身份证

Faker FAKER = new Faker(Locale.CHINA);

Faker FAKEREN = new Faker(Locale.ENGLISH);

IdCardGenerator idCardGenerator = new IdCardGenerator();

//构建for循环,控制生成测试数据的条数

for (int i = 0; i < ExceptionTransferImport.CYCLESNUMBER; i++) {

//调用了Model层,表示生成的单条数据的类型,和Model类一致

EmpInformationUpdateModel data = new EmpInformationUpdateModel();

data.setEmpName(empList.get(i).getEmpName());

data.setEmpJobNumber(empList.get(i).getEmpJobNumber());

//使用java-faker框架,来生成随机姓名,身份证

data.setForeignName(FAKEREN.name().lastName() + new Random().nextInt(50));

data.setNickName(FAKEREN.name().lastName() + new Random().nextInt(50));

//下面都是调用 数据字典 类数据

data.setIdCardType(new ChangeConstant().getValue(ChangeConstant.idCardType));

data.setNationality(new ChangeConstant().getValue(ChangeConstant.nationality));

data.setNation(new ChangeConstant().getValue(ChangeConstant.nation));

//List链表增加一条数据

list.add(data);

}

//返回 链表

return list;

}

}

数据字典类解析:配置数据字典,因为在有些数据是固定值,需要随机选择数据,所以用list来存储这些数据字典。

(new ChangeConstant().getValue(ChangeConstant.contractType);

这句话是为了随机获取一个存在List内的数据字典。

数据字典也是用list存放,通过getValue方法随机取一个值,如下:

public static final List idCardType = Arrays.asList(” 中国护照 “, “台湾居民来往大陆通行证”, “外国护照”, “居民身份证”, “港澳居民来往内地通行证”);

public static final List gender = Arrays.asList(“男”, “女”);

public String getValue(List list) {

Random random = new Random();

int n = random.nextInt(list.size());

return list.get(n).toString();

}

生成随机时间的类

randomDate(“2020-01-01”, “2022-01-01”)是随机生成在开始时间和结束时间范围内的一个日期值,函数如下:

public static String randomDate(String beginDate,String endDate){

try {

SimpleDateFormat format = new SimpleDateFormat(“yyyy-MM-dd”);

Date start = format.parse(beginDate);

Date end = format.parse(endDate);

if(start.getTime() >= end.getTime()){

return null;

}

long date = random(start.getTime(),end.getTime());

String dateString=

asLocalDate(longToDate(date)).format(DateTimeFormatter.ofPattern(“yyyy-MM” +

“-dd”));

return dateString;

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

java-faker的用法

可以生成随机的姓名、街道、公司、天气、超级英雄、星球大战等等等等。

data.setForeignName(FAKEREN.name().lastName());

data.setLuckyName(FAKER.funnyName().name());

结合起来

调用Easy Excel框架,生成Excel的方法,Main函数生成数据:

String updateContractChangeFileName =

TestFileUtil.getPath() + “个人信息更新”+”.xlsx”;

EasyExcel.write(updateContractChangeFileName,

UpdateContractChangeModel.class).sheet(“模板”).doWrite(UpdateContractChange.updateContractChangeData(empInfomationList));

结果展示

总结

在工作当中,我们经常遇到批量生成测试数据的需求,所以这个时候,我们可以借鉴网上成熟的生成随机数据方法,Java-Faker框架,很方便的构造测试数据。

再结合业务上的需求,引入了 阿里巴巴 的Easy Excel框架,站在前人的肩膀上,助力测试业务更好地开展。这样子测试的工作才会越走越顺,测试的效率也能够不断地提高~

我是谁?

我是一名从事了多年 软件测试 的老测试员,今年年初我花了一个月整理了一份最适合2020年学习的软件测试学习干货,可以送给每一位对软件测试感兴趣的小伙伴,想要获取的可以 关注我的 头条号 并在后台私信我:【头条】 ,即可免费获取。

文章来源:智云一二三科技

文章标题:工具推荐:如何通过代码构造Excel测试数据?

文章地址:https://www.zhihuclub.com/198945.shtml

关于作者: 智云科技

热门文章

评论已关闭

5条评论

  1. I appreciate, cause I found just what I was looking for. You have ended my 4 day long hunt! God Bless you man. Have a nice day. Bye

网站地图