首页 > 编程语言 >走进Java接口测试之从0到1搭建数据驱动框架(需求篇)

走进Java接口测试之从0到1搭建数据驱动框架(需求篇)

时间:2023-04-06 12:03:06浏览次数:40  
标签:test1 test2 Java 数据源 接口 用例 datasource spring 搭建

走进Java接口测试之从0到1搭建数据驱动框架(需求篇)_数据源


前言

一个 “好的” 数据驱动框架,需要从“时间”、“人力”、“收益”这三个方面出发,做好“取舍”。

不能由于被测业务系统发生一些变更,就导致花费了几个小时的脚本无法执行。同时,我们需要看到“收益”,不能为了总想看到100%的成功,而减少必须做的工作,这导致可能都需要进行大量的维护。

所以做好这三个方面的平衡并不容易,想要提高 ROI(投入产出比),我们必须从两方面入手:

  • 减少开发成本。
  • 增加使用便利度。

针对“减少开发成本”,我们需要做到:

  • 减少持久层开发的成本。尽可能的减少开发、维护的时间,尽可能使用公司已有的,或是业界成熟的工具或组件;
  • 减少用例录入成本。简化测试用例录入的方式,做到脚本和测试数据解耦,如果可以开发一些批量生成测试数据工具;
  • 减少用例维护成本。减少用例维护成本,尽量只用在参数上做简单的变更即可完成维护动作,而不是进行大量的代码操作。

针对“增加使用便利度”,我们需要做到:

  • 手工测试也能用,不需要进行接口用例逻辑开发,也可以准备测试数据;
  • 在开发和调试阶段,可以帮助我们更快的定位问题;
  • 在测试的运维过程中,可以帮助我们记录大部分的异常信息;
  • 支持对数据库测试状态进行实时监控预警。

所以,我们一起来开发一个数据驱动框架,来实现对数据驱动想法的一些实践。

目前遇到的痛点

测试用例管理

这里不提倡把测试用例直接硬编码写在 Java 文件中,因为这样做会带来很多问题:

  • 修改测试用例需要改动大量的代码;
  • 代码也不便于交接给其他同学,因为每个人都有自己的编码风格和用例设计风格,这样交接,最后都会变成由下一个同学全部推翻重写一遍;
  • 如果测试框架更换,无法做用例数据的迁移,只能手动介入,效率很低。

所以 “测试数据” 与 “脚本” 分离是非常有必要的

网上很多的范例是使用的 Excel 进行的数据驱动,而我这里推荐使用关系型数据库 MySQL,为什么呢? 

一般我们的脚本和代码都是提交至公司的 GitLab 仓库,如果使用 Excel 很显然不方便日常经常修改测试用例的情况,因为我们需要做到版本控制,集中式管理。使用 MySQL 就没有这样的烦恼了,由于数据与脚本的分离,只需对数据进行修改即可,脚本每次会在数据库中读取最新的用例数据进行测试。同时,还可以防止一些操作代码时的误操作。

多业务数据源

作为一个测试开发工程师,自动化接口测试经常要连 N个数据源。对于多数据源,网上提供了重写:

数据据库这边的配置:


1. mybatis.config-location=classpath:mybatis/mybatis-config.xml
2. 
3. spring.datasource.test1.jdbc-url=jdbc:mysql://localhost:3306/test1?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=true
4. spring.datasource.test1.username=root
5. spring.datasource.test1.password=root
6. spring.datasource.test1.driver-class-name=com.mysql.cj.jdbc.Driver
7. 
8. spring.datasource.test2.jdbc-url=jdbc:mysql://localhost:3306/test2?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=true
9. spring.datasource.test2.username=root
10. spring.datasource.test2.password=root
11. spring.datasource.test2.driver-class-name=com.mysql.cj.jdbc.Driver

一个 test1 库和一个 test2 库,其中 test1 位于主库,在使用的过程中必须指定主库,不然会报错:


1. @Configuration
2. @MapperScan(basePackages = "com.zuozewei.mapper.test1", sqlSessionTemplateRef  = "test1SqlSessionTemplate")
3. public class DataSource1Config {
4. 
5.     @Bean(name = "test1DataSource")
6.     @ConfigurationProperties(prefix = "spring.datasource.test1")
7.     @Primary
8.     public DataSource testDataSource() {
9.         return DataSourceBuilder.create().build();
10.     }
11. 
12.     @Bean(name = "test1SqlSessionFactory")
13.     @Primary
14.     public SqlSessionFactory testSqlSessionFactory(@Qualifier("test1DataSource") DataSource dataSource) throws Exception {
15.         SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
16.         bean.setDataSource(dataSource);
17.         bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mybatis/mapper/test1/*.xml"));
18.         return bean.getObject();
19.     }
20. 
21.     @Bean(name = "test1TransactionManager")
22.     @Primary
23.     public DataSourceTransactionManager testTransactionManager(@Qualifier("test1DataSource") DataSource dataSource) {
24.         return new DataSourceTransactionManager(dataSource);
25.     }
26. 
27.     @Bean(name = "test1SqlSessionTemplate")
28.     @Primary
29.     public SqlSessionTemplate testSqlSessionTemplate(@Qualifier("test1SqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
30.         return new SqlSessionTemplate(sqlSessionFactory);
31.     }
32. }

一层一层注入,首先创建 DataSource,然后创建 SqlSessionFactory 再创建事务,最后包装到 SqlSessionTemplate 中。其中需要指定分库的 mapper 文件地址,以及分库dao层代码:


1. @MapperScan(basePackages = "com.zuozewei.mapper.test1", sqlSessionTemplateRef  = "test1SqlSessionTemplate")

这块的注解就是指明了扫描 dao 层,并且给 dao 层注入指定的 SqlSessionTemplate。所有 @Bean 都需要按照命名指定正确。dao 层和 xml 需要按照库来分在不同的目录,比如:test1 库 dao 层在 com.zuozewei.mapper.test1 包下,test2 库在com.zuozewei.mapper.test2。

这个方式,确实可用,不足在于,需要根据不同数据源建立不同的 package,一旦数据源发生变更,需要更改所在的 package。也看过了动态数据源,那也不是我们想要的。

持久层开发

在使用 Mybatis 的时候,Dao 接口,Entity 实体类,还有每个实体类对应的 xml 都得自己写,这其实也是工作量很大的事情,维护起来也很费劲。

日志管理

一个成熟的数据驱动框架,日志管理这个是必不可少的。在开发和调试阶段,日志可以帮助我们更快的定位问题;而在测试的运维过程中,日志系统又可以帮助我们记录大部分的异常信息,通常很多测试框架会通过收集日志信息来对接口测试状态进行实时监控预警,比如慢SQL。

主流技术栈

主要考虑以下几个方面:

  • 开发更简单;
  • 测试更简单;
  • 配置更简单;
  • 部署更简单;
  • 基于主流的框架;
  • 具备市场竞争能力。

主要功能

所以,总结以上的需求,我画了一个图:

走进Java接口测试之从0到1搭建数据驱动框架(需求篇)_spring_02

功能描述

  • 灵活支持多业务数据源;
  • 测试用例集中式管理,结构化数据;
  • 数据驱动做到脚本与测试数据解耦;
  • 丰富的日志管理管理功能,支持异常监控,便于开发调试;
  • 支持性能监控,比如业务数据源的慢SQL;
  • 开发的便利性,能节省重复工作,降低开发成本;
  • 灵活的扩展性,满足自定义的数据类型;
  • 主流的技术栈,能跟上互联网技术节奏,不易于快速被淘汰;
  • 友好的代码结构及注释,便于阅读及二次开发。

小结

本文总结了数据驱动框架中一些常见的痛点和一些必备的功能,这决定后续我们的框架如何去设计,希望对你能有所启发。


参考资料:

[1]:Lego-美团接口自动化测试实践

[2]:在Mybatis-spring上基于注解的数据源实现方案


标签:test1,test2,Java,数据源,接口,用例,datasource,spring,搭建
From: https://blog.51cto.com/u_15181572/6172559

相关文章

  • org.apache.shiro.session.InvalidSessionException: java.lang.I
    1.遇到以下异常,找了好长时间,终于解决,报的异常如下:七月07,20173:02:16下午org.apache.catalina.core.StandardWrapperValveinvoke严重:Servlet.service()forservlet[SpringMVC]incontextwithpath[/IMP]threwexception[org.apache.shiro.session.InvalidSessionEx......
  • java中如何创建带路径的文件
    请教各位大侠了,java中如何创建带路径的文件,说明下这个路径不存在------回答---------------其他回答(2分)---------JavacodeFilef=newFile("c:/1.txt");if(!f.exists()){try{f.createNewFile();}catch(IOExceptione){e.printStackTrace();}}------其他回答(18分)----......
  • java之常用正则表达式
    http://wenku.baidu.com/link?url=gLcsovVfQqRTVayxGGaWBpjyewi4qOopgEJ3JYWaPSm_VqIsX1ALI_ZJpnrMf51P2eFpWK03DbPQly7Hfs4yI1hqWJnHDSJBjfzKkrfLZKWhttps://msdn.microsoft.com/zh-cn/library/ae5bf541(VS.80).aspx......
  • java 生成不重复的随机数
    importjava.text.SimpleDateFormat;importjava.util.Date;publicclassTest2{ publicstaticvoidmain(String[]args){ SimpleDateFormatformatter2=newSimpleDateFormat("yyyy年MM月dd日HH:mm:ss"); SimpleDateFormatformatter=newSimpleDateF......
  • java中的NAN和INFINITY
      java中的NAN和INFINITY java浮点数运算中有两个特殊的情况:NAN、INFINITY。1、INFINITY:在浮点数运算时,有时我们会遇到除数为0的情况,那java是如何解决的呢?我们知道,在整型运算中,除数是不能为0的,否则直接运行异常。但是在浮点数运算中,引入了无限这个概念,我们来看一下Double和Float......
  • Android 12蓝牙报java.lang.SecurityException: Need android.permission.BLUETOOTH_C
    报错如下:E/AndroidRuntime:FATALEXCEPTION:mainProcess:com.studay.base.study,PID:16798java.lang.SecurityException:Needandroid.permission.BLUETOOTH_CONNECTpermissionforAttributionSource{uid=10392,packageName=com.studay.base.study,a......
  • docker搭建无鱼工时系统
    1.安装docker安装docker依赖包命令:yuminstall-yyum-utilsdevice-mapper-persistent-datalvm2设置阿里云镜像源命令:yum-config-manager--add-repohttps://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo缓存镜像源信息以提高搜索安装速度命令:yummakec......
  • Java中的Class类 小的总结
    *点击查看代码publicclassProjectConfig{//合作方产品唯一标示publicstaticStringSOURCEID="hthx_swyyssys_0001";//AES加密解密keypublicstaticfinalStringAESKEY="B62i45TKqs1qwJaD";//本地公钥publicstaticfinalString......
  • Javaweb简介
    JavawebWeb:全球广域网,也称万维网(www),能通过浏览访问的网站JavaWeb:是通过用Java技术来解决相关web护网领域的技术栈网页:展现数据(前端)数据库存储数据(DBA)JavaWeb程序:逻辑处理(后端)(MYSQL)数据库:存储数据的仓库,数据是有组织的进行存储......
  • Java SpringBoot Bean InitializingBean
    Spring中有两种类型的Bean,一种是普通Bean,另一种是工厂Bean,即FactoryBean。工厂Bean跟普通Bean不同,其返回的对象不是指定类的一个实例,其返回的是该工厂Bean的getObject方法所返回的对象。Spring初始化bean有两种方式:实现InitializingBean接口,实现afterPropertiesSet方法。(比通过......