上次我们分析了什么是我们想要的自动化测试框架,这一次我们基于上一次的分析,来设计我们的自动化测试框架架构。
首先,我们需要一个类,去做帮助我们处理和IE相关的事情,帮助我们操纵IE,打开和关闭IE。然后,我们需要一组的类,来描述网页上的元素,比如TextBox和Button,去模拟他们的事件,去取得他们的状态。总体来说就是封装这些元素。
除此之外,我们还需要一些辅助的类来帮助我们做一些工作。
接下来我们就先去分析帮助我们操纵IE的类应该有那些功能。所以我们把这个类命名为WebBrowser。参考附带的WebBrowser.cs文件。
首先,我们需要一些内部的成员和辅助类,我们打开的IE进程会用SHDocVw.InternetExplorer类来接受,我们可以把这个变量存在整个类的私有变量去。还有我们其实要取出的是这个网页的HTMLDocument类,以供以后来使用。这里我们直接写成了internal,成员变量,其实可以封装成一个属性,看大家的用法了。除了这些,我们还需要一个Timer类,这个类帮助我们完成一些计时的工作。见附带的timer.cs文件。
其次,打开IE进程这样的事情应该是由这个类来做的,由于这次对WebBrowser的要求不高,我就在构造函数里面讲IE进程初始化好,具体如何处理这些请参见《自己动手写Web自动化测试框架(2):打开和操纵IE》。我们给这个类构造函数提供了一个带有string参数的方法,目的是让用户可以方便的传入URL而打开浏览器并且转到我们要的页面去。当我们没有参数给构造函数时,用户就会得到一个空的页面。
再次,我们需要一个NavigateTo函数,来操纵浏览器转到某一个地方去。这个函数不多说,就是我们以前的内容。
最后,我们在这里添加了一个DoWait的函数,这个函数的主要目的是完成我们《自己动手写Web自动化测试框架(5):判断浏览器是否加载完成》里面所讨论的等待浏览器加载完成。DoWait放在这里的原因是我们需要在几个地方判断页面加载完成:浏览器浏览到了新的页面、用户点击了某些按钮或者链接、或者甚至用户改变了控件的状态,导致页面回刷,这几个地方会分别被WebBrowser和以后的Web控件类所使用,所以我们把这个DoWait放在 WebBrowser里面,以后的Web控件回去引用WebBrowser类的这个方法来判断浏览器是否完成加载。
注意,这里把DoWait的代码写在WebBrowser里面是基于我们以上的页面没有Ajax和框架的假设做出的,如果页面可能有Ajax,我们就不可能简简单单的用这个DoWait去等待加载完成。
我们以后会有对目前框架的改进文章,这些文章会讨论这些问题。
这样我们的WebBrowser就大概写完了。
相关链接:
自己动手写Web自动化测试框架(5):判断浏览器是否加载完成
来源:oschina
链接:https://my.oschina.net/u/2910125/blog/786626