自己动手写Web自动化测试框架5 - 判断浏览器是否加载完成

发表于:2010-06-30来源:作者:点击数: 标签:自动化框架webWebWEB
自己动手写Web 自动化测试 框架5 - 判断浏览器是否加载完成 软件测试 上面的几次课程中,我们介绍了如何打开浏览器,如何获取每个web控件的信息,并且控制并验证他们。 从上面的文章中,我相信大家已经可以写出简单的测试程序了。但是还有一个很重要的问题没

  自己动手写Web自动化测试框架5 - 判断浏览器是否加载完成  软件测试

  上面的几次课程中,我们介绍了如何打开浏览器,如何获取每个web控件的信息,并且控制并验证他们。

  从上面的文章中,我相信大家已经可以写出简单的测试程序了。但是还有一个很重要的问题没有解决:如何判断浏览器是否加载完成?

  前面的文章我们没有对浏览器的加载进行判断,而只是简简单单的等一段时间,这不是一个很好的解决方法,一方面浪费了时间,另一方面,我们也无法知道应该等多久,导致我们的测试程序不够稳定。

  接下来我们假设被测网页没有Ajax和框架,以这种情况来分析如何判断网页加载完毕。

  现在比较常用判断是否加载的方法有三种:

  不停判断IE的状态,如果没有准备好就等待。

  实现IE的DocumentComplete事件,标志完成。

  不停去查找页面有没有我们想要控件,没有就等待。

  第一种方法:不停判断IE的状态,我们要判断IE的哪些状态呢?

  一方面,我们需要判断IE的Busy状态,看IE是不是在忙着解析东西,另一方面判断IE的ReadyState状态,看html文档是不是被完全加载进来。

clearcase/" target="_blank" >ccff" border=0>
MILY: 新宋体">

while(ie.Busy || ie.ReadyState !=tagREADYSTATE.READYSTATE_COMPLETE)
{
  Thread.Sleep(100);
}

  用如上的代码就可以等待IE到完成。

 

这里只是简简单单的Demo,所以用了很简单的预计进行判断,我们假设我们的网页没有Ajax,也不会出现Load的死锁,真正的实际工作要比这个复杂一些,比如要定一个Time out,如果除了Timeout的范围,就强行终止,以防止测试过程中的死锁。

而如何判断Ajax是否被加载完,不是我们这个系列的讨论范围,请关注以后的其他系列文章。

  这种方法是我比较推荐的一种方法,虽然《.net软件测试自动化之道》推荐的是第二种方法,不过我经过实际的测试,推荐第一种方法。这个方法可以比较好的处理Navigate、Submit等情况,也是WatiN使用的方法(WatiN的用法要复杂很多,考虑到了Frame等其他情况)。

  第二种方法:通过绑定DocumentComplete,用AutoResetEvent来等待。

  InternetExplorer给我们提供了DocumentComplete事件,会在IE被Load之后被调用,我们可以使用这个来等待。等待方法就是使用System.Threading.AutoResetEvent对象来。

  所以我们需要做的是:

  声明一个AutoResetEvent对象的实例,因为要在两个方法直接调用,所以需要放到类的成员变量。

  在InternatExplorer被获取之后,绑定DocumentComplete事件。

  在DocumentComplete事件中,调用AutoResetEvent.set()方法。

  在等待页面加载的时候调用AutoResetEvent.WaitOne()方法

  下面是源代码:

原文转自:http://www.ltesting.net