接口自动化测试设计

简介: 移动互联网时代,每一个App产品都有多种客户端形式,如:iOS、Android,混合应用Hybird以及H5。兼容测试覆盖的端越来越多,而大量的 计算,复杂的业务逻辑,都由服务端承载,给各种客户端提供标准的Restful 风格的标准接口调用交互。

1.接口测试基础

1.1.什么是接口测试?

  •     接口测试是测试系统组件间接口的一种测试。
  •     接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。
  •     接口测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。
  •    从接口形式来看各种应用程序的API(最著名的Windows系统API),硬件的驱动程序,数据库DAO层接口,及WebService 接口和Http Rest接口。
  •    接口测试通常包括两类,底层模块之间的接口测试和上层服务接口测试。前者通常由开发工程师做单测覆盖,后者则通常由测试工程师测试保证。

1.2.接口测试原理?

    通过测试程序或工具模拟客户端向服务器发送请求报文,服务器接收请求报文后做出处理,然后将应答报文返回给客户端,即客户端发送应答报文的过程(Request -> Response)


1.3.接口测试分类?

  •     系统与系统之间的调用:银行会提供接口供电子商务网站调用,或者说支付宝会提供接口给百度外卖调用。
  •     上层对下层服务的调用:如Service层会调用DAO层的接口,而应用层又会调用服务层提供的接口。
  •     系统内的服务之间的调用:如注册用户时,先调用用户查询的服务,查看该用户是否已经注册

1.4.为什么接口测试?

image2016-8-28%2019%3A35%3A36.png?versio

    测试金字塔概念由Mike Cohn提出,在《Succeeding with Agile》中做详细论述。核心观点:底层的单元测试应多于UI层的端到端测试。

    1).UI:通常指 Web、App的测试;2).Service:一般针对接口、服务,如 HTTP、WebService 接口测试;3).Unit:包含比较多,如:Web应用的dao、service、model,controller的junit单元测 试,javascript、css的前端单元测试,大部分应由开发做测试保证。

    参考金字塔层次划分,不能层次的测试投入量是不同的,越上层比重应越小,以尽量低的测试成本防御不同类型的风险。金字塔分层测试的ROI则是倒金字塔,即 Unit > Service > UI。Service测试层于QA而言是重要一环,也是性价比相对较高的。总之,分层自动化测试是追求覆盖的传统自动化测试的一种修正,充分利用自动化测 试的优点,规避自动化测试的缺点。


1.4.接口测试范围?

    新增及改动接口的测试(接口的改动点,可通过代码及配置 diff 测试,圈定最小测试范围。服务端接口迭代过程,需测试接口依次增多。测试时间足够条件下,当然需要进行全回归测试。但时间较短,应考虑接口的重要性与优先级,优先对核心且调用频繁的接口测试。)新增及改动业务功能测试。接口的性能与安全测试(是否需要对接口实施性能和安全测试,取决于接口特点。一个对第三方电商平台提供支付功能的接口,如:支付宝接口,性能和安全测试是 必须要例行化测试的。一个系统内部调用的获取列表页接口,性能和安全性考虑优先级相对不那么高。整体而言,从接口的业务特点,即流量大小、调用方式、服务 架构、业务闭环的重要性等角度考虑。)

 

2.接口测试策略

     检查: 接口设计检查,通过接口文档定义对接口交互数据做有效性检查,整数型数据位数、浮点型数据精度、字符串数据范围值等,要求客户端传入的整数型、浮点型、字 符串型数据及最大值和最小值都能作为服务端接口有效输入,确保服务端不会自动进行截断或四舍五入操作。(接口设计评审阶段即可进行)

               接口依赖关系检查,通常用户的一个操作可能对应服务端调用多个接口完成,从业务操作角度来看,各种业务操作所涉及的多个接口之间调用进行测试。依赖关系检 查,主要通过接口的输出值为另一接口的输入值来实现的,因此在进行接口测试之前,需要分析所测试接口的输入值是通过客户端还是其他接口输出来获取的,在设 计测试用例时,加入接口的依赖关系说明以便于测试。

     验证:接口输入/输出验证,服务端接口功能测试类似于单元测试,在设计测试用例时,侧重点在于接口模块输入/输出项的正确性验证,根据接服务端接口处理方式分类有多种:条件判断接口、数据查询接口、逻辑运算接口。
     构造:接口测试过程,常常需要构造测试数据。通常是数据库插入,mock 接口,调用依赖接口,开发脚本工具批量等。
     自动化:相对于UI层自动化测试,服务端接口的自动化测试更容易实施,较稳定且维护成本低。参考接口case的优先级做自动化覆盖,回归测试、线上监控等收益均较大。

2.1.接口测试关注点?

image2016-8-28%2019%3A36%3A50.png?versio

  •     入参数据:每个接口入参的默认值、异常类型、非空交易。 参数是否有默认值,若没有,接口逻辑是如何处理的;参数必须输入值,若不输入或输入错误,接口如何返回;接口报错,服务端和客户端是否都做了容错处理。
  •     出参返回:接口返回数据是否正确。
  •     页码页数的异常值:接口有翻页时,如:第一页有数据,翻到第二页。第二页的数据是否与第一页重复,第二页接口是否报错,页码、页数,传很大的值,接口是否报错。
  •     数据库增删改查,如对某接口post请求后,对列表页接口刷新请求,新数据是否与post数据一致。典型case,发布评论,post请求后是否返回评论数据,若无则检查是否缓存未写入数据库导致。
  •     参数个数:入参支持多个值时,考虑传值个数多的情况,接口是否报错,接口应返回友好提示。
  •     参数类型:输入参数类型必须校验,输出参数必须正确。即是int类型的,不能返回string类型。
  •     排序:列表页接口应考虑排序值,升降序、时间排序等是否正确。
  •     版本兼容:接口的改动(增加、减少字段)需要兼容老版本。
  •     参数联动性:校验返回的多个参数的实际结果是否符合需求,如:返回一个商户的列表,总数字段和列表数据是否一致。
  •     业务:从业务中来,到业务中去。接口测试是对业务逻辑的测试覆盖,对业务架构的理解。

2.2.接口测试Case设计?

Case参考点:输入参数测试,功能测试,逻辑测试,异常情况。

设计思路:a)优先级-针对所有接口,外部接口 > 系统内部核心接口 > 系统内部非核心接口。

                 b)优先级-针对单接口, 正向用例 > 逆向用例(通常情况,非绝对);前置条件 > 默认参数 > 参数必填 > 参数关联 > 参数类型限制 > 参数数据范围限制。

Case覆盖:主流程 -> 分支流程 -> 异常流程。

 

3.接口自动化演进

image2016-8-28%2019%3A38%3A50.png?versio

    接口自动化演进,通常是从手动测试 -> 工具测试 -> 代码测试 -> 平台服务化演进。

    手动:从客户端的业务场景测试去覆盖服务层接口,借助Fillder、Charles、FireBug等工具抓包分析。优点:简单,模拟真实业务场景;缺点:接口逻辑覆盖不够,异常和输入校验不足,重复繁琐,回归成本高。

    工具:使用PostMan,HttpRequest,Jmeter, SoapUI 等工具做接口测试。优点:容易保证接口逻辑覆盖,便于异常和输入校验,提高回归效率;缺点:缺乏自定义灵活性,接口依赖处理繁琐,不便自动化工程化。

    代码: 选择如,Java + Httpclient,Python + Requests, PHP + Requests/cURL/HTTPFul,搭建接口自动化框架,开发接口自动化case。优点:灵活性好,扩展性强,逻辑覆盖容易,异常和输入校验充 分,回归效率高;缺点:存在一定学习成本,框架及case脚本需持续维护。

    平台:通用的接口自动化测试平台,简而言之满足接口自动化测试的Web平台,如:Numen。优点:通用性强,上手快,一键式,配套服务全等;缺点:业务契合度,灵活性,维护成本,API扩展等。

3.1.接口测试工具?

    代理抓包工具
      
  Fillder, http://www.telerik.com/fiddler
        Charles, https://www.charlesproxy.com/
        Wireshark, https://www.wireshark.org/
    
    调试工具
       
 Firebug(Firefox), https://addons.mozilla.org/en-US/firefox/addon/firebug/
        DevTools(Chrome), https://github.com/CN-Chrome-DevTools/CN-Chrome-DevTools
    
    Json&Url encode工具
       
 json在线解析,格式验证, http://json.cn/
        json压缩转义, http://www.sojson.com/yasuo.html
        jsonview插件(Chrome), https://chrome.google.com/webstore/detail/jsonview/chklaanhfefbnpoihckbnefhakgolnmc?hl=zh-cn
       url encode工具, http://tool.chinaz.com/Tools/URLEncode.aspx

    测试工具
      
  PostMan, https://chrome.google.com/webstore/detail/postman/
        SoapUI, https://www.soapui.org/
        Jmeter, http://jmeter.apache.org/

3.2.接口自动化框架设计?

image2016-8-28%2019%3A37%3A55.png?versio

接口自动化测试框架设计关键点,其实可以用Driven、Organize、Support、CI概括。

Driven:Data Driven(数据驱动),接口测试关注输入、输出及各种异常数据,归根结底其实就是做数据测试。如何设计合理的参数化实现,降低测试数据维护成本,是自 动化框架设计的重要内容。KeyWord Driven(关键字驱动,即封装),将测试过程中公共过程、通用步骤尽量封装为通用函数,其中分别为业务、过程common 函数。合理的封装函数设计,将使得自动化脚本简洁化、一致性,可维护性高。

Organize:组织。考虑两个维度,如何管理组织自动化工程?如何组织自动化case?以Java语言举例,接口自动化case较少只有几个,创建一个普通java工程项目,在 main方法中,罗列写出case实现即可。无可厚非,这是一种简单实现。但随着接口数量增加,接口case越来越多,这种方式的维护成本越来越高,冗余越来越重。我们需要考虑将自动化工程化而不是脚本化,即做工程管理,如使用maven管理工程,配置各类jar包依赖,定义测试等。测试case使用单测 工具管理组织,如:junit/TestNG,有什么好处?定义了case的执行顺序,通用丰富的assert验证,结果统计收集等。

Support:接口自动化测试不只是模拟一个请求发送及响应解析的过程,做为框架需考虑的远不只这些。如:json数据的比对,数据库增删改查操作,接口的数据mock构造,md5值校验,url的unicode/encode,report,email等等。

CI:自动化框架搭建了,自动化case工程化了。选择什么方式调度,什么时候执行。IDE 手动调度执行,bat/sh?CI 是一种高效的机制,每次代码编译打包部署,都应该触发CI的自动化执行,自动化框架需要考虑CI的集成。


4.外面团队,如何做接口自动化?

测试工具:PostMan, SoapUI,Jmeter……

自动化框架

    Java:java + httpclient + junit/testng + ant/maven + Jenkins

               java + jmeter.jar + + junit/testng + ant/maven + Jenkins

    Python:python + (robotFrameWork) + (requests) + (xlrd) + pyUnit + Jenkins

    Ruby:ruby + (cucumber/rspec) + (http/net) + TestUnit + Jenkins

    PHP:php + requests + phpUnit + Jenkins

    NodeJS:node.js + mocha +supertest + Jenkins  

自动化平台:RAP

相关文章
|
3天前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
24 7
Jmeter实现WebSocket协议的接口测试方法
|
3天前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
21 3
快速上手|HTTP 接口功能自动化测试
|
5天前
|
安全 JavaScript 前端开发
自动化测试的魔法:如何用Python编写你的第一个测试脚本
【8月更文挑战第41天】在软件的世界里,质量是王道。而自动化测试,就像是维护这个王国的骑士,确保我们的软件产品坚不可摧。本文将引导你进入自动化测试的奇妙世界,教你如何使用Python这把强大的魔法杖,编写出能够守护你代码安全的第一道防护咒语。让我们一起开启这场魔法之旅吧!
|
3天前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
16 5
|
13天前
|
IDE 测试技术 持续交付
Python自动化测试与单元测试框架:提升代码质量与效率
【9月更文挑战第3天】随着软件行业的迅速发展,代码质量和开发效率变得至关重要。本文探讨了Python在自动化及单元测试中的应用,介绍了Selenium、Appium、pytest等自动化测试框架,以及Python标准库中的unittest单元测试框架。通过详细阐述各框架的特点与使用方法,本文旨在帮助开发者掌握编写高效测试用例的技巧,提升代码质量与开发效率。同时,文章还提出了制定测试计划、持续集成与测试等实践建议,助力项目成功。
36 5
|
12天前
|
数据采集 测试技术 API
在BrowserStack上进行自动化爬虫测试的终极指南
随着互联网的发展,数据价值日益凸显,爬虫技术成为提取网页信息的关键工具。然而,不同环境下的测试与运行挑战重重,特别是在多浏览器、多平台上保证爬虫的稳定性和兼容性尤为困难。BrowserStack作为领先的跨浏览器测试平台,提供了强大的工具和服务。本文将详细介绍如何在BrowserStack上进行自动化爬虫测试,并结合代理IP技术提升爬虫的隐蔽性和成功率。通过具体步骤和案例分析,展示如何利用Selenium、自定义用户代理和Cookie设置来应对反爬虫机制。本指南旨在为开发者提供实用模板,帮助其在多变的测试环境中构建高效的爬虫系统。
|
13天前
|
安全 Linux 测试技术
Kali Linux预装的自动化渗透测试工具
Kali Linux预装的自动化渗透测试工具
25 2
|
15天前
|
敏捷开发 jenkins 测试技术
自动化测试之美:打造高效软件测试流程
【8月更文挑战第31天】在软件开发的海洋中,自动化测试犹如一艘航船,引导着项目向着质量的灯塔航行。本文将揭开自动化测试的神秘面纱,从基础理论到实践操作,一步步构建起你的测试框架。你将学会如何编写实用的测试脚本,并将其融入日常开发,最终让测试成为敏捷开发不可或缺的力量。让我们启航,探索自动化测试的世界,确保代码之船稳健前行。
|
2天前
|
敏捷开发 测试技术 持续交付
自动化测试之美:如何用Selenium和Python打造高效测试脚本
【9月更文挑战第13天】在软件开发的海洋中,自动化测试是那抹不可或缺的亮色。它不仅提升了测试效率,还保障了产品质量。本文将带你领略使用Selenium和Python构建自动化测试脚本的魅力所在,从环境的搭建到脚本的编写,再到问题的排查,每一步都是对软件质量把控的深刻理解和实践。让我们开始这段探索之旅,解锁自动化测试的秘密吧!
3 0
|
2天前
|
jenkins 测试技术 持续交付
自动化测试的高效之路:如何利用Python进行Web应用测试
【9月更文挑战第13天】在软件开发的快节奏中,自动化测试是确保质量和效率的关键。本文将引导你了解如何使用Python语言及其强大的测试框架来提升Web应用的测试效率。我们将一起探索编写简洁而强大的测试脚本的技巧,以及如何通过持续集成(CI)实现自动化测试流程。准备好让你的测试工作飞一般的感觉!