【高效】生成人物测试数据!

我们都知道,一款软件被开发出来的过程中一般会经历开发、测试、生产阶段。这三个阶段分别对应了三种环境:

  • 开发环境
  • 测试环境
  • 生产环境

在这三种环境中只有生产环境的数据是真实的,其余两个环境均为测试数据也就是我们常说的假数据。在开发和测试的阶段我们需要大量且合理的假数据。我在刚开始工作的时候只会自己造数据,什么张三、李四、王五。。。造出来的数据不仅不美观而且有很大的局限性!

那么有没有什么方法能生成合理的测试数据呢?

今天来介绍两种方法,能快速的生成一个完整的人物信息!

Faker 工具库

Faker 是一个常用于生成虚假数据的开发工具库,用于开发和测试环境中模拟真实数据。它能生成各种类型的虚假数据,包括姓名、地址、电子邮件地址、电话号码、日期等,来帮助开发人员创建测试数据、填充数据库等任务。

集成Faker(以Maven为例)

xml 复制代码
<dependency>
    <groupId>com.github.javafaker</groupId>
    <artifactId>javafaker</artifactId>
    <version>1.0.2</version> 
</dependency>

service层

新建一个service类,在其中实现调用Faker库的过程。具体写法如下。

controller层

controller接口用于将生成的数据以json格式返回。代码如下。

postman测试

我们可以看到接口返回了一个完整的人物信息。如果想生成中文信息只需要在Faker类构造的时候指定区域。例如:

Faker faker = new Faker(new Locale("zh_CN"));

第三方API

如果不想引入第三方工具库还可以借助第三方API来生成完整的人物信息。例如:

randomuser.me/api/

service层

根据配置文件中的URL来调用第三方API。代码如下。

controller层

postman测试

我们可以看到,返回的测试数据非常完整,甚至包括了人物的头像。

总结

以上就是两种常用的生成人物测试数据的方法,可以生成完整且饱满的人物信息!

更多文章源码,推荐公众号【程序员老J】

相关推荐
廋到被风吹走12 小时前
【数据库】【MySQL】InnoDB外键解析:约束机制、性能影响与最佳实践
android·数据库·mysql
想用offer打牌12 小时前
RocketMQ如何防止消息丢失?
java·后端·架构·开源·rocketmq
掘根12 小时前
【消息队列】交换机数据管理实现
网络·数据库
Logic10112 小时前
《Mysql数据库应用》 第2版 郭文明 实验6 数据库系统维护核心操作与思路解析
数据库·sql·mysql·学习笔记·计算机网络技术·形考作业·国家开放大学
AI Echoes13 小时前
构建一个LangChain RAG应用
数据库·python·langchain·prompt·agent
源码获取_wx:Fegn089513 小时前
基于springboot + vue健身房管理系统
java·开发语言·前端·vue.js·spring boot·后端·spring
@nengdoudou13 小时前
KingbaseES支持 mysql 的find_in_set函数
数据库·mysql
摇滚侠13 小时前
面试实战 问题三十三 Spring 事务常用注解
数据库·spring·面试
梁萌13 小时前
保姆级的MySQL执行计划(Explain)解读
数据库·mysql·explain·执行计划
JIngJaneIL13 小时前
基于Java+ vue智慧医药系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot