Robot Framework之创建变量和执行用例
一、变量的使用
种子变量变量可以在命令行中设置,个别变量设置使用--variable (-v)选项,变量文件的选择使用--variablefile (-V)选项。通过命令行设置的变量是全局变量,对其所有执行的用例都有效。它们将覆盖变量表格中的同名变量或是通过变量文件引入到测试数据中的同名变量。设置单个变量的语法是--variable name:value, “name”是不使用${}的变量名称, “value”则是其赋予的值。可以多次使用该选项设置多个变量。仅有标量变量可以使用该语法且只能赋值字符串。许多特殊字符在命令行中很难表示,但可以使用转义字符转义它们,使用—escape 选项。
在命令行中使用变量文件的基本语法是--variablefile path/to/variables.py使用 Set Test Variable 创建的变量,可以在该测试用例范围内的任何位置有效。例如,你在一个用户关键字中创建了变量,它将在测试用例级别有效及当前测试中的所有其他用户自定义关键字中有效。其他测试用例将看不到该变量。使用 Set Suite Variable 创建的变量,可以在当前测试集范围内的任何位置有效。使用该关键字创建变量同使用测试数据文件的设置表格设置变量和引入变量文件相同。其他的关键字,包括可能的子测试集,都将不能看到该关键字创建的变量。使用 Set Global Variable keyword 创建的变量, 在所有测试用例和测试集中有效。 通过该关键字创建的变量同使用命令行选项-variable 或—variablefile 创建的变量相同。因为该关键字可以在任何地方改变变量值,所有需要小心使用有效的操作系统内建变量Variable Explanation${CURDIR} 提供当前测试文件存放的绝对路径。该变量是大小写敏感的。${TEMPDIR} 获取操作系统临时文件夹的绝对路径。 在UNIX系统是在/tmp, 在windows系统是在c:\Documents and Settings\\Local Settings\Temp。${EXECDIR} 获取测试执行开始目录的绝对路径。空格和空变量可以使用${SPACE}和${EMPTY}创建空格和空变量。这些变量非常有用,否则需要使用反斜杠用于转义空格或空单元格。当需要使用多个空格时,可以使用该语法${SPACE*5}。如下面的例子,should be equal 使用了同样的参数,但使用该语法比使用反斜杠更简单清晰。一些自动变量可以在测试用例中使用。这些变量在执行时会有不同的值,并且他们不是在任何时候都是有效的。
Variable Explanation Available
${TEST NAME} 获取当前测试用例名称 Test case
@{TEST TAGS} 包含当前测试集中的 tag,按字母排序 Test case
${TEST STATUS} 获取当前测试用例的状态,PASS 或 FAIL 中的一种。只能在测试用例的 teardown 中使用
${TEST MESSAGE} 当前测试用例可能的错误信息。只能在测试用例的 teardown 中使用
${PREV TEST NAME} 前一个测试用例的名称,或者为空字符串【当没有任何测试用例执行过】 。可以在任何地方使用
${PREV TEST STATUS} 前一个测试用例的状态,PASS,FAIL 或者未空字符串, 【当没有任何用例执行过】 。可以在任何地方使用
${PREV TEST MESSAGE} 前一个测试用例可能的错误信息。可以在任何地方使用
${SUITE NAME} 当前测试集的全名称。可以在任何地方使用。
${SUITE SOURCE} 测试集文件或目录的绝对路径,可以在任何地方使用。
${SUITE STATUS} 当前测试集的状态, PASS 或 FAIL。只能在测试集的 teardown 中使用。Suite teardown
${SUITE MESSAGE} 测试集的所有消息,包括统计。只能在测试集的 teardown 中使用。Suite teardown
${OUTPUT FILE} 当前输出文件的绝对路径。当输出文件被分割会有不同的值。可以在任何地方使用。
${LOG FILE} 当前日志文件的绝对路径或字符串 None【当没有日志文件时】 。当输 出被分割时,将可能有不同的值。
${REPORT FILE} 当前报告文件的绝对路径或字符串 NONE【当没有报告文件生成时】 。
${SUMMARY FILE} 摘要文件的绝对路径或字符串 NONE【当没有摘要文件时】 。
${DEBUG FILE} 调试文件的绝对路径或字符串 NONE【当没有调试文件时】 。
${OUTPUT DIR} 输出目录的绝对路径 Everywhere
变量文件创建变量时,创建列表变量,变量名称必须使用前缀LIST__(注意是两个下划线)。LIST__STRINGS = ["list", "of", "strings"]
TestCase Go二、连接对象
Catenate关键字可以连接多个对象
Catenate关键字执行结果:
Starting test: Test.Testsuit.test
20171213 08:57:43.133 : INFO : ${hi} = hello woeld!
20171213 08:57:43.133 : INFO : hello woeld!
Ending test: Test.Testsuit.test
加上“SEPARATOR=”可对多个连接的信息进行分割:
SEPARATOR分割执行结果:
三、用例执行
RF 的测试用例可以创建在文件或目录中,在运行脚本后接需要执行用例的名文件名或路径名。路径可以是绝对路径,更普遍的是相对路径。文件或目录构成顶级测试集,该测试集如果没有被--name option 所覆盖,它将使用文件或目录名作为自己的名字
RF 可以自动的产生顶级的测试集, 具体的文件或目录将变成它的子测试集。 产生的测试集的名称将由子测试集的名字和 “&”组成
使用参数:当使用参数时,参数必须位于运行脚本和源数据中间
设置参数值:大部分参数需要一个参数值, 位于参数名后面。 长参数和短参数都接受由空格分开的参数值, 例如: “--include tag”或“-i tag” 。使用长参数时,可以将等号“=”作为分隔符,例如“--include=tag” ,使用短参数时,分隔符可以省略,例如“-itag” 。某些参数可以被具体赋值多次。例如, “--variable VAR1:value --variable VAR2:another”设置了两个变量。如果某个只有一个值的参数被赋值多次,则最后一次生效.
简单正则表达式:很多参数后可接正则表达式的参数值。 “*”和“?”可替代具体的字符, “*”可匹配任何包括空值在内的字符串, “?” 可以匹配任何单个字符。 例如: “--include prefix-*” 匹配所有以 “prefix-” 开头的 tag, “--include a???” 匹配所有以“a”开头 4 个字符的 tag
返回码:运行脚本通过返回码使所有测试用例的状态和系统交互。如果所有的用例执行启动成功而且没有严重的失败,返回码将是 0,所有可能的返回码都列在下表中。返回码用例执行完之后,很容易通过返回码来确定所有用例执行的状态。例如,在 bash shell 中,返回码保存在具体的变量“ $?”中,在 Windows 系统中,返回码保存在变量% ERRORLEVEL %中。如果您使用外部的工具来运行用例,请查询相关的文档来了解如何获得返回值
执行测试集和测试用例:测试用例总是在某个测试集中执行。由目录产生的测试集包含由测试用例文件或目录组成的子测试集,由测试用例文件组成的测试集直接包含测试用例。默认情况下,所有的测试用例都会执行,可以通过参数“--test” 、 “--suite、 “--include”和“--exclude”来选择用例执行。测试集中如果没有用例,将不会执行。RF 从顶级的测试集开始执行。如果测试集中包含用例,则顺序执行。如果测试集中再包含测试集,则按照深度优先的顺序依次执行。当执行单个用例时,关键字按顺序执行。通常用例中的任何一个关键字失败了,用例将停止执行,但是,我们可以做到让失败后继续执行