APIfox自动化编排场景(二)

2024-02-07 10:04
文章标签 场景 自动化 编排 apifox

本文主要是介绍APIfox自动化编排场景(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

测试流程控制条件

你可以在测试场景中新增流程控制条件(循环、判断、等待、分组)等。进一步满足了更复杂的测试场景/流程配置的使用,最终借助自动化测试功能解决复杂场景的测试工作。

分组​

当测试流程中多个步骤存在相关联关系时,可以进行归类并放入到同一个分组中。通过对测试步骤的分组,让测试场景具备更好的可读性和操作性。

示例: 将查看详情宠物详情、修改宠物信息、再次查看详情等步骤归类成分组。

    1. 点击底部的按钮「添加步骤」,并选择「分组」。
    1. 将要归类的步骤,拖到分组步骤下或在分组中直接添加步骤。

image-20210825164712369

ForEach 循环​

在 ForEach 循环中,可以根据设定的某数组内的元素个数,循环执行编排内的全部步骤,循环次数等于数组内的元素个数。还支持提取当前循环的元素值以及当前循环的索引值。

示例:有两个接口分别是获取宠物信息列表获取单个宠物详情。我们的需求是查询在宠物列表中的刚刚新添加进来的宠物详情,按照以下操作即可使用 ForEach 循环在自动化测试中编排出这个场景。

    1. 循环外的第一步是先请求获取宠物信息列表接口,获取到实际的列表数据。一般这种情况接口内是会有一个数组涵盖多个宠物的基本信息,例如宠物 ID、名称。
    1. 设置 ForEach 循环,在循环上设置数组的来源是上一步的响应结果中的宠物信息数组部分。在本例中,写上 data.tags[*].id 可以提取 tags 里的全部 id 值作为一个数组。

    1. 在循环内设置“新建宠物信息”接口请求,并且在此接口设置请求参数 ID 中使用 ForEach 循环(element)里的元素值进行请求。

    1. 若从列表中返回了 3 个宠物信息(数组内有 3 个元素),那么你可以在测试报告中看到“获取宠物信息列表”接口执行了 3 次,每次实际请求的宠物 ID 值是对应“获取单个宠物详情”真实返回的 3 个元素内的 ID 值。

运行“测试报告”后,可以在详情内看到实际请求的值和响应数据相一致。

提示

  • 当前循环 element

系统自动将 ForEach 循环中设置的数组中的元素提取出来保存在此处指定的变量中。每次循环开始时,会基于当前循环的数组素更新这个变量的实际值。如果元素是个对象,可以通过使用 JSONPath 来提取对象中的某个子级字段。例如 {{$.1.element.data.name}}

  • 当前循环 index

当前循环的索引值,会保存在此变量中。从 0 开始,之后每次循环开始时会 +1 更新实际值。

以上两个变量除了可以通过“动态值”交互框进行可视化提取外,同样支持使用变量表达式。

For 循环​

当测试步骤需要重复执行时,可以指定相应的循环次数重复执行。在循环的附加设置中,支持添加“中断条件”和“遇到错误时”的循环异常处理选项。

示例:宠物店 IT 管理员登录宠物库存管理后台,将今日出售的 10 个宠物的在售状态自动批量变更为已售出。

    1. 点击底部的按钮“添加步骤”,并选择“循环”。
    1. 在循环次数中选择“固定值”,输入 10 次。

    1. 将和宠物信息有关的接口拖入该条件下内框中,或直接在该条件下直接添加测试步骤。

提示

当前循环 index

当前循环的索引值,会保存在此变量中。从0开始,之后每次循环开始时,会+1更新实际值。

除了使用“动态值”功能可视化提取使用之外,同样支持使用变量表达式。

条件分支​

当测试流程中存在多条件判断时,可以通过添加条件分支(If 语法)来区分流程执行的步骤。即当判断配置的条件满足时,该判断条件下的子步骤才会执行, 相反子步骤则会被跳过。

示例:宠物店店主根据昨日宠物出售情况,若判断为售出,将该宠物的出售状态设置为“已售出”。否则( else ),查询在售中列表。

    1. 点击底部的按钮「添加步骤」,并选择「条件分支」。
    1. 在 lf 条件后面的输入框填写请求接口得到的变量 saleStatus ,然后选择条件"等于",最后输入比较数值为 true。(当销售状态判断为 true 的时候,则更改宠物信息为「已售出」)
    1. 将鼠标悬浮在该条件分支操作拦会出现「+ Else 」,点击并新增「出售中的宠物列表」步骤(否则,即查询在售中的宠物列表。)。
    1. 将测试步骤拖入到相应的条件分支中。

image-20210825164712369

等待​

当测试流程中某个步骤需要执行后需要等待一段时间时,比如 A 步骤需要等待若干时间后再执行 B 步骤,可以通过新增等待条件来解决。

示例:模拟用户查看宠物详情,浏览 1000ms 后,将该宠物详情信息中的浏览状态进行更新。

    1. 点击底部的按钮「添加步骤」,并选择「等待」。
    1. 输入需要等待的时间 1000(单位毫秒)。

image-20210825164712369

 

 

从接口文档/用例同步数据

简介​

针对从接口文档/用例导入的测试步骤,其请求数据可以和关联的接口文档/用例进行同步。

在测试步骤中导入接口文档/用例时可以选择手动同步自动同步模式。

手动同步模式适合多人分工协作场景,即一个项目中的接口定义、研发、测试流程有着明确分工,每个流程有专门的负责人。流程之间要求数据独立,避免意料之外的改动相互影响。待确保接口文档/用例数据稳定后,测试人员再手动同步至测试步骤。

自动同步模式适合小团队或独立开发者场景,即一个项目中的接口定义、研发、测试流程均由一个角色负责,提升接口维护与测试的效率。当「接口管理」中的接口文档/用例发生变动时,测试步骤中的接口文档/用例数据也将联动调整,确保「接口管理」和「自动化测试」中的数据相一致。

手动同步​

选择手动同步模式,关联按钮将显示为“蓝色”。当「接口管理」中的接口文档有任何改动时,测试步骤中的数据不会实时同步改动内容。测试人员可以在「测试步骤」详情中手动点击「立即同步」按钮将接口文档/用例改动同步至此。

此模式适用于测试角色在保存有大量的接口微调请求参数的实际提测场景,避免这些测试数据受到预期之外的影响,确保测试数据与正在开发的接口数据作出隔离。

在手动同步模式下,关联按钮的下拉框中还支持手动筛选数据的同步范围。

同步接口文档​

如果是从接口文档导入的测试步骤,则其关联内容为接口文档。跟接口文档关联的测试步骤,数据同步方式为手动同步时,通过点击“立即同步”按钮触发同步后,会将接口文档内容同步到此测试步骤中。

信息

触发手动同步后,测试步骤将同步接口文档中的数据,包括参数名及前后置脚本。

测试角色需要在测试步骤中手动点击「立即同步」按钮触发数据同步机制,点击后将提示为“已同步”。确认同步后的数据无误后,还需点击右上角的“保存”按钮保存测试步骤。

同步接口用例​

如果是从接口用例导入的测试步骤,则其关联内容为接口用例。跟接口文档关联的测试步骤,数据同步方式为手动同步时,通过点击“立即同步”按钮触发同步后,会将接口用例内容同步到此测试步骤中。

信息

触发手动同步后,测试步骤将同步接口用例中的数据,包括参数名、参数值及前后置脚本。

在测试步骤中手动点击「立即同步」按钮后触发数据同步机制,点击后将提示为“已同步”。确认同步后的数据无误后,还需点击右上角的“保存”按钮保存测试步骤。

批量同步数据​

若当前测试步骤中大部分引用的接口文档/用例数据采用手动同步模式,而测试人员已经确认这些接口文档/用例的数据无误,希望将数据快速同步至测试步骤中,那么可以在测试步骤页点击“立即同步”按钮执行批量同步操作。

自动同步​

关联按钮将显示为“橙色”。此模式适合小团队或独立开发者场景,即一个项目中的接口定义、研发、测试流程均由一个角色负责。当「接口管理」中的接口文档或用例发生变动时,测试步骤中关联的数据将自动同步并保持一致,提升接口维护与测试的效率。

同步接口文档​

跟接口文档关联的测试步骤,数据同步方式为自动同步时,接口文档有变更被保存,数据将实时更新至此测试步骤中。

在自动同步模式下,测试步骤内的数据与接口文档的数据的不一致会被高亮呈现出来,测试人员可以选择「复原」来保持跟接口文档完全一致;也可以选择「保存到文档」,此时测试步骤内的数据将反向覆写回接口文档,使得两者保持一致。

反向同步后,在接口文档中可以看到新增的参数。

同步接口用例​

与接口用例关联的测试步骤,数据同步方式为自动同步时,接口用例与测试步骤将使用同一套请求数据。为了让这个逻辑更加清晰直观,同时也为了确保「接口管理」对于接口用例数据的管理唯一性,所以变更都需要在「接口管理」中进行调整。

点击测试步骤页面指引中的「去修改」按钮后,前往关联的接口用例页进行调整。测试步骤将自动同步接口用例变更后的数据,包括参数名、参数值及前后置脚本。

 

 

这篇关于APIfox自动化编排场景(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/687361

相关文章

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象

Python中异常类型ValueError使用方法与场景

《Python中异常类型ValueError使用方法与场景》:本文主要介绍Python中的ValueError异常类型,它在处理不合适的值时抛出,并提供如何有效使用ValueError的建议,文中... 目录前言什么是 ValueError?什么时候会用到 ValueError?场景 1: 转换数据类型场景

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

如何使用Ansible实现CI/CD流水线的自动化

如何使用Ansible实现CI/CD流水线的自动化 持续集成(CI)和持续交付(CD)是现代软件开发过程中的核心实践,它们帮助团队更快地交付高质量的软件。Ansible,作为一个强大的自动化工具,可以在CI/CD流水线中发挥关键作用。本文将详细介绍如何使用Ansible实现CI/CD流水线的自动化,包括设计流水线的结构、配置管理、自动化测试、部署、以及集成Ansible与CI/CD工具(如Jen

容器编排平台Kubernetes简介

目录 什么是K8s 为什么需要K8s 什么是容器(Contianer) K8s能做什么? K8s的架构原理  控制平面(Control plane)         kube-apiserver         etcd         kube-scheduler         kube-controller-manager         cloud-controlle

PostgreSQL核心功能特性与使用领域及场景分析

PostgreSQL有什么优点? 开源和免费 PostgreSQL是一个开源的数据库管理系统,可以免费使用和修改。这降低了企业的成本,并为开发者提供了一个活跃的社区和丰富的资源。 高度兼容 PostgreSQL支持多种操作系统(如Linux、Windows、macOS等)和编程语言(如C、C++、Java、Python、Ruby等),并提供了多种接口(如JDBC、ODBC、ADO.NET等