快速构造性能测试数据的一个方案

2024-03-26 01:58

本文主要是介绍快速构造性能测试数据的一个方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

性能测试脚本中的参数化数据源经常需要准备成千上万甚至更多的数据,例如手机号姓名。

如果通过java代码生成手机号以及姓名的数据工厂呢?

首先实现随机生成中文名,中文名是由姓和名组成的。

分别通过getChineseFamilyName和getChineseGivenName方法随机生成中文的姓和名。

getChineseFamilyName方法具体实现如下

public static String getChineseFamilyName(){

String str = null;

Random random=new Random(System.currentTimeMillis());

/* 598 百家姓 */

String[] Surname= {“赵”,“钱”,“孙”,“李”,“周”,“吴”,“郑”,“王”,“冯”,“陈”,“褚”,“卫”,“蒋”,“沈”,“韩”,“杨”,“朱”,“秦”,“尤”,“许”,

“何”,“吕”,“施”,“张”,“孔”,“曹”,“严”,“华”,“金”,“魏”,“陶”,“姜”,“戚”,“谢”,“邹”,“喻”,“柏”,“水”,“窦”,“章”,“云”,“苏”,“潘”,“葛”,“奚”,“范”,“彭”,“郎”,

“鲁”,“韦”,“昌”,“马”,“苗”,“凤”,“花”,“方”,“俞”,“任”,“袁”,“柳”,“酆”,“鲍”,“史”,“唐”,“费”,“廉”,“岑”,“薛”,“雷”,“贺”,“倪”,“汤”,“滕”,“殷”,

“罗”,“毕”,“郝”,“邬”,“安”,“常”,“乐”,“于”,“时”,“傅”,“皮”,“卞”,“齐”,“康”,“伍”,“余”,“元”,“卜”,“顾”,“孟”,“平”,“黄”,“和”,

“穆”,“萧”,“尹”,“姚”,“邵”,“湛”,“汪”,“祁”,“毛”,“禹”,“狄”,“米”,“贝”,“明”,“臧”,“计”,“伏”,“成”,“戴”,“谈”,“宋”,“茅”,“庞”,“熊”,“纪”,“舒”,

“屈”,“项”,“祝”,“董”,“梁”,“杜”,“阮”,“蓝”,“闵”,“席”,“季”,“麻”,“强”,“贾”,“路”,“娄”,“危”,“江”,“童”,“颜”,“郭”,“梅”,“盛”,“林”,“刁”,“钟”,

“徐”,“邱”,“骆”,“高”,“夏”,“蔡”,“田”,“樊”,“胡”,“凌”,“霍”,“虞”,“万”,“支”,“柯”,“昝”,“管”,“卢”,“莫”,“经”,“房”,“裘”,“缪”,“干”,“解”,“应”,

“宗”,“丁”,“宣”,“贲”,“邓”,“郁”,“单”,“杭”,“洪”,“包”,“诸”,“左”,“石”,“崔”,“吉”,“钮”,“龚”,“程”,“嵇”,“邢”,“滑”,“裴”,“陆”,“荣”,“翁”,“荀”,

“羊”,“于”,“惠”,“甄”,“曲”,“家”,“封”,“芮”,“羿”,“储”,“靳”,“汲”,“邴”,“糜”,“松”,“井”,“段”,“富”,“巫”,“乌”,“焦”,“巴”,“弓”,“牧”,“隗”,“山”,

“谷”,“车”,“侯”,“宓”,“蓬”,“全”,“郗”,“班”,“仰”,“秋”,“仲”,“伊”,“宫”,“宁”,“仇”,“栾”,“暴”,“甘”,“钭”,“厉”,“戎”,“祖”,“武”,“符”,“刘”,“景”,

“詹”,“束”,“龙”,“叶”,“幸”,“司”,“韶”,“郜”,“黎”,“蓟”,“溥”,“印”,“宿”,“白”,“怀”,“蒲”,“邰”,“从”,“鄂”,“索”,“咸”,“籍”,“赖”,“卓”,“蔺”,“屠”,

“蒙”,“池”,“乔”,“阴”,“郁”,“胥”,“能”,“苍”,“双”,“闻”,“莘”,“党”,“翟”,“谭”,“贡”,“劳”,“逄”,“姬”,“申”,“扶”,“堵”,“冉”,“宰”,“郦”,“雍”,“却”,

“璩”,“桑”,“桂”,“濮”,“牛”,“寿”,“通”,“边”,“扈”,“燕”,“冀”,“浦”,“尚”,“农”,“温”,“别”,“庄”,“晏”,“柴”,“瞿”,“阎”,“充”,“慕”,“连”,“茹”,“习”,

“宦”,“艾”,“鱼”,“容”,“向”,“古”,“易”,“慎”,“戈”,“廖”,“庾”,“终”,“暨”,“居”,“衡”,“步”,“都”,“耿”,“满”,“弘”,“匡”,“国”,“文”,“寇”,“广”,“禄”,

“阙”,“东”,“欧”,“殳”,“沃”,“利”,“蔚”,“越”,“夔”,“隆”,“师”,“巩”,“厍”,“聂”,“晁”,“勾”,“敖”,“融”,“冷”,“訾”,“辛”,“阚”,“那”,“简”,“饶”,“空”,

“曾”,“毋”,“沙”,“乜”,“养”,“鞠”,“须”,“丰”,“巢”,“关”,“蒯”,“相”,“查”,“后”,“荆”,“红”,“游”,“郏”,“竺”,“权”,“逯”,“盖”,“益”,“桓”,“公”,“仉”,

“督”,“岳”,“帅”,“缑”,“亢”,“况”,“郈”,“有”,“琴”,“归”,“海”,“晋”,“楚”,“闫”,“法”,“汝”,“鄢”,“涂”,“钦”,“商”,“牟”,“佘”,“佴”,“伯”,“赏”,“墨”,

“哈”,“谯”,“篁”,“年”,“爱”,“阳”,“佟”,“言”,“福”,“南”,“火”,“铁”,“迟”,“漆”,“官”,“冼”,“真”,“展”,“繁”,“檀”,“祭”,“密”,“敬”,“揭”,“舜”,“楼”,

“疏”,“冒”,“浑”,“挚”,“胶”,“随”,“高”,“皋”,“原”,“种”,“练”,“弥”,“仓”,“眭”,“蹇”,“覃”,“阿”,“门”,“恽”,“来”,“綦”,“召”,“仪”,“风”,“介”,“巨”,

“木”,“京”,“狐”,“郇”,“虎”,“枚”,“抗”,“达”,“杞”,“苌”,“折”,“麦”,“庆”,“过”,“竹”,“端”,“鲜”,“皇”,“亓”,“老”,“是”,“秘”,“畅”,“邝”,“还”,“宾”,

“闾”,“辜”,“纵”,“侴”,“万俟”,“司马”,“上官”,“欧阳”,“夏侯”,“诸葛”,“闻人”,“东方”,“赫连”,“皇甫”,“羊舌”,“尉迟”,“公羊”,“澹台”,“公冶”,“宗正”,

“濮阳”,“淳于”,“单于”,“太叔”,“申屠”,“公孙”,“仲孙”,“轩辕”,“令狐”,“钟离”,“宇文”,“长孙”,“慕容”,“鲜于”,“闾丘”,“司徒”,“司空”,“兀官”,“司寇”,

“南门”,“呼延”,“子车”,“颛孙”,“端木”,“巫马”,“公西”,“漆雕”,“车正”,“壤驷”,“公良”,“拓跋”,“夹谷”,“宰父”,“谷梁”,“段干”,“百里”,“东郭”,“微生”,

“梁丘”,“左丘”,“东门”,“西门”,“南宫”,“第五”,“公仪”,“公乘”,“太史”,“仲长”,“叔孙”,“屈突”,“尔朱”,“东乡”,“相里”,“胡母”,“司城”,“张廖”,“雍门”,

“毋丘”,“贺兰”,“綦毋”,“屋庐”,“独孤”,“南郭”,“北宫”,“王孙”};

int index=random.nextInt(Surname.length-1);

str = Surname[index]; //获得一个随机的姓氏

return str;

}

getChineseGivenName方法具体实现如下

public static String getChineseGivenName() {

String str = null;

int highPos, lowPos;

Random random = new Random();

highPos = (176 + Math.abs(random.nextInt(71)));//区码,0xA0打头,从第16区开始,即0xB0=11*16=176,1655一级汉字,5687二级汉字

random=new Random();

lowPos = 161 + Math.abs(random.nextInt(94));//位码,0xA0打头,范围第1~94列

byte[] bArr = new byte[2];

bArr[0] = (new Integer(highPos)).byteValue();

bArr[1] = (new Integer(lowPos)).byteValue();

try {

str = new String(bArr, “GB2312”);//区位码组合成汉字

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

return str;

}

接下来实现生成手机号。一般手机号都是以130、186等等号段开始的11位阿拉伯数字组成。因此可以定义长整型变量。

例如定义186号段的手机号。

long mobileL = 18600000000L;

如何生成大量不重复的姓名以及手机号呢?通过循环来实现。

接下来需要实现的是文件的写入操作。writeContent方法实现的将指定的字符串写入到指定路径的文件名中,是否追加式写入设置为true。

writeContent方法具体实现如下

public static boolean writeContent(String c, String path, boolean isAppend) {

//File f = new File(path);

try {

FileOutputStream fos = new FileOutputStream(path, isAppend);

OutputStreamWriter writer = new OutputStreamWriter(fos, “UTF-8”);

writer.write©;

writer.close();

fos.close();

} catch (IOException e) {

e.printStackTrace();

return false;

}

return true;

}

最后在入口函数main通过循环调用姓名方法以及手机号变量累加实现批量产生数据。

定义mobileL、name、familyNameStr、filepath4个变量分别存放手机号、姓名、中文姓、文件路径。通过循环1000次生成1000条手机号、姓名记录。

main方法具体实现如下

public static void main(String[] args) {

long mobileL = 18600000000L;

String name = “”;

String familyNameStr="";

String filepath = “E:\data\NameMobile.txt”;

for(int j=1;j<1001;j++){

mobileL = mobileL + 1L;

Random random = new Random(System.currentTimeMillis());

Boolean flag = random.nextBoolean();//随机标识

familyNameStr = getChineseFamilyName();

name = familyNameStr;

if(flag){//true,则名2个汉字

name += getChineseGivenName()+getChineseGivenName();

}else {//false,则名1个汉字

name += getChineseGivenName();

}

    writeContent(name+","+mobileL+" ",filepath,true);

}

}

注意,文件路径一定要存在,否则会报类似如下错误:

java.io.FileNotFoundException: E:dataNameMobile.txt (系统找不到指定的路径。)

运行代码生成数据如下所示
在这里插入图片描述
作  者:Testfan 彩虹
出  处:微信公众号:自动化软件测试平台
版权说明:欢迎转载,但必须注明出处,并在文章页面明显位置给出文章链接

这篇关于快速构造性能测试数据的一个方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/846950

相关文章

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

解决docker目录内存不足扩容处理方案

《解决docker目录内存不足扩容处理方案》文章介绍了Docker存储目录迁移方法:因系统盘空间不足,需将Docker数据迁移到更大磁盘(如/home/docker),通过修改daemon.json配... 目录1、查看服务器所有磁盘的使用情况2、查看docker镜像和容器存储目录的空间大小3、停止dock

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺

C#实现高性能拍照与水印添加功能完整方案

《C#实现高性能拍照与水印添加功能完整方案》在工业检测、质量追溯等应用场景中,经常需要对产品进行拍照并添加相关信息水印,本文将详细介绍如何使用C#实现一个高性能的拍照和水印添加功能,包含完整的代码实现... 目录1. 概述2. 功能架构设计3. 核心代码实现python3.1 主拍照方法3.2 安全HBIT

Docker多阶段镜像构建与缓存利用性能优化实践指南

《Docker多阶段镜像构建与缓存利用性能优化实践指南》这篇文章将从原理层面深入解析Docker多阶段构建与缓存机制,结合实际项目示例,说明如何有效利用构建缓存,组织镜像层次,最大化提升构建速度并减少... 目录一、技术背景与应用场景二、核心原理深入分析三、关键 dockerfile 解读3.1 Docke

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除