手把手带你设计接口自动化测试用例(二):根据接口信息设计测试用例

简介: 上一篇文章 手把手带你设计接口自动化测试用例(一):提取接口信息并分析 详细介绍了如何提取并分析登录、发布、修改、删除、查询等接口信息,这篇文章来看一下如何根据接口信息设计测试用例。ZrLog 系统接口测试用例的字段可以设计为 3 个部分,分别是主测试用例的字段(重要)、配置信息的字段、执行结果记录的字段。下面分别介绍这 3 部分字段的名称和含义。

1、设计主测试用例的字段


主测试用例的字段一般包含用例标识的字段、请求信息的字段和响应信息的字段,响应信息的字段一般作为接口用例执行结果的断言字段;另外由于本书的接口涉及 cookies 信息及接口之间的关联信息,所以需要加上 cookies 字段及接口关联字段。基于以上规则,ZrLog 系统主测试用例的字段设计如表1 所示。


表1 主测试用例的字段

image.png


2、设计配置信息的字段


配置信息的字段一般用来存放接口自动化框架中所需要的各类环境配置信息,具体需要哪些字段,在实际中可根据项目需求灵活设置,在 ZrLog 系统中对配置信息设置了 4 个常用字段,如表2 所示。


表2 配置信息的字段

image.png


3、设计执行结果记录字段


执行结果记录的字段主要用来存放测试用例执行的最终结果及相关的信息。具体需要设置哪些字段可根据项目情况灵活决定。


在 ZrLog 系统中对执行结果记录设置了以下常用的 5 个字段,如表3 所示。


表3 执行结果记录的字段

image.png


4、设计主测试用例内容并解决关联关系


接口测试用例与功能测试用例本质上并无区别,常用的设计方法有:有效、无效、边界、错误推测、场景法、正交法等。接口测试包括单接口测试和多接口测试,单接口测试是指针对单个接口的用例设计,而多接口测试是指针对多个接口的用例设计,一般是基于正向的业务流程去设计用例,并且要处理上下游接口的关联关系。


基于此规则,对于文章 手把手带你设计接口自动化测试用例(一):提取接口信息并分析 的 5 个接口,共设计出 11 个测试用例。其中登录接口为单接口,一共设计了 7 个用例;其他的 4 个接口为多个接口,一共设计了 4 个用例。主测试用例的内容及结构如图1、图2所示。


5783138238d186149afe8c543564cb7b.png

 图1 主测试用例的内容及结构(1)


b659687be26dd14c9736cf3d13839318.png

图2 主测试用例的内容及结构(2)


用例分析如下。

  • 第 1 个测试用例为登录接口的测试用例,使用了错误的密码进行登录,登录过程无须携带 cookies,所以 cookies 字段设置为空,登录失败后,预期的业务状态码为 1。如果服务端响应的业务状态码不为 1,则代表此测试用例执行没有通过。
  • 第 2个测试用例为登录接口的测试用例,请求主体信息中不携带密码这个参数,登录过程无须携带 cookies,所以 cookies 字段设置为空,预期的业务状态码为 1。如果服务端响应的业务状态码不为 1,则表明此测试用例执行没有通过。
  • 第 3个测试用例为登录接口的测试用例,请求主体信息中使用了错误的用户名,登录过程无须携带 cookies,所以 cookies 字段设置为空,预期的业务状态码为 1。如果服务端响应的业务状态码不为 1,则表明此测试用例执行没有通过。
  • 第 4个测试用例为登录接口的测试用例,请求主体信息中用户名参数使用非字符串类型的数据,登录过程无须携带 cookies,所以 cookies 字段设置为空,预期的业务状态码为 1。如果服务端响应的业务状态码不为 1,则表明此测试用例执行没有通过。
  • 第 5个测试用例为登录接口的测试用例,请求主体信息中不携带用户名参数,登录过程无须携带 cookies,所以 cookies 字段设置为空,预期的业务状态码为 1。如果服务端响应的业务状态码不为 1,则表明此测试用例执行没有通过。
  • 第 6个测试用例为登录接口的测试用例,请求主体信息中用户名为空字符串,登录过程无须携带 cookies,所以 cookies 字段设置为空,预期的业务状态码为 1。如果服务端响应的业务状态码不为 1,则表明此测试用例执行没有通过。
  • 第 7个测试用例为登录接口的测试用例,请求主体信息中使用了正确的用户和密码进行登录,登录过程无须携带 cookies,所以 cookies 字段设置为空,登录成功之后服务端响应的预期的业务状态码为 0。如果服务端响应的业务状态码不为 0,则表明此测试用例执行没有通过。另外, 用户登录成功之后,会在服务端产生 cookies 信息。在 relation 字段中设置了 token=cookiess.admin-token,它代表的含义是取得 cookies 信息中的 admin-token 字段的值,并把这个值赋给变量 token,以便下游接口引用 token 变量而得到 cookies 的秘钥。
  • 第 8个测试用例为发布文章接口的测试用例,在 cookies 字段中设置了{"admin-token" : "${token}"},这说明发布文章过程中需要携带 cookies信息,且 cookies 信息中键为“admin-token”,其值引用了登录接口中所设置的 token 这个变量。从 request_body 字段的信息中可以看到发布文章的标题(title 为标题参数)为“付出”,文章别名(alias 为别名参数)为“付出”。在文章发布成功后,将会产生文章的 id 号和文章的 alias (文章别名),所以又在 relation 字段中设置了 id_name=body.id,alias_ name=body.alias,它代表的含义是取到响应正文中的 id 号,并把它赋给变量 id_name;同时取到响应正文中的 alias(文章别名),并把它赋给变量 alias_name,以便下游接口可以引用这两个变量。最后,当文章发布成功之后,服务端响应的预期业务状态码为 0。如果服务端响应的业务状态码不为 0,则表明此测试用例执行没有通过。
  • 第 9个测试用例为修改文章接口的测试用例,在 cookies 字段中设置了{"admin-token" : "${token}"},这说明修改文章过程中需要携带 cookies 信息,且 cookies 信息中键为“admin-token”,其值引用了登录接口测试用例中所设置的 token 这个变量。从 request_body 字段的信息中可以看到,文章的 id 号引用的是发布文章接口测试用例中设置的 id_name 这个变量的值,文章的 alias 引用的是发布文章接口测试用例设置的 alias_ name 这个变量,也就是说要修改的文章是 id 为 id_name 的文章,并且在修改过程中把文章的标题修改成了“付出才能杰出”。最后,在文章修改成功之后,服务端响应的预期业务状态码为 0。如果服务端响应的业务状态码不为 0,则表明此测试用例执行没有通过。
  • 第 10 个测试用例为删除文章接口的测试用例,在 cookies 字段中设置了{"admin-token" : "${token}"},这说明文章过程中需要携带 cookies 信息,且 cookies 信息中键为“admin-token”,其值引用了登录接口测试用例中所设置的 token 这个变量。从 request_body 字段的信息中可以看到,要删除的文章的 id 号引用的是发布文章接口测试用例中设置的 id_name这个变量的值,这说明要删除的文章是 id 为 id_name 的文章。最后,在文章删除成功之后,服务端响应的预期业务状态码为 0。如果服务端响应的业务状态码不为 0,则表明此测试用例执行没有通过。
  • 第 11 个测试用例为查询文章接口的测试用例,在 cookies 字段中设置了{"admin-token" : "${token}"},这说明查询文章过程中需要携带 cookies 信息,且 cookies 信息中键为“admin-token”,其值引用了登录接口测试用例中所设置的 token 这个变量。因为此接口的请求方式为 GET 请求,所以 request_body 字段中信息为空,请求的参数直接放在 url 中。最后,由于文章已删除,查询的结果为空才是正常的,服务端响应的预期业务状态码应该为 0。如果服务端响应的业务状态码不为 0,则表明此测试用例执行没有通过。


5、设计配置信息的内容


本框架中所涉及的配置信息是被测环境服务器的 IP 地址,在配置信息中设置服务端的 IP 地址,其原因在于可以将服务器的 IP 地址从接口地址中分离出来,主要是因为一旦服务器的 IP 地址要改变,只需要在配置信息的字段进行更改便可,而不需要到每个接口用例当中对 url 中的 IP 地址进行一一更改,以实现公共数据的分离。在实际项目中具体需要在配置信息的字段中设置哪些内容,可根据项目需求灵活设置。ZrLog 系统配置信息字段的内容如图3所示。

image.png

图3 配置信息字段的内容


6、执行结果记录的内容


执行结果记录字段的内容是由程序运行之后自动填充,无须手工填写。


下一篇文章将分享如何建立数据库实例和主测试用例表,敬请期待!


目录
打赏
0
0
0
0
1026
分享
相关文章
使用ChatGPT生成登录产品代码的测试用例和测试脚本
使用ChatGPT生成登录产品代码的测试用例和测试脚本
59 35
通过ChatGPT生成测试用例和测试脚本(2)
通过ChatGPT生成测试用例和测试脚本
41 21
2025年测试用例管理看这一篇就够了 ----Codes 开源免费、全面的测试管理解决方案
Codes 是国内首款重新定义 SaaS 模式的开源项目管理平台,支持云端认证、本地部署、全部功能开放,并且对 30 人以下团队免费。它通过整合迭代、看板、度量和自动化等功能,简化测试协同工作,使敏捷测试更易于实施。并提供低成本的敏捷测试解决方案,如同步在线离线测试用例、流程化管理缺陷、低代码接口自动化测试和 CI/CD,以及基于迭代的测试管理和测试用时的成本计算等,践行敏捷测试。
2025年测试用例管理看这一篇就够了 ----Codes 开源免费、全面的测试管理解决方案
pytest接口自动化测试框架搭建
通过上述步骤,我们成功搭建了一个基于 `pytest`的接口自动化测试框架。这个框架具备良好的扩展性和可维护性,能够高效地管理和执行API测试。通过封装HTTP请求逻辑、使用 `conftest.py`定义共享资源和前置条件,并利用 `pytest.ini`进行配置管理,可以大幅提高测试的自动化程度和执行效率。希望本文能为您的测试工作提供实用的指导和帮助。
86 15
自动化测试项目学习笔记(三):Unittest加载测试用例的四种方法
本文介绍了使用Python的unittest框架来加载测试用例的四种方法,包括通过测试用例类、模块、路径和逐条加载测试用例。
131 0
自动化测试项目学习笔记(三):Unittest加载测试用例的四种方法
|
4月前
|
测试用例设计方法之基本路径测试法
基本路径测试法是在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例的方法,设计出的测试用例要保证在测试中程序的语句覆盖100%,条件覆盖100%
298 7
测试用例设计方法之基本路径测试法
Hadoop-17 Flume 介绍与环境配置 实机云服务器测试 分布式日志信息收集 海量数据 实时采集引擎 Source Channel Sink 串行复制负载均衡
Hadoop-17 Flume 介绍与环境配置 实机云服务器测试 分布式日志信息收集 海量数据 实时采集引擎 Source Channel Sink 串行复制负载均衡
74 1
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
314 3
快速上手|HTTP 接口功能自动化测试
基于 LangChain 的自动化测试用例的生成与执行
本章节详细介绍了如何利用人工智能技术自动化完成Web、App及接口测试用例的生成与执行过程,避免了手动粘贴和调整测试用例的繁琐操作。通过封装工具包与Agent,不仅提升了测试效率,还实现了从生成到执行的一体化流程。应用价值在于显著节省时间并提高测试自动化水平。
『软件测试2』 关于黑盒测试和测试用例的基础知识
该文章讲解了黑盒测试的基本概念以及如何编写有效的测试用例,包括选择合适的输入数据、预期结果的设定和测试执行的步骤。

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等