2.3.1测试用例文件

Robot Framework测试用例使用测试用例文件中的测试用例表创建的。这样的文件会自动从它包含的所有测试用例中创建一个测试套件。可以有多少测试用例没有上限,但建议少于10个,除非使用数据驱动方法,其中一个测试用例只包含一个高级关键字。

设置表中的以下设置可用于自定义测试套件:

注意

所有设置名称都可以选择在末尾包含冒号,例如Documentation: 。这可以使设置更容易阅读,尤其是在使用纯文本格式时。这是Robot Framework 2.5.5中的一项新功能。

2.3.2测试套件目录

测试用例文件可以组织到目录中,这些目录可以创建更高级别的测试套件。从目录创建的测试套件不能直接包含任何测试用例,但它包含其他带有测试用例的测试套件。然后可以将这些目录放入其他目录中,从而创建更高级别的套件。结构没有限制,因此可以根据需要组织测试用例。

执行测试目录时,它包含的文件和目录将按递归方式处理,如下所示:

  • 名称以点(.)或下划线(_)开头的文件和目录将被忽略。
  • 名称为CVS的目录将被忽略(区分大小写)。
  • 不在以下已识别的扩展名(.html, .xhtml,.htm,.tsv,.txt,.rst或.rest)的文件将被忽略(不区分大小写)。
  • 其他文件和目录都将被处理。

如果处理的文件或目录不包含任何测试用例,则会以静默方式忽略它(将消息写入syslog)并继续处理。

警告无效文件

通常,使用写入syslog的消息将忽略没有有效测试用例表的文件。从Robot Framework 2.5.5开始,可以使用命令行选项--warnonskippedfiles,它将消息转换为测试执行错误中显示的警告。

初始化文件

从目录创建的测试套件可以具有与从测试用例文件创建的套件类似的设置。因为目录本身不能包含那种信息,所以必须将其放入特殊的测试套件初始化文件中。初始化文件与测试用例文件具有相同的结构和语法,但它们不能包含测试用例表,并且不是所有设置项都支持。

初始化文件名必须始终为__init__.ext格式,其中扩展名必须与支持的文件格式之一匹配(例如,__init__.html__init__.txt。该名称格式来自Python,以这种方式命名文件表示该目录是一个模块。

初始化文件的主要用途是与测试用例文件类似,可以指定与测试套件相关的设置,但也可以设置一些与测试用例相关的设置初始化文件中创建或导入的变量和关键字在子测试套件中不可用**,但是可以使用资源文件共享资源。

如何在初始化文件中使用设置:

  • Documentation, Metadata, Suite Setup, Suite Teardown

    这些特定于测试套件的设置与测试用例文件中的工作方式相同。

  • Force Tags

    指定的标记无条件地设置为此目录直接或递归包含的所有测试用例文件中的所有测试用例。

  • Test Setup, Test Teardown, Test Timeout

    将test setup/teardown或test timeout的默认值设置为此目录包含的所有测试用例。可以在较低级别覆盖。Robot Framework 2.7中添加了对初始化文件中定义测试超时的支持。

  • Default Tags, Test Template

    初始化文件不支持。

    Setting Value Value
    Documentation Example suite  
    Suite Setup Do Something ${MESSAGE}
    Force Tags example  
    Library SomeLibrary  
    Variable Value Value
    ${MESSAGE} Hello, world!  
    Keyword Action Argument Argument
    Do Something [Arguments] ${arg}  
      Some Keyword ${arg}  
      Another Keyword    

2.3.3测试套件名称和文档

测试套件名称由文件或目录名构成。创建套件名称好处是可以忽略文件的扩展名,下划线使用空格替换,完全小写的名称将转为标题格式。例如,some_tests.html变为Some TestsMy_test_directory变为My test directory

注意

在Robot Framework 2.5中,创建测试套件名称的规则略有不同。

文件或目录名称可以包含用于控制套件执行顺序的前缀。前缀通过两个下划线与基本名称分隔,并且在构造实际测试套件名称时,前缀和下划线都将被删除。例如,文件 01__some_tests.txt02__more_tests.txt分别创建测试套件Some TestsMore Tests,前者在后者之前执行。

使用 “设置”表中的“Documentation”设置测试套件的文档。它可以在测试用例文件中使用,也可以在更高级别的套件中用于测试套件初始化文件。测试套件文档用法和之前创建测试用例章节中的用法一样。

Setting Value Value Value
Documentation An example test suite documentation with some formatting.
... See test documentation for more documentation examples.

在测试执行中,可以覆盖顶级测试套件的名称和文档。这可以分别使用命令行选项--name--doc来完成,如设置元数据一节中所述。

2.3.4测试套件元数据

测试套件还可以包含除文档之外的其他元数据。此元数据使用“Metadata”设置。以这种方式设置的元数据显示在测试报告和日志中。

对元数据的名称和值参见下表。该值的处理方式与文档类似,这意味着它可以拆分为多个单元格(用空格连接在一起)或分成几行(用换行连接在一起),简单的HTML格式化,甚至可以使用变量。

Setting Value Value Value Value
Metadata Version 2.0    
Metadata More Info For more information about *Robot Framework* see http://robotframework.org
Metadata Executed At ${HOST}    

对于顶级测试套件,也可以使用--metadata命令行选项设置元数据 。这在“ 设置元数据”一节中有更详细的讨论。

2.3.5套件设置和拆卸

测试用例和测试套件都可以进行设置和拆卸。在运行任何套件或子测试套件的测试用例之前执行套件设置,并在它们之后执行测试拆卸。所有测试套件都可以进行设置和拆卸; 对于从目录创建的套件,必须在测试套件初始化文件中指定它们。

与测试用例类似,套件设置和拆解是一个可以带参数的关键字。它们分别在设置表中使用Suite Setup和Suite Teardown设置进行定义 。它们也有类似的同义词,Suite Precondition和Suite Postcondition,作为测试用例设置和拆解。关键字名称和可能的参数位于设置名称后面的列中。

如果套件设置失败,则会立即为其中的所有测试用例及其子测试套件分配一个失败状态,并且它们实际上并未执行。这使得套件设置非常适合检查在运行测试用例之前必须满足的前提条件

在执行完所有测试用例后,套件拆卸通常用于清理。即使同一套件的设置失败,也会执行它。如果套件拆卸失败,则套件中的所有测试用例都标记为失败,无论其原始执行状态如何。从Robot Framework 2.5开始,即使其中一个关键字失败,也会执行套件拆解中的所有关键字。

作为设置或拆卸执行的关键字的名称可以是变量。通过从命令行提供关键字名称作为变量,这有助于在不同环境中进行不同的设置或拆卸。

Robot Framework(四)创建测试套件的更多相关文章

  1. Robot Framework - 2 - 创建测试库

    04- 创建测试库--基础概念 Robot Framework 实际的测试能力是由测试库提供的. ***** 支持的编程语言 Robot Framework 自身是用 Python 编写的,能使用 P ...

  2. Robot Framework - 4 - 创建和扩展测试库的示例

    创建和扩展Library的示例 示例:Check status on Linux OS 创建与使用library的基本步骤:           1--- library实现的内容和实现的方式     ...

  3. Robot Framework - 5 - 创建测试数据

    Creating test data User Guide - Creating test data:http://robotframework.org/robotframework/latest/R ...

  4. Robot Framework - 建立本地测试环境

    注意:本文内容是以“在Window7系统中安装本地RobotFrmamework自动化测试环境”为例. Robot Framework简介 HomePage:http://robotframework ...

  5. 用Robot Framework+python来测试基于socket通讯的C/S系统(网络游戏)

    项目终于换了方案,改用socket来实现而不是之前的http了,所以测试工具就不能用以前的了,因为测试人手少,逼不得已的必须要挖掘更多的自动化方案来弥补.于是先研究了下python的socket解决方 ...

  6. 【转】Robot Framework 快速入门

    目录 介绍 概述 安装 运行demo 介绍样例应用程序 测试用例 第一个测试用例 高级别测试用例 数据驱动测试用例 关键词keywords 内置关键词 库关键词 用户定义关键词 变量 定义变量 使用变 ...

  7. Robot Framework 快速入门

    Robot Framework 快速入门 目录 介绍 概述 安装 运行demo 介绍样例应用程序 测试用例 第一个测试用例 高级别测试用例 数据驱动测试用例 关键词keywords 内置关键词 库关键 ...

  8. Robot Framework 快速入门_中文版

    目录 介绍 概述 安装 运行demo 介绍样例应用程序 测试用例 第一个测试用例 高级别测试用例 数据驱动测试用例 关键词keywords 内置关键词 库关键词 用户定义关键词 变量 定义变量 使用变 ...

  9. Robot FrameWork基础学习(二)

    在Robot Framework中,测试套件(Test Suite)主要是存放测试案例,而资源文件(Resource)就是用来存放用户关键字. 内部资源:Resource 外部资源: External ...

随机推荐

  1. 配置Jupyter

    前几天见同学有用Jupyter notebook的,有点喜欢,于是今天自己配了一下. Jupyter是一个非常好用编辑器,因为Jupyter notebook 不仅可以编写代码运行,并且可以直接在代码 ...

  2. Linux放弃到入门

    流星,因为短暂而美丽,划过黑寂的夜空,释放出那一闪而逝的光芒,虽然微弱,但却没有人能无视它的存在.人生如同流星,充满了精彩与传奇,如同一支美丽的传说,究竟能否想流星那样短暂,别人决定不了,上天也决定不 ...

  3. UVa OJ 679 - Dropping Balls

    本题是一个二叉树问题——Perfect Binary Tree. 一个完美二叉树(PBT)的深度为D,从根结点开始,按层次遍历顺序编号为1,2,...,2D-1. 有若干个球,依次由根结点落下.当一个 ...

  4. 域名和ip、端口的关系

    背景:新建一个项目,属于RPC服务,调用时需要ip+端口. 在工单系统里走流程,强制填写域名.之前也操作过,感觉域名不重要.我本来需要填写ip+端口,你给整个域名,那我端口往哪写?(一直以为域名=ip ...

  5. maven 自动部署到tomcat

    使用maven的自动部署功能可以很方便的将maven工程自动部署到远程tomcat服务器,减少部署时间,方便快捷. 一.配置tomcat manager 1.编辑tomcat目录下,conf/tomc ...

  6. Android--真机调试程序方法

    方法例如以下: (1)手机通过数据线连接到手机上. (2)在手机中设置:设置-->应用程序-->开发-->USB调试 (3)在CMD中測试一下.连接是否正常,CMD中命令例如以下: ...

  7. 问题1-The type java.lang.String cannot be resolved. It is indirectly referenced from required .class files

    问题一:The type java.lang.String cannot be resolved. It is indirectly referenced from required .class f ...

  8. Linux - 进程与内存查看

    top NI表示进程的优先级. -20的优先级,非常的高. top -p xxx 可以查看具体的进程情况. renice -n -6 进程ID 可以改变一个正在运行的pid的优先级. [root@lo ...

  9. 产生冠军--hdoj

    产生冠军 Time Limit : 1000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submissi ...

  10. The Unique MST--hdoj

    The Unique MST Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 20000/10000K (Java/Other) Tota ...