服务端测试之接口测试用例设计

软件测试杂谈 软件测试杂谈     2022-09-16     171

关键词:

小伙伴们大家好,上一次和大家分享了《服务端测试之接口测试初探》,讲了一些接口测试的基本概念和理论知识。在上次的分享中,简单提到了接口测试用例设计包含的几个方面。本期我将在上次分享的基础上,和各位小伙伴一起具体看看这几个方面都是什么,在实际的项目中应该如何使用。

一、功能性用例设计

之前讲过,服务端的接口是和客户端的功能相对应的,对功能的验证,可以参照接口说明文档来进行。概括起来讲,就是我们需要验证接口说明文档中提到的各种情况,保证这些情况下接口的返回和最初设计的是一样的,这样我们就可以认为该接口实现了功能需求。

举个例子,目前有一个接口A,关于该接口的请求参数列表如下:

 

可以看到,规定该接口的请求类型是get,同时该接口包含4个请求参数,那么在功能性的用例设计上,我们可以考虑如下几个方面: 
1.以get方式请求; 
2.请求中需要包含这4个参数; 
3.各个参数的类型符合要求; 
4.key参数的长度需要控制在10个字符以内。

通过这几个方面写出来的case就是功能性的测试用例了。其实不难看出,功能性测试用例的目的是为了验证服务端在正常情况下是否实现了需求,因此构造出的用例都是满足接口说明文档的要求,即验证在正常情况下,客户端传入正常的参数后,服务端可以正常响应。

二、业务逻辑用例设计

业务逻辑方面的用例设计与功能性用例设计不同,逻辑用例主要关注接口内的各种判断对应的逻辑分支是否符合预期,这种用例不是针对某个具体的功能点,而是去验证接口内部的各种处理逻辑。这类用例,往往需要以业务逻辑流程图为依据进行设计。 
举个例子,在小编最近测试的项目中,画出接口流程图后有这样的一个逻辑:

 

 


可以看到这一块有两个判断,那么 针对这一块儿的处理逻辑,我们需要对不同的判断分支都设计用例,以保证流程图中涉及到的分支我们都有测试用例覆盖。图中涉及到的不同的分支有: 
1.abdf; 
2.acg; 
3.abdeg; 
相应的,我们的用例就应该是: 
1.userInfo != null && value(userGroup) != 0; 
2.userInfo == null; 
3.userInfo != null && value(userGroup) == 0; 
业务逻辑的用例设计主要是以服务端接口内部的逻辑流程图为基础,针对流程图中的判断和分支进行用例设计,保证服务端接口的每一种逻辑下都有测试用例覆盖。

三、异常处理的情况

由于客户端与服务端接口之间通常是通过HTTP请求来进行交互获取数据,因此对于请求中携带的参数以及数据的容错处理是必须考虑的一类case。关于异常处理我们可以归为两大类:参数异常和数据异常。具体而言常见的异常类型有以下几种:缺省或增加参数、参数类型不对、参数为空、数据超过限制等等。我们还是用接口A的参数来举例:

 


接口A的请求中一共有4个参数;那么异常情况可以这样去考虑: 
1.多了一个/若干个参数,比如请求中又携带了一个v=1这样的参数; 
2.缺省了某个参数,比如请求中不带page参数; 
3.参数类型不对,比如isMob规定是boolean类型,可以尝试传递一个其他的类型; 
4.数据为空,比如我们可以令key=(null),发送请求后检查服务端的响应; 
5.数据超过限制,比如在接口文档中规定key的长度不超过10个字符,那么我们需要设计可以覆盖到边界值的用例,比如长度为9、10、11等。 
…… 
值得注意的是,在功能均已实现的时候,对服务端而言容错非常重要,如果容错做得不好,往往可能一个格式不正确的参数就会引起服务端的异常甚至崩溃,因此在设计用例的时候,异常用例需要格外注意,需要尽可能多的设计出包含各种异常的用例,至少保证服务端在请求异常的情况下不会出现崩溃等极端状况。

四、性能和安全性方面

在进行服务端测试的时候,性能和安全性方面的用例是必须要考虑的。服务端的性能测试往往与功能性测试分开执行,一般情况下在服务端的功能测试进行完毕保证功能上没有问题的情况下,可以进行性能测试。性能测试借助于一些工具开展,比如LoadRunner等,关于性能测试,在后续的分享中我们会为大家详细介绍。安全性方面,主要需要考虑一些常见的安全策略,举个例子,在请求中需要携带用户的敏感信息(比如电话号码、身份证号码、地址信息等)时,敏感信息一定是需要加密的,需要验证对这些数据加密的生效性;又比如,在上面的接口A中,我们可以在参数中传一段JS代码,看服务端如何处理……

以上向大家介绍了服务端用例设计常见的几个方面,希望可以给各位测试小伙伴在平时的用例设计中提供一点帮助。大家如果有什么好的思想和方法,也可以进行留言互动。在以后的文章中,我们会继续就服务端测试相关的思想、方法、工具使用以及流程规范等和大家共同探讨,敬请大家持续关注。

 

接口自动化之pytest——用例设计原则及执行顺序

一、用例设计原则pytest是如何查找测试用例的?总的来说,寻找测试用例遵循以下原则: 总结:—文件名是test_开头或者_test结尾。—测试类必须是Test开头。—测试函数、测试方法以test_开头。 二、用例执行顺... 查看详情

postman系列之批量执行接口测试用例

...多方便~比如我们写了几十个测试用例,请求都是同一个服务器IP,一旦服务器IP地址从测试环境搬到线上环境,需要修改所有的服务器IP,如果不能将测试用例保存起来,统一修改服务器IP,并且批量执行,那将是一件很麻烦的事... 查看详情

接口测试基础--柠檬不萌!

...的分类二、前端和后端1、前端/client/客户端2、后端/server/服务端3、client端开发语言4、server端开发语言三、接口测试1、什么是接口测试2、为什么要做接口测试3、接口测试的必要性4、接口测试流程5、接口文档6、接口测试用例设... 查看详情

自动化测试之-测试用例设计方法总结

黑盒、白盒、接口测试一系列用例设计方法。黑盒测试用例设计方法包括等价类划分法、边界值分析法、错误推测法、因果图法、判定表驱动法、正交试验设计法、功能图法、场景图法等。(一)等价类划分法定义:等价类划分... 查看详情

测试基础

一.测试用例1.测试用例设计之场景图法2.测试用例设计之因果图法3.测试用例设计之正交表法和配对测试法4.测试用例设计之状态转换法5.测试用例设计之等价类法6.测试用例设计之判定表法7.测试用例设计之边界值法8.测试用例设... 查看详情

jmeter4.0接口测试之断言实战

...,另外一个是业务状态码的断言,最后是某一接口请求后服务端响应数据的断言。在Jmeter中增加断言的方式是右键测试用例点击断言,在断言中点击响应断言,在响应断言中,要测试的模式填写内容:HTTP/1.1200OK,要测试的响应字... 查看详情

测开基础之mock接口测试

...测试对象的返回,用于测试 通常意义的mockserver,模拟服务器返回的接口数据,用于前端开发,第三方接口联调 为什么要用mock:  1前后端开发进度不一致,前端开发速度快于后端, 查看详情

服务端测试之接口测试初探

  提起服务端测试,第一反应想到的可能就是http协议、socket连接、post/get发送请求等等。回想起小编当时初次接触服务端测试,真可谓一脸懵逼,不知道要干什么也不知道从哪儿开始做。服务端测试往往呈现给大家的是一个很... 查看详情

(转)接口测试用例设计(详细干货)

...相互作用的部分。这里说的接口是广义的,客户端与后台服务间的协议;插件间通信的接口;模块间的接口;再小到一个类提供的方法;都可以理解为接口。接口测试:是指针对 查看详情

jmeter接口测试系列之测试用例编写和调用

在使用Jmeter进行接口测试时,首先需要根据接口定义,编写响应的接口测试用例,在编写接口测试用例时,我们根据测试的侧重点不同,使用不同的方式编译测试用例。一种是:整个请求参数作为一个变量,进行测试执行;一种... 查看详情

jmeter基础之编写http接口用例

...p;二、配置http请求: 如下图所示:配置名称、协议、服务器名称或者IP、端口号等 常用配置说明: 名称:该请求名称,尽量以测试接口的功能做名称; 协议:此处可以空置,默认使用http请求; 服务器名称或... 查看详情

接口自动化测试测试用例设计

参考技术A浅谈接口自动化测试测试用例设计一、 前言  很多中台项目,大部分为接口测试。为了使新入职的测试同事尽快融入项目,以及迭代开发中方便管理测试用例。完成该总结。二、 测试用例设计思路 &#... 查看详情

自动化接口测试-基础知识

...通过遵守某种约定的协议(目前最常用的是http协议),服务端提供给客户端调用的某种服务。随着服务端架构越来越复杂,从单体架构、分布式架构,演变至如今流行的微服务架构,软件接口测试也变得越来越重要。二、软件... 查看详情

jmeter接口测试系列之测试用例变量参数化处理

在进行接口测试时,一组完整的接口测试用例,存在后一个测试用例使用前一个用例的请求结果中的数据,此时就需要参数化测试用例中值。直接使用变量调用会存在问题,此时就需要用到beanshell去改变。举例说明:比如接口1... 查看详情

接口测试怎么才能做好?

...例设计、执行来说吧。A.需求首先要了解这个接口提供的服务的需求定义,那么我们就知道大概测试的结果是啥。同时理论上要先提供接口规范,方便后续测试,以及给调用者联调的一个文档约定。B.测试用例设计根据测试的接... 查看详情

接口测试用例设计指导文档:新建查询修改删除功能以及流程等用例设计

一、功能点测试用例(单个测试用例)二、新建接口三、查询接口&查询列表接口四、修改接口&删除接口五、流程测试用例(组合测试用例)六、测试执行时,需注意的地方 查看详情

如何简单设计接口测试用例

本文摘自:http://blog.csdn.net/yzl11/article/details/51952903接口测试是项目测试的一部分,它测试的主要对象是接口,是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与所测系统之间以及内部各系统之间的交互点。测... 查看详情

如何简单设计接口测试用例

接口测试是项目测试的一部分,它测试的主要对象是接口,是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与所测系统之间以及内部各系统之间的交互点。测试的重点是检查数据交互、传递、和控制管理过程... 查看详情