测试项目与测试套件的概念
如果你查看当前所创建的项目会发现,“测试项目”是一个目录。
“测试套件”则是一个 txt 文件。
“测试项目”和“测试套件”本质上并没有什么区别,如果你愿意,也可以把测试项目创建成一个文件:
如果你把“测试项目”创建成一个文件后,那么在这个“测试项目”下就不能再创建“测试套件”了, 只能创建测试用例。
除非我们所创建的“测试项目”非常小,只需要几个用例。一般情况下,我们会选择将其定义成一个目录,这样它就可以分成多个套件,套件可定义为不同的业务,不同的业务下再分用例,结构会更加清晰。
当然,你同样也可以把“测试套件”创建成一个目录。
如果你把“测试套件”创建成了一个目录后,就不能直接在其下面创建用例了,还需要再创建的“File”类型的“子测试套件”。说白了就是用例只能创建在 file 类型的套件中。
下面用一张图来表述他们的关系:
常用关键字介绍
在学习一门编程语言的时候,大多教材都是从打印“hello world”开始。我们可以像编程语言一样来学习 Robot Framework。虽然通过 RIDE 提供“填表”一样的写测试用例的方式。但它却有着像编程语言一样的强大的关键字,以及可以开发关键字的扩展能力。
log 就是“print”
log 关键字就是编程语言里的“print”一样,可以打印任何你想打印的内容。在 test case 中填写以下内容:
log hello world
勾选测试用例,点击工具栏的“Run Tests”按钮或按快捷键“F8”执行测试用例。如图:
在 Run 标签页,将看到执行结果:
过运行结果中看到,“INFO:”的“hello world” 就是通过 log 关键字打印的信息。
定义变量
在 robot Framework 中通过“Set variable”关键字来定义变量,如:
${a} Set variable hello world
log ${a}
Starting test: 测试项目.测试套件.test case
20150303 09:35:33.927 : INFO : ${a} = hello world
20150303 09:35:33.927 : INFO : hello world
Ending test: 测试项目.测试套件.test case
连接对象
“Catenate”关键字可以连接多个信息。
${hi} Catenate hello world
log ${hi}
Starting test: 测试项目.测试套件.test case
20150303 10:07:29.039 : INFO : ${hi} = hello world
20150303 10:07:29.039 : INFO : hello world
Ending test: 测试项目.测试套件.test case
加上“SEPARATOR=”可以对多个连接的信息进行分割。
${hi} Catenate SEPARATOR=--- hello world
log ${hi}
Starting test: 测试项目.测试套件.test case
20150303 10:07:29.039 : INFO : ${hi} = hello--- world
20150303 10:07:29.039 : INFO : hello--- world
Ending test: 测试项目.测试套件.test case
定义列表
通过“Create List”关键字可以定义列表。
例 1
${abc} Create List a b c
log ${abc}
Starting test: 测试项目.测试套件.test case
20150303 10:23:20.760 : INFO : ${a} = [u'a', u'b', u'c']
20150303 10:23:20.762 : INFO : [u'a', u'b', u'c']
Ending test: 测试项目.测试套件.test case
每个字符串前面加 u,是为了统一编码问题,将字符串转为 Unicode 编码。
例 2
@{abc} Create List a b c
log many @{abc}
如果通过“@{}”去定义列表的话,可以通过“log many”关键字进行打印Starting test: 测试项目.测试套件.test case
20150303 17:04:30.631 : INFO : @{abc} = [ a | b | c ]
20150303 17:04:30.632 : INFO : a
20150303 17:04:30.633 : INFO : b
20150303 17:04:30.633 : INFO : c
Ending test: 测试项目.测试套件.test case
时间的操作
在 Robot Framework 中也提供操作时间的关键字。
1) Robot Framework 中提供了“get time”关键字用来获取当前时间。
${t} get time hello world
log ${t}
Starting test: 测试项目.测试套件.test case
20150303 17:04:30.628 : INFO : ${t} = 2015-03-03 17:04:30
20150303 17:04:30.630 : INFO : 2015-03-03 17:04:30
Ending test: 测试项目.测试套件.test case
2) “sleep”关键字用来设置休眠一定时间。
${t} get time hello world
sleep 5
${t} get time hello world
sleep 关键字默认以“秒”为单位。Starting test: 测试项目.测试套件.test case
20150303 17:23:17.020 : INFO : ${t} = 2015-03-03 17:23:17
20150303 17:23:22.020 : INFO : Slept 5 seconds
20150303 17:23:22.022 : INFO : ${t} = 2015-03-03 17:23:22
Ending test: 测试项目.测试套件.test case
通过前后两次获取当前时间的差,可以清楚的看到 sleep 休眠 5 秒所起的作用。
if 语句
通过“run keyword if”关键字可以编写 if 分支语句。
${a} Set variable 59
run keyword if ${a}>=90
log 优秀
... ELSE IF ${a}<=70 log 良好
... ELSE IF ${a}<=60 log 及格
... ELSE log 不及格
首先定义两个变量 a 等于 59 。
If 判断 a 大于等于 90 ,满足条件 log 输出 “优秀 ”;
不满足上面的条件,接着 else if 判断 a 大于等于 70 ,满足条件 log 输出 “良好”;不满足上面的条件,接着 else if 判断 a 大于等于 60 ,满足条件 log 输出 “及格”;上面的条件都不满足,else log 输出“不及格”。
注:注意 sele if 和 else 前面的三个点点点(...)Starting test: 测试项目.测试套件.test case
20150303 11:04:05.676 : INFO : ${a} = 59
20150303 11:04:05.676 : INFO : 不及格
Ending test: 测试项目.测试套件.test case
for 循环
在 Robot Framework 中编写循环通过“:for”。
例 1,执行 10 次循环。
:FOR ${i}in range10
log${i}
通过“:for”定义 for 循环;in range 用于指定循环的范围。Starting test: 测试项目.测试套件.test case
20150303 13:24:37.713 : INFO : 0
20150303 13:24:37.716 : INFO : 1
20150303 13:24:37.718 : INFO : 2
20150303 13:24:37.720 : INFO : 3
20150303 13:24:37.723 : INFO : 4
20150303 13:24:37.725 : INFO : 5
20150303 13:24:37.727 : INFO : 6
20150303 13:24:37.729 : INFO : 7
20150303 13:24:37.732 : INFO : 8
20150303 13:24:37.734 : INFO : 9
Ending test: 测试项目.测试套件.test case
注意,in range 定义为 10,它的范围是 0~9。
例 2,遍历列表。
@{abc} create list a b c
:FOR ${i}in @{abc}
log${i}
“create list” 关键字用来定义列表(a,b,c),“@{}”用来存放列表。通过过“:for”循环来来遍历@{abc}列表中的字符。
Starting test: 测试项目.测试套件.test case
20150303 13:42:05.064 : INFO : @{abc} = [ a | b | c ]
20150303 13:42:05.065 : INFO : a
20150303 13:42:05.066 : INFO : b
20150303 13:42:05.068 : INFO : c
Ending test: 测试项目.测试套件.test case
例 3,循环中的判断
@{abc} create list a b c
:FOR ${i}in @{abc}
Exit For Loop If '${i}'=='c'
log ${i}
通过“Exit For Loop If”关键字时行 for 循环内的判断,当满足 Exit For Loop If 条件后,循环结束。Starting test: 测试项目.测试套件.test case
20150303 16:24:26.146 : INFO : @{abc} = [ a | b | c ]
20150303 16:24:26.154 : INFO : Exiting for loop altogether. 20150303 16:24:26.158 : INFO : c
Ending test: 测试项目.测试套件.test case
从执行结果看到当循环到字符 c 时,Exit For Loop If 条件成立,结束循环;通过 log 打印当前的字符 c。