自学接口测试系列 —— 自动化测试用例设计基础!

1123 篇文章 44 订阅
830 篇文章 2 订阅

一、接口测试思路总结

❓首先我们在进行接口测试设计前思考一个问题:接口测试,测试的是什么?

❗我们必须要知道,接口测试的本质:是根据接口的参数,设计输入数据,验证接口的返回值。

那么接口测试的范围就包括:围绕参数进行用例的设计----->准备各种各样的数据,对接口的返回值进行验证。

动图

接口测试用例的设计思路涵盖了许多方面,旨在确保测试覆盖面广泛、详尽和有效。以下是我总结出来的一些接口测试用例设计思路:

  1. 正向测试

- 针对接口的正常使用情况编写测试用例,验证它是否按照预期工作。这包括测试各种请求和参数的组合,以确保接口返回正确的结果。

  1. 边界值测试

- 测试接口的边界条件,包括最小和最大值、边界值和特殊字符。这有助于发现潜在的边界错误。

  1. 异常测试

- 针对接口可能遇到的异常情况编写测试用例,包括无效参数、错误请求方法、权限不足等。

  1. 鉴权和授权测试

- 验证接口的鉴权和授权机制是否正常工作,包括测试不同角色的访问权限。

  1. 性能测试

- 编写性能测试用例,测试接口的响应时间、吞吐量和稳定性。这包括模拟不同负载下的请求。

  1. 数据一致性测试

- 测试接口的数据一致性,包括数据的创建、读取、更新和删除操作。确保数据在接口操作后保持一致性。

  1. 数据验证测试

- 验证接口的响应数据是否与预期的数据一致。这包括字段验证、数据类型验证和数据格式验证。

  1. 并发测试

- 测试接口的并发性,包括多个并发请求对接口的影响。确保接口在并发条件下稳定工作。

  1. 安全性测试

- 测试接口的安全性,包括检查是否存在安全漏洞,如SQL注入、跨站点脚本(XSS)等。

  1. 跨域请求测试

- 验证接口是否能够正确处理跨域请求,确保它在不同域之间的通信正常工作。

  1. 回归测试

- 编写回归测试用例,以确保接口在代码更改后仍然按照预期工作。

  1. 异常处理测试

- 测试接口对于错误情况的处理方式,包括检查错误消息、状态码和错误日志。

  1. 性能优化测试

- 测试接口的性能,识别性能瓶颈,并提供性能优化建议。

  1. 缓存测试

- 如果接口使用了缓存,测试缓存的命中率和有效性。

  1. 文档一致性测试

- 检查接口文档与实际接口行为之间的一致性,确保文档准确反映了接口的功能和参数。

  1. 随机测试

- 随机生成请求参数,测试接口的稳定性和容错性。

  1. 复杂场景测试

- 测试接口在复杂场景下的行为,包括多步骤操作、嵌套请求等。

  1. 安全漏洞测试

- 针对常见的安全漏洞进行测试,如跨站点脚本(XSS)、跨站请求伪造(CSRF)等。

这些是设计接口测试用例时可以考虑的不同方面和思路。具体的测试用例设计将根据项目的需求、接口的复杂性和风险因素而有所不同。

那么作为新手刚开始一定需要掌握的常见思路是以下几点:

  • 正确的值
  • 错误的值
  • 异常的值
  • 边界的值
  • 根据场景设计的值
  • ......

即黑盒测试用例设计方法but要尽量根据接口产生画面感。

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:110685036

二、接口自动化测试用例设计要点

❗尽量让人和代码都能够看懂且用得上

❗但是,很多时候我们做不到那就只能分开

(一)设计要点

目标明确:明确测试的目标和预期结果。断言:编写明确的断言来验证接口的响应是否符合预期。
测试覆盖:确保测试用例覆盖了接口的各种功能、参数和边界情况。异常处理:测试接口对于无效输入和错误情况的处理方式,包括检查错误消息和状态码。
数据驱动:考虑使用不同的数据集来测试接口,以确保数据的多样性和完整性。性能测试:如果适用,包括性能测试用例,以测试接口的响应时间、吞吐量和稳定性。
可维护性:编写易于维护的测试用例,使用模块化、可重用的代码和参数化测试数据。报告和日志:生成详细的测试报告,记录测试结果、问题报告和性能数据。此外,考虑生成日志以帮助故障排除。
清晰的命名:使用清晰、有意义的命名来描述测试用例,以便于理解和维护。并发和并行测试:如果需要,编写测试用例来测试接口在并发和并行条件下的行为。
预处理和后处理:在测试用例中考虑预处理和后处理步骤,以确保测试环境的准备和清理。

 

(二)实施前提

API文档:必须有可用的API文档,包括接口端点、请求参数、响应格式、鉴权机制等信息。版本控制:最好将测试用例存储在版本控制系统中,以便跟踪和管理更改。
开发环境:需要可用的开发环境或测试环境,以便执行自动化测试。自动化测试框架:如果需要,可以使用测试框架(如TestNG、JUnit、pytest等)来组织和运行测试用例。
自动化测试工具:您需要选择合适的自动化测试工具,例如Postman、RestAssured、Requests库(Python)等。团队协作:与开发团队和其他相关团队成员合作,以确保测试用例的准确性和及时性。
测试数据:需要准备测试数据,包括有效数据、无效数据和边界数据,以覆盖各种情况。持续集成/持续交付(CI/CD):将自动化接口测试集成到CI/CD流程中,以便在每次代码更改后自动运行测试。
测试环境配置:确保测试环境已正确配置,包括鉴权凭证、访问权限等。监控和报警:建立监控和警报机制,以便在生产环境中检测和响应问题。

 

(三)接口自动化测试用例字段设计

以下是一份较为完善的接口自动化测试用例模板字段:

字段名称描述示例值或说明
用例名称测试用例的名称测试创建用户
用例编号唯一标识符或编号TC001
用例描述测试用例的详细描述测试创建新用户的正常情况。
请求方法HTTP请求方法POST
接口端点要测试的接口的URLhttps://api.example.com/users
请求头部请求中的HTTP头部{"Content-Type": "application/json"}
请求体请求的主体数据(JSON/XML等格式){"name": "John", "email": "john@example.com"}
请求参数请求中的查询参数和路径参数{"id": "12345", "status": "active"}
前提条件测试执行前需要满足的条件用户已登录
测试步骤执行测试用例的具体步骤1. 发送POST请求<br>2. 验证响应状态码<br>3. 验证响应体
预期结果每个步骤的预期结果1. 响应状态码为201<br>2. 响应体包含用户ID
断言用于验证响应的断言语句- 验证状态码是否等于201<br>- 验证响应体中是否包含用户ID
环境变量用于存储和引用环境数据的变量- 用户令牌,用于授权访问
相关链接与测试用例相关的链接或文档- API文档链接
优先级测试用例的优先级
作者编写测试用例的人员姓名或用户名JohnDoe
标签用于分类和检索测试用例的标签功能、创建用户、API

三、接口自动化测试用例书写

  1. 项目实战测试案例

以下是针对项目编写的接口测试用例:

用例编号用例标题请求接口类别请求地址输入数据(分字段)数据格式请求方式是否需要登录期望结果
login-01正确的登录登录/loginWithJwt{"userName":"imooc","password":"12345678"}paramsget010000
login-02错误的登录登录/loginWithJwt{"userName":"imooc","password":"123456789"}jsonget010006
product-01获取商品列表商品列表/product/list00get010000
cart-01添加商品到购物车购物车/cart/list{"count":1,productId":3}formpost110000
cart-02获取购物车列表购物车/cart/list00get110000
cart-03添加错误商品到购物车购物车/cart/list{"count":1,productId":3000}formpost110016
  1. 常见数据结构汇总

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走!

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
 

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值