新闻资讯

    出品|软件测试网

    项目背景

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

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

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

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

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

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

    java-faker

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

    easy-excel

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

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

    作用类上,生成所有成员变量的/方法,作用于成员变量上,生成该成员变量的/方法获取网站完整源码工具,可以设定访问权限及是否懒加载等。

    代码解析

    代码调用链

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

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

    package org.example.excel.model.emp;import com.alibaba.excel.annotation.ExcelProperty;import lombok.Data;
    //个人信息更新@Datapublic 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…依次递增,第一行第一列的标题名称是*-工号。

    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 empInformationUpdateData(List empList) {
    //构建一个List来存放数据 List list = new ArrayList();
    //使用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存放,通过方法随机取一个值,如下:

        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();    }

    (左右滑动查看完整代码)

    生成随机时间的类

    ("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框架,站在前人的肩膀上,助力测试业务更好的开展。这样子测试的工作才会越走越顺,测试的效率也能够不断的提高~

    End

    -往期回顾-////

网站首页   |    关于我们   |    公司新闻   |    产品方案   |    用户案例   |    售后服务   |    合作伙伴   |    人才招聘   |   

地址:北京市海淀区    电话:010-     邮箱:@126.com

备案号:冀ICP备2024067069号-3 北京科技有限公司版权所有