关于RF框架的一些整理
简介和特点RobotFramework 简称RF基于python开发的,可扩展的,以及关键字驱动的自动化测试框架。目前只支持python3.7以下的版本支持数据驱动关键字驱动特点编写测试用例方便,支持robot、txt、tsv、html等格式自动生成html报告自带很多类库,支持很多扩展库可以根据业务逻辑自定义关键字支持非GUI方式运行,还可以和jenkins持续集成环境搭建安装py
目录
简介和特点
- RobotFramework 简称RF
- 基于python开发的,可扩展的,以及关键字驱动的自动化测试框架。目前只支持python3.7以下的版本
- 支持数据驱动
- 关键字驱动
- 特点
-
编写测试用例方便,支持robot、txt、tsv、html等格式
-
自动生成html报告
-
自带很多类库,支持很多扩展库
-
可以根据业务逻辑自定义关键字
-
支持非GUI方式运行,还可以和jenkins持续集成
-
环境搭建
-
安装python3.7
-
安装插件
pip install robotframework -i Simple Index --trusted-host pypi.douban.com
pip install robotframework-ride -i Simple Index --trusted-host pypi.douban.com
安装成功后会生成桌面快捷方式 -
检测是否安装成功: pip list
-
安装谷歌浏览器
-
下载对应版本的浏览器驱动http://chromedriver.storage.googleapis.com/index.html 放到python目录下
类库和标准库
-
标准库 (RF自带的库,不需要额外安装)
Buitln 测试库
Collections 集合库
DateTime 时间库
Screenshot 截屏库
存放位置:Python37\Lib\site-packages\robot\libraries
-
扩展库(需要通过pip额外安装的库)
web自动化测试:SeleniumLibrary 或 Selenium2Library
安装:pip install robotframework-seleniumlibrary
接口自动化测试:RequestsLibrary
安装:pip install robotframework-requests
app自动化测试:AppiumLibrary
安装:pip install robotframework-appniumlibrary
存放位置:Python37\Lib\site-packages
-
在RIDE中,按F5可查看库和关键字
基本使用
- 新建项目
Type要选择Directory - 添加一个目录,可以理解为项目中的一个模块
- 添加测试套件
- 添加测试用例
- 然后就可以在这里编写脚本了
- 运行脚本,运行前要先选择脚本(在前面的checkbox中打勾)
方式一
方式二
一些基本关键字
# F5可查看关键字
# Ctrl+Shift+空格 获得关键字提示
# 定义变量
${a} Set Variable 100# 打印信息
Log ${a}# 获得系统时间
${time} Get Time# 字符串拼接,默认以空格拼接
${str} catenate a b c
# 使用特定字符拼接(如用#拼接)
${str} catenate SEPARATOR=# a b c# 创建列表,得到${a} = ['a', 'b', 'c']
${list} Create List a b c
Log ${list} # 和python一样的列表格式# 另一种列表
@{list} Create List a b c # 适合做循环
# 得到@{a} = [ a | b | c ]
# 需要用Log Many打印
Log Many @{list}
# 打印出 a b c 三个单独的值# 字典关键字,得到${dict} = {'name': '张三', 'age': '24'}
${dict} Create Dictionary name=张三 age=24
# 直接执行python的方法,modules相当于导包
${rand} Evaluate random.randint(1,100) modules=random
${time} Evaluate time.time() modules=time# 可以使用这种方法获取字典的值
${value} Evaluate ${dict}.values()# 执行py文件的方法
Import Library py文件路径
${x} Evaluate int(10)
${y} Evaluate int(20)
${result} sum ${x} ${y} # sum是py文件中的方法,实现加法运算
Log ${result}# 流程控制if
Run Keyword If ${score}<60 Log 不及格
... ELSE IF ${score<80} Log 一般
... ELSE Log 优秀
# for循环写法1
FOR ${a} IN test python java
Log ${a}
END# for循环写法2
@{list} Create List test python java
FOR ${a} IN @{list}
Log ${a}
END# for循环写法3
FOR ${a} IN IN RANGE 1 11 # 相当于Python的 for a in range(1,11)
Log ${a}
Run Keyword If ${a}==6 Exit for Loop # 退出循环
END
# 截图,需导入Screenshot
Take Screenshot
Web自动化
需要安装扩展库:
pip install robotframework-seleniumlibrary 或 pip install robotframework-selenium2library
常用关键字
# 打开浏览器
Open Browser URL地址 chrome# 设置隐式等待
Set Browser Implicit Wait 3# 窗口最大化
Maximize Browser Window# 指定浏览器的尺寸
Set Window Size 600 800# 获得浏览器的宽度和高度
${width} ${height} Get Window Size# 回退
Go Back# 前进
Go To url地址# 刷新
Reload Page# 获取标题
${title} Get Title# 获得地址
${location} Get Location# 关闭浏览器
Close Browser
元素定位
我比较喜欢用xpath和css定位,具体的定位方法以后再补充
操作元素的关键字
Open Browser http://www.baidu.com chrome #打开浏览器
Maximize Browser Window #最大化窗口
Set Browser Implicit Wait 5 #隐式等待
Input Text id=kw 测试 #输入文本
Clear Element Text id=kw #清空文本
${text1} Get Text xpath=//a[@href="http://news.baidu.com"] #获取文本
${text2} Get Element Attribute xpath=//a[@href="http://news.baidu.com"] text #获取文本
${shuxing} Get Element Attribute xpath=//a[@href="http://news.baidu.com"] class #获取元素class属性
Input Text xpath=//input[@id="kw"] 鸽子 #输入文本
Click Element css=#su #点击元素#下拉框选择
Select From List By Index 定位到下拉框 下标 #通过索引选择下拉选项,索引从0开始
Select From List By Label 定位到下拉框 文本 #通过文本定位下拉选项
Select From List By Value 定位到下拉框 Value属性值 #通过Value属性值定位到下拉选项
断言的关键字
系统断言
Should Be Empty ${a} #判断是否为空
Should Be Equal A a #判断相等,区分大小写
Should Be Equal A a ignore_case=True #判断相等,忽略大小写
Should Be True #判断是否为True
Should Contain ceshi es ignore_case=True #是否包含
Should Start With ceshi ce #是否以*开头
Should End With ceshi i #是否以*结尾
Length Should Be ceshi 5 #判断长度selenium断言
Page Should Contain 新闻 #页面是否包含文本
Page Should Contain Element id=kw #页面是否包含元素
元素等待的关键字
Set Browser Implicit Wait 5 #隐式等待,针对当前浏览器
Set Selenium Implicit Wait 5 #隐式等待,针对所有浏览器
Wait Until Element Contains link=新闻 新闻 10 #等待元素包含指定的文本
Wait Until Element Enable link=新闻 新闻 10 #等待元素可用
Wait Until Element Visible link=新闻 新闻 10 #等待元素可见
Wait Until Page Contains 新闻 3 #等待页面包含指定文本
Wait Until Page Contains Element id=kw 3 #等待页面包含指定元素
Frame切换
frameset框架集,frame框架,iframe子框架
当要操作的元素在其他frame中时,需要切换到对应的frame中才能进行定位和操作。frameset不用理会#进入框架
Select Frame name=menu-frame
#跳出框架
Unselect Frame
#跳出框架后可以进入其他框架
弹出框操作
这段是抄来的(`・ω・´)
alert 只有一个确定按钮
confirm 有确定和取消按钮
prompt 有确定、取消还可以输入文本1、Alert Should Be Present
这个关键字不仅仅验证是否存在包含响应arg的弹出框,同时如果存在就执行关闭操作
2、Get Alert Message
用于获取获取警告信息,通常我们会把获取到的文本传递给一个变量,然后打印结果进行查看
3、Confirm Action关闭确认框并返回确认框信息
默认点击确定按钮,如果操作取消按钮,需要在确认框弹出之前预定于“ Choose Cancel On Next Confirm action 再用Confirm Action
4、Input Text Into Prompt文本提示框输入关键字
Input Text Into Prompt [ text ]
用于Alert 弹出文本输入框的输入,配合Confirm Action警告框实现整个文本弹出框的操作
5、Handle Alert
Handle Alert [ action=ACCEPT | timeout=None ] 默认就是点弹出框的确定
Handle Alert action=DISMISS 点取消
切换窗口
Select Window new #切换到新的窗口
Select Window main #切换回初始窗口@{handles} List Windows #获取所有窗口句柄的列表
Select Window @{handles}[-1] #通过句柄选择窗口
Select Window ${title} #通过title选择窗口
三层架构
哪三层?
页面元素层<--业务逻辑层<--测试用例层
业务逻辑层调用页面元素层,测试用例层调用业务逻辑层为什么要分层?
方便管理,提高可维护性
示例:
以百度的搜索功能为例,完成脚本的封装和基础的数据驱动的示例
首先创建项目,添加搜索模块和common目录(用于存放一些公共的方法和数据)
在common下添加Resource(公共元素和公共数据),选择txt格式
在公共数据下添加参数
公共元素可以导入library和resource,并添加user keyword
注意大小写敏感
添加页面元素层
导入library和resource
添加keyword
通过Arguments传入数据
再添加一个点击搜索的keyword
添加业务逻辑层,步骤如上
最后添加测试用例层
先在搜索目录下添加一个测试套件
导入library和resource
添加用例
试运行一下:
最后再改造一下测试用例,实现数据驱动
运行结果
根据不同的数据,分别运行了3次。
再看一下自动生成的报告,默认报告路径(用户名换成自己的) C:\Users\Administrator\AppData\Local\Temp\RIDEkocsbjed.d\
基本的用法就是这样了,但是实际环境肯定复杂的多,还是会有点废头发的。。。
更多推荐
所有评论(0)