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

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

一、功能性用例设计

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

举个例子,目前有一个接口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代码,看服务端如何处理……

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

时间: 2024-12-18 10:38:15

服务端测试之接口测试用例设计的相关文章

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

提起服务端测试,第一反应想到的可能就是http协议.socket连接.post/get发送请求等等.回想起小编当时初次接触服务端测试,真可谓一脸懵逼,不知道要干什么也不知道从哪儿开始做.服务端测试往往呈现给大家的是一个很大很宽泛的任务,我们知道要做服务端测试但却不知道怎么做,流程是啥,用什么工具去做,要达到什么样的效果.今天小编就结合最近自己做的一些服务端测试的任务,和大家聊聊服务端测试中的一个常见方法--接口测试. 一.什么是接口测试 先来看看接口测试的定义: 接口测试是测试系统组件间接口的一

(转)【腾讯 TMQ】 接口测试用例设计

导语 这是我在其他的开源社区看到的一篇分享帖子.这篇文章的目的只是为大家提供一个思路,但是实现成本太高了,因为一个接口设计的接口测试用例很多,一般公司的接口数量几百到上千不等,每一个接口都设计这么多测试用例,那么对于测试来说,这样的话会死人的!所以此篇文章旨在给大家一个接口测试的思路,抛开成本,从技术上面来说,这个文章写得无可挑剔的! 随着测试分析和分层测试的深化,"接口测试"出现在我们视野的频次越来越高.那么接口测的用例设计常用哪些方法呢?本文将详细描述. 1 接口测试 1.1 接口

以网游服务端的网络接入层设计为例,理解实时通信的技术挑战

本文参考并引用了部分腾讯游戏学院的相关技术文章内容,感谢原作者的分享. 1.前言 以现在主流的即时通讯应用形态来讲,一个完整的即时通讯IM应用其实是即时通信(英文简写:IM=Instant messaging)和实时通信(英文简写:RTC=Real-time communication)2种技术组合在一起的一整套网络通信系统.之所以以IM这个简写代称整个即时通讯软件,其实是历史原因了(因为早期的诸如ICQ这样的即时通讯工具,也就是文字聊天,并没有加入实时音视频这样的实时通信技术),对这个话题有兴

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

随着测试分析和分层测试的深化,"接口测试"出现在我们视野的频次越来越高.那么接口测的用例设计常用哪些方法呢?本文将详细描述. 1  接口测试 1.1  接口测试 接口:主要是子模块或者子系统间交互并相互作用的部分. 这里说的接口是广义的,客户端与后台服务间的协议:插件间通信的接口:模块间的接口:再小到一个类提供的方法:都可以理解为接口. 接口测试:是指针对模块或系统间接口进行的测试. 1.2  接口测试发现的典型问题 接口测试经常遇到的bug和问题,如下: (1)传入参数处理不当,导致

python的flex服务端数据接口开发

python的flex服务端数据接口开发 python 如果给flex提供服务端,需要提供一个网关和一个可供客户端(flex)调用的类.这方面我更加推荐用twisted来写这个网关,因为twisted有很好的异步机制. 下面的我写的一个简单的验证用户的python服务端: ______________________________DBServer.py # Copyright (c) 2009-2010 The Newjh Project."""@author: Roy@s

关于接口测试用例设计的一些思考

接口测试发现的典型问题 传入参数处理不当,引起程序错误 类型溢出,导致数据读取和写入不一致 对象权限校验出错,可获取其他角色信息 状态出错,导致逻辑处理出现问题 逻辑校验不完善 定时任务执行出错 接口测试用例设计 接口测试用例设计主要针对输入.处理.输出进行考虑 针对输入进行设计 对于接口来说,输入就是入参,一般的参数类型 数值型 边界内.边界值.边界外三个方面去考虑 特殊值处理不当程序异常.类型边界溢出.错误信息返回不正确 字符串 主要考虑字符串长度和字符串的内容 空.特殊字符.数字.表情符号

CMDB3 完善采集端代码(ssh方案的多线程采集), 异常处理, 服务端目录结构的设计(django的app), API数据分析比对入库

完善一下采集端代码 ssh方案的多线程采集 线程和进程,协程的区别 (90% 问到) 提高并发的话,使用多线程 python2 多进程有 多线程没有 python3 多进程有 多线程有 from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor p = ThreadPoolExecutor(10) def test(i): time.sleep(1) print(i) for i in range(100): p.s

接口测试用例设计实践总结

设计思路 1)   优先级--针对所有接口 1.暴露在外面的接口,因为通常该接口会给第三方调用: 2.供系统内部调用的核心功能接口: 3.供系统内部调用非核心功能接口: 2)   优先级--针对单个接口 1.正向用例优先测试,逆向用例次之(通常情况,非绝对): 2.是否满足前提条件 > 是否携带默认参值参数 > 参数是否必填 > 参数之间是否存在关联 > 参数数据类型限制 >参数数据类型自身的数据范围值限制 3)   设计分析 通常,设计接口测试用例需要考虑以下几个方面: 1

接口测试用例设计

转载:http://blog.sina.com.cn/s/blog_13cc013b50102w1ot.html 设计思路 1)   优先级--针对所有接口 1.暴露在外面的接口,因为通常该接口会给第三方调用: 2.供系统内部调用的核心功能接口: 3.供系统内部调用非核心功能接口: 2)   优先级--针对单个接口 1.正向用例优先测试,逆向用例次之(通常情况,非绝对): 2.是否满足前提条件 > 是否携带默认参值参数 > 参数是否必填 > 参数之间是否存在关联 > 参数数据类型限