首先,说明下这里采用的关键字驱动框架是RobotFramework,Web 自动化测试框架是Selenium2。该 WebLibrary 是对自动化测试的一个初步探索,并不完善,欢迎大家一起讨论。

这个自动化 Library 的初衷是:

针对上述目的采用的实现方法是:

那么,在上述的实现方法之下,用例的可读性、可维护性和可扩展性有哪些提高呢?

可读性

上层关键字规范的中文命名方式使用例的呈现方式接近于自然语言,可读性大大增强,一个具体的用例写出来的形式如下图所示:

可维护性

可扩展性

这里只提一下 RobotFramework 提供的关键字驱动的可扩展性还是十分优秀的,把需要的功能或者操作封装成关键字即可;除此之外,Selenium2 自身的扩展性是完整保留的,Grid 也是支持的

RFUI 对 Selenium2 的二次封装

RobotFramework 提供上层的关键字驱动支持,底层的关于 元素/页面/窗口 各种操作的基础关键字,例如,click/input_text/maximize_browser_window,还是由 Selenium2 提供支持,所以需要将 Selenium2 封装成 RobotFramework 支持的 TestLibrary。

通过下图可以看出对 Selenium2 做了哪些封装,例如,支持文本定位点击(Web Click TextButton)、支持 Windows 下 Flash 上传控件(Web Upload File)、相同元素根据序号定位操作(Web Click Element)、支持 Hover and Click(Web Hover And Click)、获取匹配指定 Locator 的元素个数(Web Get Elements Num)、文本框输入完成后按下 Enter 键(Web Input Text)。当然包括这些特有的操作,所有的操作中都添加了加载保护(Wait Until Element Is Enabled/Visible),等元素到了可操作状态才进行下一步操作,所以可以省去用例中的 Sleep。图片太小可以右键->“新标签页打开”。

有了封装好的 WebLibrary 和 RobotFramework,那么我们的框架结构是这样的:

具体到实现原理的框架结构其实是这个样子的(需要结合前两篇博客来看):

总体来讲,框架功能的完善性很多可以加强的地方,不过先前提出的几个问题基本上得到了解决。这种基于关键字驱动的自动化用例编写方式是否可行,通过在实际项目中的使用之后得出的结论是肯定的,不过还有许多有待完善的地方,比如 RobotFramework IDE 还不够成熟,WebLibrary 提供的基础关键字不够全面不够智能等等,这些会在后续的对自动化测试的学习中逐渐完善。


↙↙↙阅读原文可查看相关链接,并与作者交流