接口测试用例设计
2021-12-31 14:52:03 7 举报
AI智能生成
记得点赞,接口测试用例设计
作者其他创作
大纲/内容
一、接口测试流程
1. 需求讨论
2. 需求评审
3. 场景设计
4. 数据准备
5. 执行
二、分析接口文档元素
1. 接口名称
2. 接口地址
3. 支持格式
4. 请求方式
5. 请求参数(参数名称、类型、是否必填、参数说明等)
6. 返回参数(返回码、返回值信息、返回json串信息)
三、如何设计接口测试用例
3.1 为什么要设计测试用例
1. 理清思路、避免漏测
2. 提高测试效率
3. 跟进测试进度
4. 告诉领导做过
5. 跟进重复性工作
3.2 设计接口测试用例从哪些方面考虑
1. 功能
功能是否正常
功能是否按照接口文档实现
正常场景
异常场景
2. 逻辑业务
是否依赖业务、比如是否登录成功
3. 异常测试
参数异常
关键字参数、参数为空、多、少参数、错误参数
覆盖所有的必选参数,组合可选参数,参数有、无或为null,参数的顺序、个数、类型
参数类型数值大小、输入的数值范围,参数字串长短,参数包含特殊字符
数据异常
关键字数据、数据为空、长度不一致、错误数据
4. 安全
Cookie
header
唯一识别码
四、常用的接口测试用例覆盖方法
4.1 必须参数覆盖
对于接口的参数,接口文档一般都会说明哪些儿是必需的,哪儿是非必需的。对于必需的参数,一定要测试传参数和不传参数接口是否报错?
4.2 必须参数各种情况覆盖
传非法的字符,特殊的字符,空值,超过边界的参数是否报错?错误信息是否正确?
4.3 非必须参数覆盖
一般接口对于非必需参数都不会做非正常性传值的判断,所以要测试合法的参数值 ,接口返回的内容是否正确。如果有接口文档说明对非必需参数做了非正常的验证的话,也要对其进行验证。
4.4 参数组合覆盖
有些参数需要相互配合着才起作用,如“offset”和“count”组合起来进行翻页,这个时候要组合起来进行测试。
4.5 业务逻辑相关覆盖
有些接口与业务逻辑关联密切,单独从接口角度测试,可能会遗漏掉一些儿因业务逻辑而产生的bug。所以如果和业务逻辑相关,也要考虑到业务逻辑相关的测试用例。
五、接口测试接口优先级
5.1 优先级 - 针对所有接口
1.暴露在外面的接口,因为通常该接口会给第三方调用
2.供系统内部调用的核心功能接口
3.供系统内部调用非核心功能接口
5.2 优先级 - 针对单个接口
1.正向用例优先测试,逆向用例次之(通常情况,非绝对)
2.是否满足前提条件 > 是否携带默认参值参数 > 参数是否必填 > 参数之间是否存在关联 > 参数数据类型限制 >参数数据类型自身的数据范围值限制
六、 接口测试的设计思路分析
6.1 是否满足前提条件
有些接口需要满足前置条件,才可成功获取数据。常见的,需要登陆Token。
逆向用例:
针对是否满足前置条件(假设为n个条件),设计0~n条用例
针对是否满足前置条件(假设为n个条件),设计0~n条用例
6.2 是否携带默认值参数
正向用例:带默认值的参数都不填写、不传参,必填参数都填写正确且存在的“常规”值,其它不填写,设计1条用例;
6.3 业务规则、功能需求
根据实际情况,结合接口参数说明,可能需要设计n条正向用例和逆向用例
6.4 参数是否必填
逆向用例:
针对每个必填参数,都设计1条参数值为空的逆向用例
针对每个必填参数,都设计1条参数值为空的逆向用例
6.5 参数之间是否存在关联
有些参数彼此之间存在相互制约的关系
逆向用例:
根据实际情况,可能需要设计0 - n 条用例
逆向用例:
根据实际情况,可能需要设计0 - n 条用例
6.6 参数数据类型限制
逆向用例:
针对每个参数都设计1条参数值类型不符的逆向用例
针对每个参数都设计1条参数值类型不符的逆向用例
6.7 参数数据类型自身的数据范围值限制
正向用例:
针对所有参数,设计1条每个参数的参数值在数据范围内为最大值的正向用例
逆向用例:
针对每个参数(假设n个),设计n条每个参数的参数值都超出数据范围最大值的逆向用例
针对每个参数(假设n个),设计n条每个参数的参数值都小于数据范围最小值的逆向用例
针对所有参数,设计1条每个参数的参数值在数据范围内为最大值的正向用例
逆向用例:
针对每个参数(假设n个),设计n条每个参数的参数值都超出数据范围最大值的逆向用例
针对每个参数(假设n个),设计n条每个参数的参数值都小于数据范围最小值的逆向用例
总结:以上几个方面考虑全的话,基本可以做到如下几个方面的覆盖:
• 主流程测试用例:正常的主流程功能校验;
• 分支流测试用例:正常的分支流功能校验。
• 异常流测试用例:异常容错校验
• 主流程测试用例:正常的主流程功能校验;
• 分支流测试用例:正常的分支流功能校验。
• 异常流测试用例:异常容错校验
七、接口测试返回结果的比较
目的
验证代码正常
验证代码正确
1. 比较返回码
2. 比较返回值的完整性,即返回的key全不全
3. 比较key的value数据类型(jsonschema)
4. 比较key对应的value值(也包括验证业务相关数据的value值)
总结:一般接口自动化,通常验证1、2两点即可,第3点根据公司测试周期来评估,而第4点,在功能测试中会验证value值的正确性。
注:jsonschema 是把返回的键 和 键的数据类型定义包,然后保存到文件中,然后和读取到的接口 做键 和值的类型 做比较
注:jsonschema 是把返回的键 和 键的数据类型定义包,然后保存到文件中,然后和读取到的接口 做键 和值的类型 做比较
八、 实践与操作
8.1 接口样例
获取订单列表接口(多条件)
获取店铺指定期间的所有订单列表(多种条件组合),默认根据日期倒序排序。
接口方向
客户端 -> 服务端
接口协议
接口地址:$xxx_Home/xxx/鉴权前缀/xxxxx/getAllOrderList
接口协议:JSON
HTTP请求方式:GET
接口方向
客户端 -> 服务端
接口协议
接口地址:$xxx_Home/xxx/鉴权前缀/xxxxx/getAllOrderList
接口协议:JSON
HTTP请求方式:GET
消息请求,字段列表,如图
子主题
消息请求,样例
?shopId=1111111111&token=123411nmk515155&queryDate=2015-10-10
消息响应,字段列表,如图
消息响应
明细列表
成功时,返回JSON数据包:
子主题
8.2 接口测试用例设计
case1 . 覆盖所有参数,正向用例
data={'shopId':123,'token':'bolixiyang','dataType':1,'startDate':'2016-06-06','endDate':'2016-06-07','orderStatus':'','orderTransactionType':'','payType':'','cashierId':'','billerId':'','pNo':'','pSize':''}
data={'shopId':123,'token':'bolixiyang','dataType':1,'startDate':'2016-06-06','endDate':'2016-06-07','orderStatus':'','orderTransactionType':'','payType':'','cashierId':'','billerId':'','pNo':'','pSize':''}
case2 .覆盖所有必填参数,正向用例
data={'shopId':123,'token':'bolixiyang','startDate':'2016-06-06'}
data={'shopId':123,'token':'bolixiyang','startDate':'2016-06-06'}
case3 .某一必填参数为空,逆向用例
data={'shopId':'','token':'bolixiyang','startDate':'2016-06-06'}
data={'shopId':123,'token':'','startDate':'2016-06-06'}
data={'shopId':123,'token':'bolixiyang','startDate':''}
data={'shopId':'','token':'bolixiyang','startDate':'2016-06-06'}
data={'shopId':123,'token':'','startDate':'2016-06-06'}
data={'shopId':123,'token':'bolixiyang','startDate':''}
case4 .多传一个参数、少传一个参数,逆向用例
data={'shopId':123,'token':'bolixiyang','startDate':'2016-06-06','canshuduo':'123'}
data={'shopId':123,'token':'bolixiyang'}
data={'shopId':123,'token':'bolixiyang','startDate':'2016-06-06','canshuduo':'123'}
data={'shopId':123,'token':'bolixiyang'}
case5 .必填参数数据类型错误,数据值错误,逆向用例
data={'shopId':'123','token':'bolixiyang','startDate':'2016-06-06'}
data={'shopId':666,'token':'bolixiyang','startDate':'2016-06-06'}
data={'shopId':'123','token':'bolixiyang','startDate':'2016-06-06'}
data={'shopId':666,'token':'bolixiyang','startDate':'2016-06-06'}
case6 .任意组合可选参数,正向用例
data={'shopId':123,'token':'bolixiyang','dataType':1,'startDate':'2016-06-06','endDate':'2016-06-07','cashierId':'','billerId':'','pNo':'','pSize':''}
data={'shopId':123,'token':'bolixiyang','dataType':1,'startDate':'2016-06-06','endDate':'2016-06-07','cashierId':'','billerId':'','pNo':'','pSize':''}
case7 .参数数值的范围、参数默认值的范围、字符串的长度,逆向用例
data={'shopId':123,'token':'bolixiyang','startDate':'2016-06-06','orderStatus':'0,1,2,10'}
data={'shopId':123,'token':'bolixiyang','startDate':'2016-06-06','orderStatus':'0,1,2,10'}
case8 .与业务逻辑相关的,token为空或者错误,逆向用例
data={'shopId':123,'token':'','startDate':'2016-06-06'}
data={'shopId':123,'token':'errorToken','startDate':'2016-06-06'}
data={'shopId':123,'token':'','startDate':'2016-06-06'}
data={'shopId':123,'token':'errorToken','startDate':'2016-06-06'}
case9 .字段的唯一性校验,如插入数据userName字段不能重复,发送两次请求,查看第二次返回结果
data={'userName':'bolixiyang'}
data={'userName':'bolixiyang'}
data={'userName':'bolixiyang'}
data={'userName':'bolixiyang'}
8.3 个人对接口的认知
0 条评论
下一页