Robot Framework + Selenium2Library自动化测试系列(6) - 设置项目结构1 - 用资源文件管理函数

到现在为止,我们创建了一个叫MyFirstTestCase的项目,一个叫TCLOG-1的test case,还有三个函数。如果项目很简单,就几个Case,那这么写就够用了。可事实上呢?往往不可能。实际项目都很大,动辄需要上百上千的case,而且涉及各种模块,如果不把项目合理分层容易在后期出现混乱,不方便管理。比如现在我们除了要测hrsystem网站登录模块外,还要测登录后的主页,那我们就得把这两个模块放在不同地方。

打开RIDE回忆一下,我们测登录模块时新建了MyFirstTestCase,当时是点击New Project。如果只有登录这一个模块New Project就够了,因为这个项目本身就是这一个模块。但是现在要求变了,我们要加个主页模块,所以需要在项目文件夹上右键-> New Suite: 

《Robot Framework + Selenium2Library自动化测试系列(6) - 设置项目结构1 - 用资源文件管理函数》

Suite可以简单理解成模块。建完之后发现和MyFirstTestCase图标相同,都是一个白色方块。右键点击MyFirstTestCase –> Rename,改名Login,这俩模块就出来了。以后我们就把关于主页的测试用例建在Home模块下,把关于登陆的测试用例放到Login模块下,当然以后我们还会有更多的模块。为了便于管理,再建个叫Tests的文件夹。右键点击项目文件夹 -> New Directory:

《Robot Framework + Selenium2Library自动化测试系列(6) - 设置项目结构1 - 用资源文件管理函数》

打开资源管理器,把两个模块都拖入到该文件夹中:

处理完了模块,我们看看函数方法需不需要修改。我们先用浏览器打开Login.html,看看文件里到底怎么写的:

《Robot Framework + Selenium2Library自动化测试系列(6) - 设置项目结构1 - 用资源文件管理函数》

我们发现函数都写在了里面。如果我想把这些函数,或是说Keyword – Login,Setup和Teardown以后用在关于Home的测试用例中呢?很显然,这些函数需要放在公共的位置。Keyword除了可以建在test case下边,还可以建在资源文件(resources)下边。因为Login to hrsystem只用在登录模块中的,我们可以这么做:

右键点击项目文件夹 -> New Resource,新建一个叫Login.html的资源文件:

《Robot Framework + Selenium2Library自动化测试系列(6) - 设置项目结构1 - 用资源文件管理函数》
《Robot Framework + Selenium2Library自动化测试系列(6) - 设置项目结构1 - 用资源文件管理函数》

资源文件的图标是白色方块加个齿轮。引入Selenium2Library,前几次说过怎样引这几个东西,如果忘记了可以再翻看前面的文章。

右键点击Login.html -> New User Keyword,然后把Login to hrsystem再新建一遍,内容复制粘贴。最后把在Login模块下的那个Login to hrsystem删掉,就成了现在这个样子:

《Robot Framework + Selenium2Library自动化测试系列(6) - 设置项目结构1 - 用资源文件管理函数》

然后转到TCLOG-1会发现Login to hrsystem那步黑了,因为现在它是在资源文件Login.html下新建的,原来的连接已经不存在了,好,重新在Tests -> Login里点击resources引入Login.html:

添加类库点击Library,添加资源文件点击Resources,这两者天差地别,朋友们别加错了。

Setup/Teardown和Login to hrsystem不同,这俩函数被用在所有模块中,所以我们可以把它们放到一个共同的资源文件下。右键点击Lib -> New Resource,起名ApplicationSpecific.html,代表这个资源文件下的所有函数都是公用的。

在ApplicationSpecific.html添加Selenium2Library和OperatingSystem两个类库,然后把Setup和Teardown在ApplicationSpecific.html下面再重新建立一遍,同时删掉在Tests->Login模块里的:

我们回到Tests下的Login模块,现在我们已经不需要OperatingSystem的Library了,因为需要它的Setup函数已经被转移到ApplicationSpecific.html资源文件下并且在那里已被引用。我们还需要做一件事,就是把ApplicationSpecific.html引到Login模块下,否则这两者谁也不认识谁,无法沟通。点击Resources引login.html:

现在我们的Login模块底下干干净净,但又不影响执行,因为它既可以从ApplicationSpecific.html资源文件中拿到Setup和Teardown,又可以从Login.html中拿到Login to hrsystem。

我们再新建一个叫Pages的文件夹用来把存放所有的资源文件,然后再为模块Home建一个资源文件Home.html。目前项目结构是这样的:

然后我们再一次转到TCLOG-1,会发现”Login to hrsystem”那步又黑了,因为它虽然是在资源文件Login.html下,可现在多了一个文件夹Pages,原来的链接又不存在了。好,重新在Tests -> Login里引入Login.html:

这么一看是不是就清楚多了?每个test case可以从类库中拿关键字来执行操作,又可以从资源文件里拿自定义的函数。Login模块是这样,Home模块也是这样,以后我们再写的模块都是这样,它们都是一样的套路:

到此,项目结构我们已经完成了一半,在以后的实践中,我们就把Test Case按模块写到Tests文件夹下,把这些Test Cases所需要的函数按资源文件写到Pages文件夹下。

运行一遍TCLOG-1,测试结果通过。

这篇文章的源代码在[Test6](https://github.com/cslm/cslm.robotframework/tree/master/Test6)中。

    原文作者:马可吃菠萝
    原文地址: https://www.jianshu.com/p/1807d3523c17
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞