实战丨基于接口的银行系统自动化测试实践
本文以接口自动化测试作为银行测试工作突破口,在分析主流工具与银行业实际需求之间差异的基础上,通过自研打造接口自动化测试平台,分享了平台建设及落地的实践经验。
自动化测试类型分析
自动化测试是提高测试效率的有效方法,目前业界的自动化测试基本分为两类,一类是基于UI的自动化测试,另一类是基于接口的自动化测试。一般情况下,软件的界面UI变化比较频繁,实施基于UI的自动化测试维护测试用例的成本较高。而软件的接口相对变化较少,维护测试用例的成本较低。其次,接口自动化测试的执行效率较高,暴露缺陷的解决成本相对较低,在繁重的测试压力下,可以通过接口测试快速验证软件的基本功能,提高软件的测试效率。
1.构建接口自动化测试平台
通过对市场上Postman、SoapUI及Jmeter等接口测试工具的研究发现,这些工具可以完成基本的接口测试。但对于接口信息的维护、测试案例的设计与管理、测试数据的准备、发送报文的拼装、返回报文的解析以及测试缺陷的自动提交等方面却无能为力。另外,对于多接口的串联交互、复杂检查点的设置与判断、测试报告的生成等则还需要相应脚本语言的支持,测试人员只能编写脚本进行控制,这又会挤占测试时间。此外,上述测试工具不支持银行信息系统中广泛使用的Socket(定长/不定长、有/无分隔符、长/短连接等)、TONG及MQ等协议。为解决以上问题,我们结合华夏银行应用系统的特点,针对各个系统不同的通讯协议和各种特殊的报文拼装与解析方式,打造了一款基于微服务架构、支持接口测试全流程的平台。通过该平台不仅可以实现单系统以及系统群的接口测试,还可实现交易并发的性能测试,支持功能测试与性能测试的前移。
2.接口自动化测试平台架构
①平台技术架构
如下图1所示,整体应用端采用Nginx作为反向代理服务器,实现web端应用对高并发连接场景的适应能力,消除web端的单点故障;
通过虚拟路由技术解决Nginx服务器单点故障;
使用API网关路由,实现根据请求锁定目标微服务并将请求进行转发的功能,同时实现权限校验、限流控制、高可用、负载均衡及容错能力,防止整体崩溃的情况;
使用Eureka集群做为微服务注册中心,所有微服务都注册到Eureka供消费端使用,可根据需要扩展微服务的节点,并且各个Eureka节点间通过复制方式完成数据的同步,其中一个Eureka节点出现问题时,注册中心仍可正常提供服务;
使用sleuthzipkin + rabbitMQ微服务链路追踪,监控并收集所有服务请求;
使用Mysql存储业务关系数据,使用Redis、Elasticsearch存储用户信息、查询频繁及数据量大的数据,加速请求访问;
通过actuator对各个微服务节点进行监控,随时掌控各个微服务的运行状况。
②平台应用架构
如下图2所示:
基础资源管理: 基于用户角色实现菜单访问及功能操作的权限控制。
作业实施层: 提供测试作业过程的案例分析、生成、执行等服务。
作业控制层: 提供测试需求管理、任务同步、结果审核等服务。
作业结果层: 提供各种统计报表、测试报告、缺陷信息处理服务。
公共资产库: 提供消息通知、日志管理等服务,存储经审核并归档的测试资产,为测试人员提供查询及引用服务,提高测试效率。
接口自动化测试平台功能介绍
①接口测试全流程线上化
本平台实现了接口测试全流程的线上化、标准化与自动化,包含接口信息维护、测试案例设计与管理、测试数据准备、检查点设置、发送报文拼装、报文发送、返回报文解析、检查点判断等功能,每个功能模块都可以以微服务方式向外提供服务接口。
②执行机容器与执行机
考虑到银行被测业务系统与通讯协议的多样性,本接口自动化测试平台在设计之初就考虑到了与被测系统匹配的灵活性。在架构设计上提出“执行机容器”与“执行机”的概念,做到了执行与准备的完全分离,根据协议类型与报文格式创建的执行机服务,可脱离被测系统实现共享,降低后续维护负担。同时测试数据与测试案例完全分离,实现以数据为驱动的测试,如下图3所示。目前已支持的协议有Socket(定长/不定长、有/无分隔符、长/短连接等)、TONG、http(json),并实现了全行主流的重要信息系统的接口自动化测试。
③数据准备方案、报文拼装与解析
本平台提供了灵活多样的数据准备方案:
1、数据池功能: 辅助用户快速创建测试数据库表,存储用户所需的测试数据已备接口传入参数使用。
2、函数功能: 工具自带随机数字、随机日期、随机身份证号等函数方便用户生成消耗性测试数据。
3、常量数据: 支持从excel中批量导入常量数据。
4、交易链: 支持多接口串联的业务场景测试,将前置接口的响应字段传递给后续接口的请求自带。
5、SQL动态获取: 支持从被测系统数据库中使用sql语句取测试数据,或作为检查方式使用sql查询被测系统数据库中的数据是否正确处理。
这些方法降低了测试数据准备的难度。同时,可根据接口文档实现可视化的发送报文自动拼装与返回报文自动解析,提供了灵活简易的测试案例检查点设置及检查点的自动判断功能,如下图4所示。
④测试案例执行报告
为切实减轻测试人员整理测试成果物的负担,平台将会自动生成内容详实的执行报告,包括案例执行人、执行结果、执行用时、发送与返回报文详情及相应的统计信息等等。方便测试人员随意裁剪,形成可交付的最终测试成果物,如下图5所示。
⑤交易(接口)链
平台实现了完全摆脱程序脚本的交易(接口)链功能,根据平台维护的交易接口信息,通过可视化的拖拽等操作,不仅可以实现同一被测系统内不同交易接口间参数的自由传递,还可实现不同被测系统间交易接口的参数传递。通过该功能可以方便地完成实时的跨系统测试数据准备及关联接口的相关测试。如下图6所示。
应用实践
1.解决系统测试时间不同步的问题
由于金融业务的安全性与特殊性,决定了银行软件系统的复杂性。每笔交易除了往返于传统的前台、中台与后台之外,还要经历由各个独立子系统甚至是第三方系统提供的各种有效性检查、加密、解密、验证、复合确认等等。因此,在银行软件系统的测试过程中经常会出现系统之间互相等待的情况。例如,信贷接口已经开发完成,需要等待网银的最新界面才能完成调用测试,也就是说,各个系统进入测试阶段的时间点有先有后,节奏和步调始终不能统一。现在,我们利用接口自动化测试平台,在被测系统完成单元测试后,不必等待其它的上下游系统开发完毕,即可完成对其自身的接口测试,实现了测试的前移,为测试人员争取了更多的测试时间,为进一步丰富测试案例和测试数据提供了时间保障。
2.系统并发性测试前移
在接口自动化测试平台中开发了接口并发性测试功能,每条测试案例可以根据需要灵活配置它的并发数。这样,在开发的最初阶段,开发人员即可对系统的接口进行并发性的自测试,使被测系统的性能缺陷提前暴露,减轻后期的性能测试团队压力并降低缺陷的修复成本。
3.实现系统群、交易群、数据群的接口测试
在金融软件的测试过程中,数据的准备往往是非常耗时的,并且有些数据一经使用,即失去再次使用的价值,如贷款账户等数据。一个应用系统为了测试某些新增的功能点,常常需要在其上游系统中通过触发一连串的交易来获取自身系统所需的测试数据,例如,信贷系统放贷之前,需要核心系统开立个人客户,然后开立个人卡。针对这些上游系统,把常用的交易链部署在接口自动化测试平台中,同时利用“贴标签”的方式标记这些交易链,形成实时的“数据群”,测试人员可以方便地调用这些交易链来快速准确地准备测试数据,摆脱对上游系统繁琐的手工操作过程。
另外,我们利用接口自动化测试平台对被测系统的上下游系统进行测试案例群的覆盖,形成了标签化的系统群、交易群,可以实现对系统群、交易群的同时验证。
4.接口自动化测试平台配合其它工具使用
在对各应用系统的测试过程中,并非所有的测试案例都可以通过调用接口来实现。接口自动化测试平台的接口测试功能配合应用系统的定时自动跑批任务调度器,再配合平台的文件检查等功能使用,可以更全面地覆盖银行应用系统的测试场景。举例来说,有A、B、C(如图7)三个银行的被测应用系统,测试目标是通过调用A系统的接口,改变了A系统的数据库字段(如金额),B系统的定时自动跑批任务调度器在日终后定时触发跑批任务,从A系统的数据库中批量抽取字段,经过加工后,将数据传送至C系统,C系统的自动跑批任务调度器定时触发跑批任务,生成数据文件,接口自动化测试平台的文件检查服务将在系统指定的时间点检查文件是否生成,并检查文件中的内容是否正确,并自动生成相应测试报告。
5.测试结果与数据库的自动比对验证
接口自动化测试平台不仅需要具备对被测系统返回报文进行预期字段预设值检查的功能,有些接口的调用,被测系统并无具体的接口报文返回,而是在系统处理报文的过程中改变了数据库表的某些字段值,或者生成相应的处理结果文件,如核心系统跑批交易接口等。为了更好地验证被测系统,我们开发了接口自动化测试平台的数据库适配功能,实现了通过配置相应数据库,对数据库表的具体字段进行自动检查,验证其是否符合测试预期。
6.测试成果物的辅助生成
通过本平台的自动化功能,实现数据的抽取与统计,自动生成相应测试报告,减轻测试人员手工操作的成本,提高测试报告数据准确度的同时加快了报告生成的速度。
7.测试缺陷的自动提交
测试案例自动化执行发现缺陷后,本平台可以根据执行结果自动提交或填充相应缺陷信息与回归步骤,并且自动更新缺陷状态,减少测试人员的手工操作,使测试人员专注于缺陷本身,进一步提高测试效率。
最后: 大家可以去我博客首页看下侧边栏! 进去有许多资料共享!资料都是面试时面试官必问的知识点,也包括了很多测试行业常见知识,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。
好文推荐
转行面试,跳槽面试,软件测试人员都必须知道的这几种面试技巧!
面试经:一线城市搬砖!又面软件测试岗,5000就知足了…
面试官:工作三年,还来面初级测试?恐怕你的软件测试工程师的头衔要加双引号…
什么样的人适合从事软件测试工作?
那个准点下班的人,比我先升职了…
测试岗反复跳槽,跳着跳着就跳没了…
实战丨基于接口的银行系统自动化测试实践相关推荐
- pythonwebsocket接口自动化测试_基于websocket接口的jmeter自动化测试实践(2)
jmeter属性 通常我们会使用用户自定义变量,把每个用例共用的东西提取出来.然而,当测试环境多起来时,这些写死在jmx脚本里的变量就不那么好用了.例如,对多个环境测试时,难道要复制多个脚本.单独改变 ...
- 基于postman的api自动化测试实践
测试的好处 每个人都同意测试很重要,但并不是所有人都会去做.每当你添加新的代码,测试可以保证你的api按照预期运行.通过postman,你可以为所有api编写和运行测试脚本. postman中的测试 ...
- 接口自动化测试实践指导(中):接口测试场景有哪些
在第一篇文章 接口自动化测试实践指导(上):接口自动化需要做哪些准备工作中详细给小伙伴们讲解了一下接口自动化需要做哪些准备工作,准备工作中最后一步接口测试用例设计是非常重要的一个环节,用例设计的好不好 ...
- 接口自动化测试实践指导(下):接口自动化测试断言设置思路
在前篇文章: 接口自动化测试实践指导(中):接口测试场景有哪些 中详细给小伙伴们讲解了一下接口自动化需要做哪些准备工作及接口测试场景有哪些. 本篇文章是最后一篇,主要分享一下接口自动化测试断言设置思路 ...
- python自动化测试开发_基于python的selenium2自动化测试从基础到实战(Python3、selenium2、自动化测试、web测试)...
Selenium2是目前比较流行的一款针对web页面测试的自动化测试工具,他的前身是Selenium .Selenium测试直接运行在浏览器中,就像真正的用户在操作一样.支持的浏览器包括IE.Mozi ...
- Maven实战(四)——基于Maven的持续集成实践
相信很多读者和我一样,最早接触到持续集成的概念是来自Martin的著名文章<持续集成>,该文最早发布于2000年9月,之后在2006年进行了一次修订,它清晰地解释了持续集成的概念,并总结了 ...
- 基于CNN的自动化测试实践
基于CNN的自动化测试实践 ReLuQ 交叉学科就像交叉特征一样有趣 已关注 2 人赞同了该文章 写在开头: 本篇是笔者在公司的一个项目,主要与公司测试部一位经验丰富的老哥(曾在华为腾讯任职十年)合作 ...
- 《数据分析实战:基于EXCEL和SPSS系列工具的实践》——3.3 耗时耗力的数据整理过程...
本节书摘来自华章计算机<数据分析实战:基于EXCEL和SPSS系列工具的实践>一书中的第3章,第3.3节,作者 纪贺元,更多章节内容可以访问云栖社区"华章计算机"公众号 ...
- 基于python的界面自动化测试-基于Python语言的自动化测试实战第二章(上)
原标题:基于Python语言的自动化测试实战第二章(上) 测试环境搭建 2.1 Windows 下的环境搭建 如果想要学习一门编程语言,对于新手来说只需到其官方网站上去下载最新版本安装即可,但对于想要 ...
最新文章
- 024:模版查找路径配置
- C++ Primer 5th笔记(chap 16 模板和泛型编程)效率与灵活性
- 【AI白身境】深度学习中的数据可视化
- App 不想被“点名”,mPaaS 隐私合规检测为开发者护航数字生态建设
- 买空long position、卖空short position
- LeetCode Algorithm 1052. 爱生气的书店老板
- 腾讯云TStack获“下一代云计算技术创新奖”,助力云生态信息创新发展
- linux 打包排除多个目录,tar打包整个目录(可排除子目录)几种方法
- 第5 章持久化类(Persistent Classes)
- Java基础知识Set、List、Map的区别
- 3DShader之法线贴图(normal mapping)
- bzoj4771 七彩树
- Docker概述(一)(标贝科技)
- arcgis api for js绘制箭头图
- 代写COSC1295 Advanced Programming 作业、代做Java JDBC 程序设计作业、Java编程代写
- 数据统计平台设计与实现
- 单片机(Arduino)+FLASH+MIC+喇叭自制录音、播放器(二)
- 【算法】深度搜索(DFS) 和 广度搜索(BFS)
- 搜狐狐友搅局社交;小米手环4发布;2019互联网趋势报告发布;Python火爆依旧...
- (17) 基于时空网络的出租车OD需求预测
热门文章
- eclipse 集成svn客户端_TortoiseSVN及Eclipse的svn插件安装使用
- oracle 客户端连接数_查看oracle数据库允许的最大连接数和当前连接数
- android 短信文件夹,Android查看签名文件信息
- java能不能不用jvm_Java、JVM和操作系统之间的关系,写给新人,
- 相机靶面大小和显微镜FN的匹配关系
- 同时生成 Release版和Debug版DLL的方法
- 中国计算机信息系统集成行业协会有含金量吗,系统集成工程师证书的含金量怎么样...
- Linux虚拟机添加磁盘
- leetcode 456. 132 Pattern 132模式 题解(栈)
- 《大数据导论》一1.4 案例学习背景