如何编写有效的接口测试?

测试工程师是一个高技术含量的岗位,但现在不少人误以为测试工程师就是“点工”,拿到软件“点点点”,就可以完成测试了,没啥技术含量,而一些测试工程师错误的工作方法也滋长了这种误解。

1

什么是接口测试

接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等

2

为什么要做接口测试

a)互联网的快速发展,公司内部系统或与外部系统的关联越来越多,一个业务流程关联多个后端系统,它们的关联都是基于接口来实现,接口测试可以将复杂的系统关联进行简化,只要做好每个接口的测试就能够较好的保证系统质量。
b)单个系统的变更,是否会影响到关联业务系统,比较难用常规的测试方面来覆盖相关的应用系统(例如使用此接口的外部 系统有N个,不可能每个做功能兼容性测试),但可以通过对接口功能的覆盖来验证是否影响它人对接口的调用。
c)接口功能比较单一,能够比较好的进行测试覆盖,也相对容易实现自动化持续集成,,可以减少人工回归成本与时间,缩短测试周期。
d)接口相对于界面功能,会更底层一些,测试覆盖会更容易(如业务在调用接口时做了判断,当不满足条件时链接就不显示,此时从界面无法测试相关功能是否做好判断,通过接口就比较容易)

3

接口测试的范围

a)业务功能(包括正常、异常场景是否实现)
b)业务规则(覆盖度是否全面)
c)参数验证(边界、业务规则是否达到要求)
d)异常场景(重复提交、并发提交、事务中断、多机环境、大数据量测试)
e)性能测试(响应时间、吞吐量、并发数、资源要求)
f)安全测试(权限验证、SQL注入等)

4

接口测试的重点

a)检查接口返回的数据是否与预期结果一致。
b)检查接口的容错性,假如传递数据的类型错误时是否可以处理。
c)接口参数的边界值。例如,传递的参数足够大或为负数时,接口是否可以正常处理。
d)接口的性能,http请求接口大多与后端执行的SQL语句性能、算法等比较相关。
e)接口的安全性,外部调用的接口尤为重要。

5

测试原则

基础原则:

·自动化:接口测试是非交互式的自动化执行,不需要人参与。

·独立性:接口测试之间不应该相互依赖。

·可重复:接口测试可重复执行,不受环境影响。

·接口测试遵守BCDE原则,保障接口交付质量。

  • Border:边界测试。

  • Correct:正确的输入,正确的预期输出。

  • Design:按照需求和设计文档编写测试逻辑。

  • Error:错误输入,预期输出。

·数据准备:数据准备通过系统服务进行,不能通过直接插入db方式。

·可测性:对于不可测的代码需要进行重构成合理的结构。

·覆盖性:接口测试需要覆盖所有UC,同时代码覆盖率和分支覆盖率应达到一定标准,新增代码必须被覆盖。

·持续性:如果代码修改导致已有接口测试执行失败,必须修复代码问题或者测试代码逻辑。

·时间要求:接口测试应该在项目发布之前完成,不应放到项目发布之后补充。

以上的基本原则应适用于所有层的自动化测试用例,在编写接口测试时,除了上面这些原则,还有其他原则需要遵守,先看一张图:
从系统角度来分析入口调用,以HSF服务为例:

·外围系统调用由我们系统提供的服务。

·系统执行了一堆代码逻辑,其中包含有分支逻辑。

·系统执行过程中依赖外部HSF服务,进行了调用,并得到了返回值。

·系统执行过程中依赖DB查询或者落地了数据,依赖缓存查询或者落地了数据。

·系统执行过程中对外发送了消息。

·给上游系统返回HSF执行结果。

有效接口测试的关键原则是要覆盖所有入口,mock所有依赖,校验执行过程中所留下的痕迹,总结如下:

·入口覆盖:接口测试用例必须覆盖HSF服务入口、消息入口、定时任务入口。

·依赖mock:在基本原则中,有可重复这个原则,即接口测试不能受环境依赖,需要mock掉对外依赖。但对于db依赖,不建议完全mock掉,一方面mock成本高,另外可能覆盖不到sql和表约束逻辑。

·校验完整:有效的接口测试,应该具备完整的校验,没有校验的接口测试是没有意义的。只要执行过程中,留下的痕迹对业务有影响,都要进行完整校验,方能保障接口测试的有效性。

  • HSF接口返回值校验:按照场景和接口约定进行HSF返回参数校验。

  • DB校验:校验落地数据的正确性。

  • 缓存校验:校验存入缓存中数据的正确性。

  • HSF依赖入参校验:通过mock工具获得依赖HSF调用的入参,进行入参校验。

  • 消息校验:通过mock工具获得发送的消息对象,进行消息体校验。

6

接口测试常用工具

1、JMeter
JMeter是Apache组织开发的基于Java的压力测试工具,能够将请求转换为脚本来实现,并允许使用正则表达式创建断言来对请求返回结果进行判断,具备接口测试功能和性能的能力。

2、SOAPUI
SoapUI是一个完整的自动化测试解决方案。支持SOAP和REST的Web服务,JMS企业消息层,数据库,丰富的互联网应用,等等。而在SoapUI,你从它的直观和强大的用户界面这一切。对于自动化程度较高,SoapUI还提供了命令行工具,让您运行的功能/负载测试和几乎所有的任务调度程序,或作为您的构建过程中的一个组成部分MockServices集。

3、PostMan
Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件,具备Fiddler\httpwatch之类的工具调试请求的功能,同时具备接口管理功能,官网提升脚本保存同步功能,支持接口导入导出

4、Loadrunner
HP公司的性能测试工具,使用C语言或JAVA语言编写脚本,易学易用

(0)

相关推荐

  • Spock是什么?它和JUnit,JMock有什么区别?

    这是Spock系列的第一篇文章,整个专辑会介绍Spock的用途,为什么使用Spock?它能给我们带来什么好处?它和JUnit.JMock.Mockito有什么区别?我们平时写单元测试代码的常见问题和痛 ...

  • 解读六边形架构

    追溯微服务架构的渊源,一般会涉及到六边形架构.追溯六边形架构的起源,要看始作俑者Alistair Cockburn的这篇文章 http://alistair.cockburn.us/Hexagonal ...

  • 家谱怎么编写,有什么格式?

    家谱的形式和内容 一.什么是家谱? 家谱作为中华几千年历史发展传承而来的文化表现形式,虽然在长期的发展过程中因各种因素而编写形式有所不同,在编写体例.记载范围.记载内容和编修重点会有所不同,但其格式规 ...

  • 如何编写简历核心能力部分?

    创建一份简历以突出你的重要工作经验,完整的技能和资格,对于帮助你引起关注很重要.你的简历是你为准雇主提供良好第一印象的机会,具有核心能力部分的简历可让你注意你最相关的技能以及你将成为什么样的员工.我们 ...

  • 二、编写式讽喻

    19.有一个卖骏马的人,一连三个早 晨带着骏马站在马市上,没有人过问. 他去见善相马的伯乐,说:"我有一匹骏 马,打算卖掉它,可一连三个早晨站在 马市上,没有一个人来问过.我希望您 在我的马 ...

  • 科研课题结题报告编写

    科研课题结题报告编写

  • 孙剑云编写的《孙式太极拳理法歌诀》

    <孙式太极拳理法歌诀>(有称<孙式太极拳歌诀>)是孙剑云为孙式太极拳学者编写的七言二十句歌诀.作为一代宗师"赛活猴"."虎头少保"孙禄堂 ...

  • 监理日志、通知单、例会纪要如何编写?存在哪些问题?

    路桥隧干货集 公路.桥梁.隧道.市政技能干货!Official Account来源:民生监理版权属于原作者 监理日志监理日志是反映监理机构每日工作成果的记录,应由专业监理工程师编写,总监或总监代表审核 ...

  • 监理日志、通知单、例会纪要如何编写?

    建设监理实时了解建筑行业资讯和更多深度好文关注 来源:黄程龙看了最近许多监理同仁的留言,监理日志,通知,这类关键词比较多,这个文章之前发过,但是发的时间比较早了,很多后来的监理小伙伴可能看不到,再发一 ...

  • 施工方案还写不好?这份规范编写的要点快收好

    源自丨土木工程网 施工方案是单位工程或分部(分项)工程中某施工方法的分析,是对施工实施过程所耗用的劳动力.材料.机械.费用以及工期等在合理组织的条件下,进行技术经济的分析,力求采用新技术,从中选择最优 ...

  • 还在用C编写LVGL上的画面,何不试试Python? (2)

    在上一篇中,小编为大家简单介绍了LVGL库,并且介绍了如何实现lvgl和MicroPython的绑定,使得lvgl以MicroPython模块的形式供用户通过Python进行调用,方便开发. 本篇小编 ...