ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

RobotFramework接口自动化测试详解

2021-02-01 17:32:04  阅读:2156  来源: 互联网

标签:robotframework Should 关键字 RF 详解 接口 测试 pip RobotFramework


RF框架介绍、RIDE认识+RF环境搭建+自动化测试概述、RF的接口自动化测试、RF的内置测试库【看Robot都有哪些库,最靠谱的方法就是直接上官网查看。
官网地址为:https://robotframework.org】、自定义RF

持续集成自动化测试、DatabaseLibrary库

 

1 Robot Framework框架介绍

  Robot Framework的架构是一个通用的验收测试和验收测试驱动开发的自动化测试框架(ATDD)。

  RF是使用关键字驱动的测试方法

1.1 RF特性

  • 易于使用[表格式语法],统一测试用例格式。
  • 重用性好,利用现有关键字组合新关键字。
  • 易于阅读,结果报告和日志采用HTML格式。
  • 平台和应用程序是独立的。
  • 易于扩展,提供简单的库API,用户可以自定义基于python或java的测试库。
  • 易于集成,提供命令行接口和基于XML的输出文件。
  • 功能全面,为Selenium提供Web测试,Java GUI测试,运行进程,Telnet,SSH等支持。
  • 可以使用关键字驱动、数据驱动和行为驱动开发(BDD)完成。
  • 内置对变量的支持,特别适用于不同环境的测试。
  • 提供tag标签来分类和选择案例执行。
  • 实现与源代码控制的轻松集成:测试套件只是可以使用生产代码进行版本控制的文件和目录。
  • 提供测试用例和测试套件级别的设置和拆卸。
  • 模块化架构支持创建测试,即使对于具有多种不同接口的应用程序。

1.2 RF框架

  RF是一个通用的,应用程序和技术独立的框架,具有高度模块化的架构。

该测试数据是简单,易于编辑表格格式。启动RF时,它会处理测试数据,执行测试用例并生成日志和报告。核心框架对测试中的目标一无所知,与它的交互由测试库处理。库可以直接使用应用程序接口,也可以使用低级测试工具作为驱动程序。

Robot Framework自动化测试框架的组成:

1.3 如何创建一个自动化测试框架

  1. 创建测试项目:测试项目一般创建type选择目录。
  2. 创建测试套件:测试套件与测试项目一致。
  3. 创建测试用例:创建好的测试条件,右击,选择测试用例,输入用例名称。

type的选择:测试项目(directory)-测试套件(file)-测试用例。测试用例只能放在file类型的测试套件下。

fomat的选择:比较推荐robot和txt,在安装VS code的插件后查询.robot文档会自动语法高亮,便于维护和版本管理。

 

1.4 Robot Framework基础关键字

基础关键字

说明

如何搜索 Robot Framework 的关键字

Tools->Search Keywords或F5快捷键

关键字log

输出内容

如何在用例中定义一个变量

Set Variable

如何快速查询某一个关键字的 API 说明

选中关键字,同时按Ctrl+Alt

如何快速补全关键字

Ctrl+Alt+空格键

如何定义一个列表

@{list1}   Create List

如何定义一个字典

&{Dict1}   Create Dictionary

如何拼接两个字符串

Catenate

如何使用 for 循环

:FOR 变量 in 列表或字典

如何中断 for 循环

Exit For Loop If

Run Keyword If 判断的使用

逻辑判断的关键字,如果满足某一个判断条件,就会执行关键字

Comment 关键字的使用

注释,注释的脚本不会被执行

Return From Keyword 和 Return From Keyword If 关键字的使用

脚本执行到该关键字后,会直接返回,不会再执行后面的脚本
用if条件来进行判断,当满足指定的if条件后,就执行retrun返回。返回时和Return From Keyword关键字一样,可以指定返回的具体值

1.5 robot Framework断言关键字

断言关键字

说明

Should Be Equal

用来判断实际结果是否和预期结果相等

Should Be True

用来判断返回值是否为True

Should Contain

用来判断某个字符串中是否包含了我们预期需要的字符或者字符串

Should End With

用来判断某个字符串是否以我们预期指定的字符串来结束

Should Be Empty  

判断是否为空,若不为空,则执行失败

Should Start With

判断某个字符串是否以预期执行的字符串开始,若以指定的字符串开头,则执行成功,否则执行失败

Should Not Start With

与 Should Start With 刚好相反, 若以指定的字符串开头,则执行失败,否则执行成功。

Should Match

判断某个字符串是否与预期指定的字符串相匹配,若可以匹配,则执行成功,否则执行失败

Should Not Match  

与 Should Match 刚好相反,若字符串匹配,则执行失败,否则执行成功

Should Contain X Times


与 Should Contain 关键字类似,用来判断指定的字符串包含指定的字符或者字符串多少次

Should Be Equal As Integers

以整数的形式来进行比较

Should Be Equal As Strings

以字符串的形式来进行比较

Should Be Equal As Numbers

以 number 的形式来进行比较

Should Not Be Equal

与 Should Be Equal 用法相反,当带比较的两个值相等时,执行失败,否则执行成功

Should Not Be Empty

与 Should Be Empty 用法相反,若为空,则执行失败

1.6 BuiltIn库剩余关键字

转换类型关键字

说明

Convert To Binary

将指定的内容转换为二进制形式

Convert To Boolean

将指定的内容转换为布尔类型

Convert To Bytes

将指定的内容转换为字节数

Convert To Hex

将指定的内容转换为十六进制形式

Convert To Integer

将指定的内容转换为 Integer 形式

Convert To Number

将指定的内容转换为 Number 形式

Convert To Octal

将指定的内容转换为八进制形式

Convert To String

将指定的内容转换为字符串形式

 

Get类型关键字

说明

Get Count

获取某个字符串包含指定字符或者字符串的次数

Get Length

获取指定字符串的长度

Get Time

获取时间

Get Variable Value

获取指定变量的值

Get Variables

获取所有的环境变量

2 环境准备

2.1 Python安装

  • 4、python安装后,通过命令:pip list查看pip版本,如果版本低于20,通过命令:python -m pip install --upgrade pip升级pip,便于后面通过pip安装我们所需的包。
#pip版本过低时,升级pip
python -m pip install --upgrade pip

2.2 robotframework-ride安装

  由于不同版本的ride兼容性不一样,优劣势不一样,具体可参考:https://www.cnblogs.com/leozhanggg/p/11698862.html。在这里我们使用1.7.3.1版本。在控制台使用命令安装:pip install robotframework-ride==1.7.3.1。安装成功后,使用命令:pip list 可以在列表中查看。

#支持python3.6及以上,且当前该版本相对稳定
pip install robotframework-ride==1.7.3.1
pip list

 2.3 wxPython、robotframework安装

  RIDE GUI是wxPython实现的,而使用RF框架又要依赖robotframework库。在安装robotframework-ride的时候,pip已经给你安装好了。如果通过命令pip list没有看到wxPython以及robotframework,可以手动安装,通过命令:pip install wxPython==4.0.7.post2 以及pip install robotframework==3.1.2 安装,安装后可以在pip list里面查看到。

#RIDE GUI是wxPython实现,RF框架依赖库robotframework
pip install wxPython==4.0.7.post2
pip install robotframework==3.1.2
pip list

 2.4 启动RIDE

  通过以上步骤就部署好robotframework基础框架了,我们打开python的安装目录下的Script目录,会发现多了一个ride.py和robot.exe文件。可以创建桌面快捷方式,后续启动。 

ride.py就是RIDE GUI的启动程序,我们可以双击启动一下看看是否能够打开RIDE的GUI界面,如果打开后出现下面的界面,说明RIDE工具已经安装成功了。

 PS:[针对3.7.0的python版本]在使用过程中中文会出现乱码的情况。比如我们的用例名是中文,执行用例,日志里会乱码。 解决办法:通过命令:where python查看python安装路径,在安装路径下找到Lib/site-packages/robotide/contrib/testrunner/testrunner.py,477行修改成mbcs。

2.5 安装常用库

  RobotFramework全部内置标准库及第三方库介绍参考:https://blog.csdn.net/weixin_40326608/article/details/101058416 。

我们常用的第三方外置库包括以下:

1、安装requests,主要用于Get、Post等请求。

cmd>pip install requests  (支持第二步,否则RF引入RequestsLibrary库会报错)
cmd>pip install -U robotframework-requests(-U 升级原来已经安装的包,不带U不会装新版本,带上U才会更新到最新版本。)

2、安装mysql,用于对数据库进行操作。

cmd>pip install robotframework-databaseslibrary
cmd>pip install PyMySQL

3、安装ExcelLibrary,用于对表格进行操作。

  目前支持python3.7的excellibrary未更新,一直沿用的是python2.X对应的版本,由于语法上的一些不同,也导致了直接通过pip安装会报错,当提示如图所示错误时:execfile(join(dirname(file), ‘ExcelLibrary’, ‘version.py’)) NameError: name ‘execfile’ is not defined

可以通过修改文件,使excellibrary适用与3.X版本。

首先下载robotframework-excellibrary-0.0.2[建议下载的所有库都去官网进行下载]:https://pypi.org/project/robotframework-excellibrary/0.0.2/

修改以下几个文件:

#1、robotframework-excellibrary-0.0.2,进入对应的包:
A. \robotframework-excellibrary-0.0.2\setup.py
#execfile(join(dirname(__file__), 'ExcelLibrary', 'version.py'))
exec(open(join(dirname(__file__),'ExcelLibrary','version.py')).read())

B. \robotframework-excellibrary-0.0.2\ExcelLibrary\ExcelLibrary.py
将所有的print xxx 语句修改为 print(xxx)

C. \robotframework-excellibrary-0.0.2\ExcelLibrary\__init__.py
#from ExcelLibrary import ExcelLibrary
#from version import VERSION
from .ExcelLibrary import ExcelLibrary
from .version import VERSION 

D. \robotframework-excellibrary-0.0.2\ExcelLibrary\ExcelLibrary.py
#from version import VERSION
from .version import VERSION

#2、文件修改完毕后,cd到\robotframework-excellibrary-0.0.2\路径,通过python setup.py install 安装。
#安装成功后,python路径下在site-packages里可以看到ExcelLibrary包。
cd xx/robotframework-excellibrary-0.0.2
python setup.py install

#安装好相应库后,在使用时,只需要import即可使用。

 3 RF的接口自动化测试

数据驱动测试的核心:测试数据与测试脚本分离,实现测试脚本参数化,提高测试脚本的可重用性。

接口自动化,主要用到了get request和post request。

基于RF的接口测试库,主要包含requests和requestsLibrary(robotframework-requests)。

接口测试:系统之间交互的接口,或者某个系统对外提供的一些接口服务。

cmd>pip install requests  (支持第二步,否则RF引入RequestsLibrary库会报错)
cmd>pip install -U robotframework-requests(-U 升级原来已经安装的包,不带U不会装新版本,带上U才会更新到最新版本。)

requestsLibrary(robotframework-requests)关键字:

  • Create Session:创建一个session,连接某个服务器;
  • Create Ntlm Session:也是创建一个session,只不过加上了域、用户名、密码用于NTLM认证;
  • Get Request:通过GET方式发起请求;
  • Post Request:通过POST方式发起请求;
  • Head Request:发送一个HEAD请求;
  • To Json:将文本转换成json对象;

 4 RF的内置测试库

RF内置库官网文档:http://robotframework.org/robotframework/

https://robotframework.org

常用的测试库:

  • RF自带的测试库-python目录下:\Lib\site-packages\robot\libraries。
  • RIDE加载内置库时,显示的关键字读取路径-python目录下:\Lib\site-packages\robotide\lib\robot\libraries。

RF出了新版后,RIDE未及时更新,导致新的关键字不能被RIDE识别,此时需要把RF自带的测试库下的文件复制到RIDE内置库的取值路径。

 

 

 

标签:robotframework,Should,关键字,RF,详解,接口,测试,pip,RobotFramework
来源: https://www.cnblogs.com/wendyw/p/13234283.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有