RobotFrameWork接口项目分层及通用控制方式

简介: RobotFrameWork接口项目分层及通用控制方式

微信图片_20220522140356.png

1前言



   

   上一篇文章介绍了在设计接口用例之前应遵守的设计规范,详见《RobotFramework接口设计规范》,当然读者公司的内部规范也不一定非得完全遵循笔者所提到的,适合自己公司内部的一套就可以了。


由于现在公司新项目的启动和自身负责的开发工作量的增剧,基本上更新文章都只能利用周末零碎时间来写,一个字一个字的码出来的,另外透露一下,下面分享的内容有部分核心思想笔者是将之前发表过的技术专利中的内容开放了一小部分哦,还是有些干货内容值得借鉴的,也希望各位读者多多支持一下。


接下来,我们来聊聊,RobotFramework接口设计的分层玩法和常用的控制方式。


2RF分层推荐玩法


   

   说到分层,大家最容易想到的就是著名的测试金字塔的分层结构,如:


微信图片_20220522140952.png

   

那么RobotFramework设计的接口框架分层该怎么来分呢,当然分层的好处和作用笔者就不在这里过多的说了,也不是本文的重点,相信大家也都能体会到。


分层原则

分层目标:接口数据和接口业务分离


可再细分为

  • 项目目录结构分层
  • 接口数据、接口用例、接口业务分离
  • 公共方法、数据分离


3分层实施



3.1、项目结构分离


       具体要实施接口自动化的产品项目,一般可作为一个自动化工程的主目录。

其中,项目主目录中,按分层思想,又可根据接口功能分成不同模块,不同模块可作为二级目录。在这里模块可划分成两类,一类为按功能模块,在命名时,以具体功能作为命名,如评论模块,可命名为Comment,且功能模块主要用来验证某个单一模块下各接口功能上是否符合预期,另一类为模块业务,在命名时,以Business命名,所有业务功能验证均存放在此目录下,主要用来验证实现具体业务功能时,各接口的关联组合调用验证,如验证某个视频播放功能时,其中,对于视频播放这一具体的业务来说可能会涉及到很多接口之间的调用,包括接口前置条件,接口之间传递数据,接口数据清理等。


*项目的功能模块划分以具体的项目而定,在实际的接口自动化项目开展中,需要求开发人员,提供项目接口对接文档。接口测试人员,依据接口对接文档描述,划分具体的功能模块及某个功能模块下包含了哪些具体接口。


3.2、接口业务分离


不同接口模块下,又可根据子功能的不同,划分成不同接口。主要又包含两部分,一部分为接口业务关键字(对应在其它编程语言中,这里所说的关键字,其实就是封装的函数、方法),通常一个接口下,可以根据测试的业务不同,定义多个不同的关键字。另一部分就是接口功能用例,接口用例下仅需填测试数据即可。通常不同的用例存放不同的测试数据,即业务关键字的入参,业务关键字根据接收到不同测试数据而去自动执行对应的业务流程。


*通常将具体的一组动作序列封装一个业务关键字,测试用例中之所以只存放测试数据的设计核心就是在于将测试业务与测试数据分离。因为通常测试过程中,一个业务关键字的动作序列不会经常变更,需要变更的是测试数据,通常不同的测试数据,会导致业务关键字的产生的结果不同。



3.3、公共方法数据分离

包括三部分,公共方法(Public)、项目配置文件(Config)、数据构造文件(xx_var.py)。其中:


公共方法主要提供各个不同项目接口之间都会调用到的一些公共方法,如数据加密、解密,接口数据校验、接口统计等。


主配置文件主要存储接口在各个不同环境下(通常一个产品,开发完成后,都需要在测试环境验证通过后,才可发布到线上环境,这里所说的不同环境指的就是测试环境、线上环境)的访问地址,通常做法可在业务关键字编写脚本时,将接口访问地址通过变量来控制,然后此变量访问主配置文件对应的接口地址即可,通常接口环境分定义为测试环境下的接口访问地址、预发布环境接口地址、线上接口环境地址等(可参照下述截图部分)。


数据构造文件由于在不同环境下,需要用到的测试数据可能会有所不同,所以可通过构建对应环境下的变量文件来为接口在不同环境下执行时提供测试数据,变量控制文件中主要存储一些可变的变量文件,或通过函数来构造测试数据然后再将构建数据方法返回到具体变量中提供给测试用例或业务关键字使用。


数据控制文件的设计核心在于,在变量文件中定义构造数据的函数方法,然后将方法的返回值赋给一个变量,在具体的接口引用该变量。



4实例化图解框架分层



4.1

功能模块分层实例图解


微信图片_20220522141038.png


4.2

业务模块分层实例图解


微信图片_20220522141107.png


4.3 公共库实例图解

1、在关键字头部,引入Library后面填入公共方法存放文件的路径

微信图片_20220522141132.png


2、或通过RIDE导入的方式引入,RIDE导入的方式,只需选择右侧按钮,如导入关键字,只需点击右侧Library按钮,选择关键字路径即可。

微信图片_20220522141159.png



5通用控制方式



这里主要介绍一下接口数据、接口用例、接口业务分离的通用控制方式:


  • 接口数据与接口用例分离

微信图片_20220522141229.png


提倡大家在测试用例中仅包括数据,也就是入参!!!(重要的事情,只说一遍!!!)


大家可以看到在测试用例中的入参数据有两处的数据是通过变量自动构造生成的,(一个是评论信息,另一个是登录用户名),这也是上面提到数据构造文件的作用。将数据构造的方法传入到变量,在用例层引入该变量即可,如:


微信图片_20220522141310.png微信图片_20220522141323.png


  • 接口用例与接口业务分离



微信图片_20220522141402.png微信图片_20220522141431.png



写完之篇后,发现清早已花了一个多小时来码这篇文章了,如果大家觉得本文还是有些地方对大家有用,在下面打赏鼓励一下哦~




6教程目录大纲(已更新)



RobotFrameWork系列免费课程大纲介绍


RobotFrameWork环境搭建(基于HTTP协议的接口自动化)


RobotFrameWork接口设计规范


7下节预告


《RobotFrameWork编写接口测试及如何断言》

目录
相关文章
|
4月前
|
存储 NoSQL 数据处理
组合和继承怎么集成一个性能较好的项目
组合与继承是面向对象编程的核心概念,前者通过对象间关联实现高效解耦,后者则重用代码以节省空间和内存。组合常用于现代项目,利用代理与依赖注入简化代码管理;而继承简化了子模块对父模块资源的应用,但修改会影响整体。随着分层解耦及微服务架构如SpringCloud的出现,这些技术进一步优化了数据处理效率和服务响应性能,尤其在分布式存储与高并发场景下。同步异步调用、Redis分布式应用等也广泛运用组合与继承,实现代码和内存空间的有效复用。
|
7月前
|
运维 JavaScript Serverless
函数计算产品使用问题之构建自己的流水线时,已经有一个基础第三方包的层,想在这个基础上进行额外的第三方包安装,该如何实现
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
8月前
|
人工智能 大数据 5G
400G光模块已经部署,需求将进一步扩大
2023年底,电信运营商完成400G OTN试验网设备部署,标志着400G技术大规模部署的开端。400G传输技术日趋成熟,预计2024年实现长距离商用。400G光模块在提升数据传输效率、降低能耗方面发挥关键作用,适应云计算、大数据、AI对高效算力的需求。光纤技术行业显现复苏态势,400G光模块部署成为数据中心发展的必然,支持新兴技术发展。随着5G、云计算等技术进步,对高速光模块需求激增,推动光纤行业创新与市场扩张。
86 2
|
8月前
|
开发者 索引 容器
【鸿蒙软件开发】Stage模型开发概述应用/组件级配置
【鸿蒙软件开发】Stage模型开发概述应用/组件级配置
423 0
【鸿蒙软件开发】Stage模型开发概述应用/组件级配置
|
数据采集 算法 数据可视化
MMdetection框架速成系列 第03部分:简述整体构建细节与模块+训练测试模块流程剖析+深入解析代码模块与核心实现
按照抽象到具体方式,从多个层次进行训练和测试流程深入解析,从最抽象层讲起,到最后核心代码实现,希望帮助大家更容易理解 MMDetection 开源框架整体构建细节
623 0
|
编解码 前端开发 数据处理
前端基础向--从项目入手封装公共组件
前端基础向--从项目入手封装公共组件
317 0
|
jenkins 测试技术 持续交付
python接口自动化(三十六)-封装与调用--流程类接口关联续集(详解)
上一篇已经给大家都介绍过了流程类接口关联,但是由于博客的登录机制改变,所以没有办法给小伙伴们实战演练一下,那么这篇就按照上一篇计划的用jenkins来给小伙伴们演示一下流程类接口的封装和调用,其实很简单,就是用上一篇和前边这篇传送门的代码稍稍修改即可。不知道你自己练习了么,如果练习了,可以看看和我有什么不同,没练习的看看自己思路和我有啥不一样。好了废话少说进入主题
207 0
python接口自动化(三十六)-封装与调用--流程类接口关联续集(详解)
|
Java 调度 开发工具
QuickTask动态脚本支持框架整体介绍篇
一个简单的动态脚本调度框架,支持运行时,实时增加,删除和修改动态脚本,可用于后端的进行接口验证、数据订正,执行定时任务或校验脚本
267 0
QuickTask动态脚本支持框架整体介绍篇
|
安全 Java 容器
5-基础构建模块
5-基础构建模块
214 0
|
Cloud Native JavaScript Serverless
开发函数计算的正确姿势——使用交互模式安装依赖
函数计算以 Zip 压缩文件格式作为约定的交付物,交付物通常包含代码和依赖库文件。这些依赖库文件通常分为系统依赖(使用 apt-get 包管理安装的库)和语言运行时依赖(使用语言相关的包管理器如 npm、pip 安装的库)。安装这些依赖库时开发者需要一个交互式的沙箱环境一便于了解:已经安装了哪些软件,某个目录下有些什么文件 以及文件的内容以及属性是什么。
开发函数计算的正确姿势——使用交互模式安装依赖