Robot Framework完整流程学习系列一

2024-06-17 10:08

本文主要是介绍Robot Framework完整流程学习系列一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.环境搭建
网上有很多的教程,这里就不多讲了
二.RIDE的界面认识
Robot <wbr>Framework完整流程学习系列一
这里只介绍几个重要常用的功能,其他相信自己都能理解
1.Search Keywords(F5): 搜索关键字
Robot <wbr>Framework完整流程学习系列一

2.ContentAssistance:内容助手

Robot <wbr>Framework完整流程学习系列一

 

 

 

3.ViewRIDELog:查看RIDE日志,使用过程中报错,可以来这里查看,寻找报错原因
 
三.最基本的流程
1.NewProject
Type选择Directory,Format选择TXT
Robot <wbr>Framework完整流程学习系列一

2.NewSuite
在Project的基础上Create NewSuite,Type选择File,Format选择TXT
Robot <wbr>Framework完整流程学习系列一

3.NewTestCase
在Suite的基础上CreateNew TestCase
Robot <wbr>Framework完整流程学习系列一

4.NewResource
在Project的基础上Create NewResource
Robot <wbr>Framework完整流程学习系列一

5.New UserKeyword
在Resource的基础上Create UserKeyword
Robot <wbr>Framework完整流程学习系列一

这时候你的RIDE如下图显示就对了
Robot <wbr>Framework完整流程学习系列一


四.工作区EDIT
1.测试套件
Robot <wbr>Framework完整流程学习系列一

大体分成3个部分。

(1):加载外部文件

AddLibrary     :加载测试库,主要是[PYTHON目录]\Lib\site-packages里的测试库

AddResource:加载资源,主要是你工程相关的资源文件

AddVariables:加载变量文件,不怎么用,可暂时忽略

(2):定义内部变量

AddScalar:定义变量

AddList:定义列表型变量

(3):元数据定义

AddMetadata:定义元数据。我是直接翻译的,这个是新增加的部分,大概看了一下作用是在report和log里显示定义好的内容,格式和document一样。

 

2.添加Resource(在Suite中

Robot <wbr>Framework完整流程学习系列一

 

3.添加Library(在Suite中

Robot <wbr>Framework完整流程学习系列一

4.添加成功的标志,在Source中出现Selenium2Library和res1

Robot <wbr>Framework完整流程学习系列一

 

5.setting(包括Project,Suit,Case,Resource,UserKeywords图片就不一一上传了)

Robot <wbr>Framework完整流程学习系列一

Documentation:文档,每一项都有。可以给当前的对象加入文档说明。

SuiteSetup指的是测试套件启动的时候就执行某个关键字。(例:我在SuiteSetup设置了Sleep | 5sec,表示等待5秒,要注意关键字的参数要使用 |分隔)

TestTeardown指的就是案例结束的时候执行某个关键字。

TestTemplate:测试模版,这是可以指定某个关键字为这个测试套件下所有TestCase的模版,这样所有的TestCase就只需要设置这个关键字的传入参数即可。

TestTimeout:设置每一个测试案例的超时时间,只要超过这个时间就会失败,并停止案例运行。这是防止某些情况导致案例一直卡住不动,也不停止也不失败。

ForceTags:这里还是要说一下,在文件型Suite这里还可以继续给子元素增加ForceTags,但是他不能删除父元素设置的tags

DefaultTags:默认标记,其实和Force Tags没啥区别的

Arguments:传入参数

Return Value:返回值

 

五.工作区RUN

 

Robot <wbr>Framework完整流程学习系列一

 ExecutionProfile:选择运行方式,里面有pybot、jybot和customscript。其中我们默认是用pybot来运行案例,jybot需要安装Jython的支持。customscript是选择自定义的脚本来运行。就目前而言,我们不用修改了,默认pybot即可

 Start和Stop:这两个应该不用说了,运行和停止案例。

 Report和Log:报告和日志,要运行之后才能点击。他们的区别么,我的感觉是报告更多是结果上的展示,日志更多是过程的记录,更多使用的还是日志。

 Autosave:自动保存,如果不勾选,在修改了案例之后如果没有保存的话,运行案例时会提示是否保存。勾选则在运行时自动保存了。

 Arguments:pybot的参数(或者jybot等),比如我后面截图里加上了一个参数。完整版的参数可以在doc命令行输入pybot.bat--help

Only Run Tests withthese Tags: 只运行这些标记的测试案例。

Skip Tests with theseTags: 跳过这些标记的测试案例

 

六.案例设计之流程与数据分离1 

 

 1.创建案例

Robot <wbr>Framework完整流程学习系列一

 

这算是一个比较完整的案例了,包含完整的流程和检查点,那么这时候如果我要增加一个案例,搜索另外的内容怎么办呢?

在原来的case上修改肯定是不合适的,毕竟那个案例可能还是需要保留的。

最简单的办法,把这个case复制一个,修改搜索内容。那么我们复制出一个case2吧

 

Robot <wbr>Framework完整流程学习系列一

2.分层方法

选中case中的所有脚本,点击右键,选择ExtractKeyword

Robot <wbr>Framework完整流程学习系列一

而我们再看case的内容就只有这个关键字了

Robot <wbr>Framework完整流程学习系列一

新建一个Resource文件,把UserKeyword移动过去(或者移动到已有的Resource文件里)

这样做的目的是为了更清晰,在测试套件中一般不放置UserKeyword,前面第2讲的时候我们就说过了,首要建议UserKeyword放在Resource里。

我这里新建一个Resource,叫TestFlow.txt,然后把这个搜索测试移动过去,就成了这样。

 

接下来我们针对这个测试流程进行分离,因为这个案例流程比较简单,实际上就只有搜索内容这一个值是变化的,因此我们把他改成一个变量,同时把这个UserKeyword的参数加上这个变量。

Robot <wbr>Framework完整流程学习系列一

再回头看看case的内容和添加内容

Robot <wbr>Framework完整流程学习系列一
可以运行试试看

到现在我们完成了一个简单的分层,把搜索测试这个流程剥离成一个关键字,然后在不同的case调用这个关键字,然后传递不同的参数,用以进行不同数据在同一个流程下的测试。

这样就不用担心再新增10个或100个案例了,因为这个案例比较简单,通过复制也可以做出10个或100个案例,但是最大的区别在于,如果我的流程中间需要做一点小的调整和优化,对于流程和数据分离的案例来说,我这样维护一下搜索测试这个UserKeyword就行了;对于复制的案例,那你就要辛苦了,你有多少个案例就改多少吧。

其实这个道理引申出来,我们做自动化测试也是一样,选择不同的方法或者工具都可以实现最终的目标,但是我们需要考虑的不是把案例做起来,因为这个比较容易实现。对于自动化案例来说,最大的难度不是在于怎么做案例,而是怎么维护案例。因为随着需求的更新,系统的流程或者页面会发生很多的变化,这时候的维护成本的高低才是我们首要考虑的,如果自动化案例建立起来之后,没有后续维护的投入,最终经过若干个版本,这些自动化案例基本就是废弃的了。

 

 

七.案例设计之流程与数据分离1

 

将搜索测试中的内容继续分层,还是要把一些底层的代码级关键字继续拆分出来

下面对res1.txt进行操作

 

1.打开浏览器

Robot <wbr>Framework完整流程学习系列一


 2.输入搜索内容

Robot <wbr>Framework完整流程学习系列一

3.点击搜索

Robot <wbr>Framework完整流程学习系列一

4.校验标题

Robot <wbr>Framework完整流程学习系列一

5.关闭浏览器

Robot <wbr>Framework完整流程学习系列一

 

接着我们把对应的搜索测试中的代码都换成相应的关键字,记得添加参数${url}


Robot <wbr>Framework完整流程学习系列一

最后该运行了

Robot <wbr>Framework完整流程学习系列一

至此,我们这个案例就已经完成分层了,因为案例比较简单,所以只分了3层,分别是案例层,流程层,元素层。他们的调用关系也是逐层深入的

Robot <wbr>Framework完整流程学习系列一

=============总结一下=============

这样做的好处不单是为了以后维护方便,也使得案例的架构层级清晰。越是靠近上层的部分,脚本越贴近自然语言,或者说很像我们的测试案例;越靠近下层的部分,越是接近页面元素的代码级部分。这样以后如果发生维护的时候,根据需要维护的内容,只需要在很少的地方进行调整即可。比如一个元素的id变了,那我只要在elements里面更新就行了。比如测试的流程调整了,以前是ABC的页面顺序,现在是ACB的页面顺序,那么只要在testflow层进行调整即可。

那么回到我们的标题,流程与数据分离,实际上目前我们的流程都集中在testflow以及下面的部分,而数据一般都是在案例层去给流程层传递,这就是我们的流程与数据分离了。当然,我们还可以再进一步的分离,把数据放到外面,脱离我们的案例,在运行的时候才传递进行,也是可以实现的。


转载自--http://blog.sina.com.cn/s/blog_63d6e6400102vsti.html

这篇关于Robot Framework完整流程学习系列一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

PyCharm 接入 DeepSeek最新完整教程

《PyCharm接入DeepSeek最新完整教程》文章介绍了DeepSeek-V3模型的性能提升以及如何在PyCharm中接入和使用DeepSeek进行代码开发,本文通过图文并茂的形式给大家介绍的... 目录DeepSeek-V3效果演示创建API Key在PyCharm中下载Continue插件配置Con

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

springboot启动流程过程

《springboot启动流程过程》SpringBoot简化了Spring框架的使用,通过创建`SpringApplication`对象,判断应用类型并设置初始化器和监听器,在`run`方法中,读取配... 目录springboot启动流程springboot程序启动入口1.创建SpringApplicat

本地搭建DeepSeek-R1、WebUI的完整过程及访问

《本地搭建DeepSeek-R1、WebUI的完整过程及访问》:本文主要介绍本地搭建DeepSeek-R1、WebUI的完整过程及访问的相关资料,DeepSeek-R1是一个开源的人工智能平台,主... 目录背景       搭建准备基础概念搭建过程访问对话测试总结背景       最近几年,人工智能技术

SQL Server数据库迁移到MySQL的完整指南

《SQLServer数据库迁移到MySQL的完整指南》在企业应用开发中,数据库迁移是一个常见的需求,随着业务的发展,企业可能会从SQLServer转向MySQL,原因可能是成本、性能、跨平台兼容性等... 目录一、迁移前的准备工作1.1 确定迁移范围1.2 评估兼容性1.3 备份数据二、迁移工具的选择2.1

通过prometheus监控Tomcat运行状态的操作流程

《通过prometheus监控Tomcat运行状态的操作流程》文章介绍了如何安装和配置Tomcat,并使用Prometheus和TomcatExporter来监控Tomcat的运行状态,文章详细讲解了... 目录Tomcat安装配置以及prometheus监控Tomcat一. 安装并配置tomcat1、安装

MySQL的cpu使用率100%的问题排查流程

《MySQL的cpu使用率100%的问题排查流程》线上mysql服务器经常性出现cpu使用率100%的告警,因此本文整理一下排查该问题的常规流程,文中通过代码示例讲解的非常详细,对大家的学习或工作有一... 目录1. 确认CPU占用来源2. 实时分析mysql活动3. 分析慢查询与执行计划4. 检查索引与表

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...