在测试某个功能前,需要准备测试数据是不可或缺的步骤,最原始准备测试数据基于GUI操作生成测试数据,哪还有其他方式准备测试数据吗?现在很多WEB和APP应用使用前后端分离方式,前端获取服务端数据通过调用APP接口方式,我们也可以通过调用API接口生成测试数据,把准备数据服务作为一个小小终端。
我们都知道数据是存储在数据库中,我们也可以通过对数据库进行CURD操作生成测试数据。另外调用API接口生成数据,可能造成部分数据不够齐全,这时候使用数据库操作补全数据。
总结,准备测试数据有四个方法:
- 基于GUI操作生成测试数据。
- 通过API调用生成测试数据。
- 通过数据库操作生成测试数据。
- 综合运用API和数据库方式生成测试数据。
接下来粗略谈谈这四种实现方式:
基于GUI操作生成测试数据
基于GUI操作生成测试数据,是最原始创建测试数据方法。测试员采用E2E执行业务场景来生成数据。这种方法是简单直接,同时,效率也低。
通过API调用生成测试数据
通过API调用生成测试数据,是目前主流的测试数据生成方法。我们使用GUI界面生成测试数据,其实是依次调用后端API接口来生成数据。我们知道每个业务逻辑
需要把测试数据进行封装成测试数据准备函数,然后调用API,具体实现后续讲解。
通过数据库操作生成测试数据
通过数据库操作生成测试数据,直接对数据库进行CRUD操作。需要熟悉每个业务需要对哪些数据表进行操作,其次,熟悉SQL语句编写。
综合运用API和数据库方式生成测试数据
先通过API调用生成基础的测试数据,然后使用映射对数据库的CRUD操作,这些都可以用代码实现。
现在重点讲解使用API生成测试数据准备方式。使用GUI方式准备数据时,在页面输入数据基本是某个实体的属性(Field),调用API接口请求参数也是某个实体的属性。
通过代码方式生成测试数据时,首先构建实体,把实体作为参数传进给API接口。在准备测试数据大部分属性可以使用参数默认值,只有个别参数不一样,推荐Builder模式来完成,如果想了解Builder Pattern,可以在维基百科查看。
使用Builder Pattern方式准备测试数据,流程如下:
Model > Build > Manipulation > Creation
Model
创建Model,可以选择根据数据库字段创建Model的Field。
public class User {
private Long id;//id
private String username;//用户名
private String email;//邮箱
private Integer vip;//是否是vip,0-不是,1-是
private Integer sex;//性别,1-女,2-男
public User() {};
public User(Long id, String username) {
this.id = id;
this.username = username;
}
public User(Long id, String username, String email) {
this.id = id;
this.username = username;
this.email = email;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public Integer getVip() {
return vip;
}
public void setVip(Integer vip) {
this.vip = vip;
}
public Integer getSex() {
return sex;
}
public void setSex(Integer sex) {
this.sex = sex;
}
@Override
public String toString() {
return "User [id=" + id + ", username=" + username + ", email=" + email
+ ", vip=" + vip + ", sex=" + sex + "]";
}
}
Build
运用Build Pattern策略建立Builder,目的为了构建对象。
@Service
public class UserBuilder {
private User user;
public UserBuilder() {
if (user == null) {
user = new User();
}
}
public User build() {
if (user.getUsername() == null) {
user.setUsername("test");
}
if (user.getVip() == null) {
user.setVip(0);
}
if (user.getSex() == null) {
user.setSex(1);
}
if (user.getEmail() == null) {
user.setEmail("test@sina.com");
}
return user;
}
public UserBuilder withUserName(String userName) {
user.setUsername(userName);
return this;
}
public UserBuilder withVip(int vip) {
user.setVip(vip);
return this;
}
}
Manipulation
使用Builder来生成对象
@Test
public void buildCommonUser() {
User user = userBuilder.build();//使用默认值构建user对象
User user1=userBuilder.withUserName("Jack").build();//用户名为Jack的user对象
}
Creation
生成对象后,可以开始调用API接口生成数据或者对数据库进行操作。
@Test
public void buildCommonUser() {
User user = userBuilder.build();
userService.createUser(user);//创建用户
}
总结,使用Builder模式生成测试数据方便简单,步骤是:Model->Build->Manipulation->Creation。
参考资料:
1.AN INTRODUCTION TO THE DATA BUILDER PATTERN
2.极客时间-茹炳晟《软件测试52讲》