随笔-61  评论-13  文章-19  trackbacks-0
一个很重要的问题:如何判断浏览器是否加载完成?

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

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

  1. 不停判断IE的状态,如果没有准备好就等待。
  2. 实现IE的DocumentComplete事件,标志完成。
  3. 不停去查找页面有没有我们想要控件,没有就等待。

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


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对象来。
所以我们需要做的是:

  1. 声明一个AutoResetEvent对象的实例,因为要在两个方法直接调用,所以需要放到类的成员变量。
  2. 在InternatExplorer被获取之后,绑定DocumentComplete事件。
  3. 在DocumentComplete事件中,调用AutoResetEvent.set()方法。
  4. 在等待页面加载的时候调用AutoResetEvent.WaitOne()方法

下面是源代码:

//1.声明AutoResetEvent对象实例 

privatestaticAutoResetEventDocComplete =newAutoResetEvent(false);
staticvoidMain(string[] args)
{ 

 //...省略得到IE对象

 //2.绑定DocumentComplete事件

 ie.DocumentComplete +=

   newDWebBrowserEvents2_DocumentCompleteEventHandler(ie_DocumentComplete); 

 Console.WriteLine("Navigating ...");

 objecto =null;

 ie.Navigate("http://www.baidu.com/",refo,refo,refo,refo); 

 //调用WaitOne等待

 DocComplete.WaitOne();

 HTMLDocumentdoc = (HTMLDocument)ie.Document;

 HTMLInputElementkeyword = (HTMLInputElement)doc.getElementById("kw");

 keyword.value ="colblog.net";

  HTMLButtonElementsubmit = (HTMLButtonElement)doc.getElementById("sb");

 submit.click(); 

 //调用WaitOne等待

 DocComplete.WaitOne(); 

 ie.Quit(); 

} 

//实现DocumentComplete事件,调用Set方法。

staticvoidie_DocumentComplete(objectpDisp,refobjectURL)

{

 DocComplete.Set();

}

省略了一些前几篇文章的东西,完整代码请下载源代码。
这种方法有自己的好处,就是使用了IE自己的事件,判断代码很简单,不过有也不好的地方,第一就是帮度DocumentComplete事件以后,打开的IE会变得响应很慢,尤其是当设置断点调试的时候,IE会变得尤其的慢。第二个缺点就是如果加上框架,还有页面的跳转,就会是这个方法很难捉摸。比如,如果上面的例子里面,URL写成"baidu.cn",就会出错。

第三种方法是不停的去读我们要的控件是否出来。这个方法一般需要配合前面两个使用,而且也可以部分解决Ajax的问题。因为具体实现代码比较多,而又不是我们要讲的重点,就不贴出源代码,只是讲一下实现的思路,让大家了解一下。
具体实践方法是:设置一个Timeout,在这个Timeout时间之前,不停的去看我们要验证的控件是不是被Load进来。如果对页面进行建模,就会去看我们的这个页面的所有的已经定义了的控件是不是被Load进来,如果出了Timeout,就会报错。

这个方法的优点是可以部分解决Ajax,但是缺点也就是实现比较复杂,而且如果报错,无法分清是因为页面没有这个控件,还是因为速度较慢,控件还没有被读入。

以上介绍了在没有Ajax和框架情况下,如何判断浏览器是否已经加载完成。从下一篇文章开始,我们就要进入正题,开始我们的自动化测试框架了。

posted on 2010-01-15 10:10 xnabx 阅读(1399) 评论(0)  编辑  收藏

只有注册用户登录后才能发表评论。


网站导航:
博客园   IT新闻   Chat2DB   C++博客   博问