一个登录功能的test case就那么几步,很容易写,但通常情况下登录仅仅是第一步,比如你上网买东西的时候,查看购物车的时候,写微博的时候,这些行为基本离不开登录,登录是基础。这就意味着你写复杂test case的时候总得先写登录。虽然就那么几步,还每次写是不是还是很蛋疼?太费劲了,要是能写一次就好了。和直接写程序一样,在Robot Framework里也可以把它写成函数/方法,每次需要直接调用。现在我们就改进一下咱们的登录项目。
函数肯定是脱离开test case本身的,所以肯定要新建一个东西。打开RIDE,右键点击工程MyFirstTestCase,我靠,发现有好几个选项都带New,那应该选哪个呢?函数在Robot Framework里对应是Keyword,选New User Keyword打开函数对话框,起名“Login to hrsystem”。名称下面还有一个叫Auguments的文本框,其实就是用于放函数参数的。现在先什么都不填,我们点击OK。
打开编辑页面后感觉和测试用例TCLOG-1相似,因为本来函数就是测试用例的一部分:
Documentation:用来写函数的介绍;
Tags:标签,可以用来标注函数的相关信息;
Arguments:实际参数。函数有可能需要参数,就写在这里;
Teardown:如果还有步骤需要在测试完成后执行可以写在这里;
Return Value:函数返回值;
网格的用处也是一样的,我们把除最后一步Close Browser之外的所有步骤都复制粘贴到Keyword的网格里:
最后回到TCLOG-1,把所有步骤都去掉,直接写上Login to hrsystem和Close Browser两步。注意,当刚输入“L”时使用快捷键Ctrl+Alt+Space会发现上Login to hrsystem自动出现,我们发现自己写的函数是用深蓝色表示的,它们也成为了关键字:
你按住Ctrl点击函数还会跳转到函数那页。TCLOG-1现在只有两行,已经变得非常简单了,因为所有的登录操作都已经放到函数中。 我们再次运行程序,测试通过。
能不能进一步改变一点?别忘了,函数Login to hrsystem现在不加参数的。这就意味着我们永远得用相同的员工代号/密码-1001/123来测试。这就肯定不对了,一组测试数据哪儿够呢?来,把员工代号和密码作为函数的参数加上。打开Login to hrsystem,我们在Arguments里填“${usercode} | ${password}”,代表此函数接受两个参数 - ${usercode}和${password},分隔符为“|”。“${}”是用来声明变量的。接着我们把“1001”替换成${username},“123”替换成${password},一个带参数的完整函数体就写完了:
这样,以后任意的员工代号和密码都可以传给函数执行了。回到TCLOG-1会发现Login to xiaocesuo旁边多出了两个红色的格,代表有两个必要参数需要输入。这和我们刚才对函数的设置正好对应,软件很聪明:
在第一个红格员工代号位置输入“1001”,第二个密码位置输入“123”,保存,运行。测试通过。
现在我们回到之前那个问题,当你新建一个project的时候RF会问你选什么样的文件格式,有四种– ROBOT, TXT, TSV, HTML 。现在打开项目目录会看见一个叫MyFirstTestCase.html的文件,明白啥意思了吧?当你选择一种格式,项目文件就会以什么样的格式出现。双击这个文件,你可以看到声明过的所有信息都存在这里:
这其实就是一个html网页,如果你想修改这个文件而且又不愿意从RF里改,鼠标右键打开文件编辑模式就行了。但新手不推荐,写错了就读不出来了。
有人说1001/123不还是一组数据吗?别着急啊,一步一步来。我们刚刚把函数完善了,现在可以在TCLOG-1中输入各种用户名密码了。下一章我们进行第二次改进 – 创建数据集并用Robot Framework进行读取。
这篇文章的源代码在[Test2](https://github.com/cslm/cslm.robotframework/tree/master/Test2)中。