• 15
  • 15
分享
  • 工具推荐:通过代码构造Excel测试数据——软件测试圈
  • 曼倩诙谐 2021-09-28 09:55:46 字数 5650 阅读 1352 收藏 15

  项目背景

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

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

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

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

1-1.png


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

  这里我们使用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方法,可以设定访问权限及是否懒加载等。

  代码解析

  代码调用链

1-2.png


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

  这里我们需要注意的是 @ExcelIgnore 和 @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));

  结果展示

1-3.png

  总结

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

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



作者:Henry   

来源:http://www.51testing.com/html/26/n-4478726.html

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 一、先来看最优效果要达到该点,在做接口测试前,做为测试者,我们需要非常明确自己选择测试工具去达到的核心目的。通常情况下可能有以下几个:这里不仅仅只是说明了全流程自动化接口测试实现方案,对于常规的接口测试也进行了罗列开发者调试接口测试人员提前介入测试,尽早发现程序缺陷测试人员对于系统接口回归,确保后台逻辑无缺陷,降低版本迭代风险如是情况1或者2,在实际的项目开发过程中,这其中的空余时间不固定且零散,按照这样的预期,我们期望接口测试工具更为便捷,可以快速的配置出接口测试脚本或用例。这类接口自动化测试工具有:1、PostmanPostman工具的优势清晰的图形界面;结合界面操作可以快速的配置接口请求...
            0 0 3348
            分享
          •   随着中国IT业的发展和软件市场的不断成熟,国内人工智能(AI)、物联网、大数据、云计算等IT产业得到了迅速发展。但是,目前中国软件产业在产品功能和性能测试等领域还存在着严重不足。根据Gartner的预测:到2022年,IT行业的开发总成本将从3.76万亿美元增涨至3.87万亿美元。而到了2023年,全球相应的软件测试市场,预计将出现14%的综合年度增涨率。软件市场不断扩大,越来越多的企业认识到软件测试的重要性。在未来,如何应对快速发展的技术变革,是测试行业和测试人员需要面对的挑战。  调查目的  51Testing以测试行业为分析对象,以真实数据为依据,从软件测试从业人员所在公司的基本属性...
            13 13 868
            分享
          •       自2018年被评选为编程语言以来,Python在各大排行榜上一直都是名列前茅。目前,它在Tiobe指数中排名第三个,仅次于Java和C。随着该编程语言的广泛使用,基于Python的自动化测试框架也应运而生,且不断发展与丰富。      因此,开发与测试人员在为手头的项目选择测试框架时,需要考虑许多方面的因素,其中包括:框架的脚本质量,测试用例的简单性,以及运行模块可能存在的技术弱点。为了避免出现“选择困难症”,我在此为大家准备了五种Python类型的自动化测试框架,以供比较和讨论。      ...
            13 12 2897
            分享
          •   苹果公司的 AirPods 产品线将在未来一年经历多次变革,因为该公司试图以一种更合理的方式完善其提供给消费者的产品。一份报告称,苹果公司将在 2024 年更新 AirPods 产品,包括两款超值版 AirPods 和 AirPods Max。  在周日为彭博社撰写的"Power On"时事通讯中,马克-古尔曼(Mark Gurman)重申了关于 2024 年 AirPods 产品线变化的一些说法,在 10 月份早些时候的大修说法之后,他加倍强调了产品线的变化。  最新报道称,苹果将生产两个版本的低端 AirPods,这可能会解决该产品线的营销问题。目前售价 179 美...
            0 0 1214
            分享
          •   苹果公司CEO蒂姆?库克在接受《早安美国》节目的采访时表示,他使用了ChatGPT这款聊天机器人,并对其感到兴奋。他还透露,苹果正在密切关注这项技术,并有一些独特的应用场景。  ChatGPT是由OpenAI开发的一款基于生成式人工智能(generativeAI)的聊天机器人,可以与人类进行自然的对话。据报道,今年早些时候,苹果公司出于隐私方面的考虑,限制了员工使用ChatGPT。  当被问及是否使用OpenAI的聊天机器人时,库克称:“哦,我当然使用它。是的,我对它很兴奋。我认为它有一些独特的应用,你可以相信这是我们正在密切关注的东西。”  库克对人工智能和生成式人工智能持谨慎态度,而其...
            0 0 861
            分享
      • 51testing软件测试圈微信