收藏本站 收藏本站
积木网首页 - 软件测试 - 常用手册 - 站长工具 - 技术社区
软件测试 > QTP > 正文

首页 | 领域细分: 游戏测试 安全测试 手机测试 Web测试 | 技术研究: 单元测试 入门教程 用例设计 性能测试 功能测试 | 测试职场: 面试精选 职场发展 面试试题

测试管理: 配置及流程 - 需求管理 - 质量验收 - 缺陷管理 - 其它管理相关 | 开发语言: PHP技巧 - PHP基础 - PHP实例 - PHP错误代码

测试工具: LoadRunner JiRa QuickTestPro RoBot WinRunner TestDirector 其它测试工具 | 数据库: Mysql数据库 Oracle数据库 CSS/DIV基础 HTML基础

使用QTP统计页面加载时间

来源:互联网 日期:2013-08-04 07:30

  QTP是一款功能自动化测试工具,而页面加载时间或响应速度应该是性能测试的事情,其实QTP也可以实现对页面加载时间的统计功能。因为QTP使用的是VBS脚本,VBS脚本的强大之处在于它可以调用任何windows的COM组件和对象。那么问题解决的思路就很简单了,就是我们要利用VBS获取 IE网页,并统计网页加载的时间。

  分析很简单,但是在实现上却有几个技术问题:一、如何使用VBS分析网页。我们知道网页技术是基于DOM模型的(也不知道这么说是不是准确),那么只要我们能用VBS调用DOM下的document对象,那么我们就可以使用document的方法来实现我们的要求;二、如果能实现对DOM的调用,我们如何统计页面加载的各个阶段的时间,通过查阅资料可以知道,在document中有一个readystate方法,该方法共有五个返回值,分别对应网页初始化到网页加载完毕五个阶段,我们可以利用该方法实现我们的要求。

  实现的思路如下:

  1、利用createobject创建一个IE的实例,以访问document对象;

  2、利用document对象的readystate属性获取网页加载时各个阶段的时间,

  3、利用timer()实现对毫秒的统计。timer()函数的作用是统计从午夜时间到当前时间所过去的秒数,我们用两个timer值想减就可以得到两个时间点之间相隔的毫秒数。

  4、为了方便调用,将时间统计的代码封装成一个函数。

  最后代码如下:

'在loadrunner脚本中,把要访问的url做参数化,变量名为SITEURL
'timeCount方法返回一个字符串,字符串的内容是统计各个阶段发生的时间
'可以使用各种方法查看result的内容
SITEURL = "www.sina.com.cn"'设置要进行访问的URL
result = timeCount(SITEURL)'返回运行结果
MsgBox result '输出运行结果,在loadrunner中可以将该行注释掉

'方法定义开始
Public Function timeCount(url)
Set dom = CreateObject("InternetExplorer.Application") '创建一个IE的对象
dom.Navigate(url) '打开指定的URL
time_start = Now()'获取统计开始时的时间
timer_start = timer()'获取当前时间的毫秒数
'a = dom.ReadyState'获取当前IE的状态值,将使用该状态值判断IE的当前状态
dom.visible = True '设置IE可见
While dom.busy or (dom.readyState<>4)'当IE处于BUSY状态或者加载未完成时(readystate不等于4)时,根据IE的状态统计时间,每毫秒统计一次
wscrīpt.sleep 1 '时间间隔1毫秒,如果时间间隔比较长的话,很有可能会取不到状态值
Select Case dom.readystate '判断dom.readystate的值

Case 0 'IE未初始化,其实在该方法,readystate=0无意义,因为循环至少是从1开始的.
time0 = Now()
timer0 = timer()

Case 1 '"正在发送请求"
time1 = Now()
timer1 = timer()

Case 2 '"请求已经发送完成"
time2 = Now()
timer2 = timer()

Case 3 '"可以接收到部分响应数据"
time3 = Now()
timer3 = timer()

Case 4 '"页面加载完成"
time4 = Now()
timer4 = timer()

End select
wend
time_end = Now() '统计结束时间
'MsgBox "开始时间是:" & time1 & ";结束时间是"&time2

timeCount = "统计开始时间:"&start_time&vbcrlf&"time0:"&time0&vbcrlf&"time1:"&time1&vbcrlf&"time2:
"&time2&vbcrlf&"time3:"&time3&vbcrlf&"time4:"&time4&vbcrlf&"完成IE的初始化并发送请求:
"&(timer1-timer_start)&"秒"&vbcrlf&"发送完成并接受服务端部分响应数据:
"&(timer3-timer1)&"秒"&vbcrlf&"100%接收并完成HTML内容解析:
"&(timer4-timer3)&"秒"&vbcrlf&"总共花费:"&(timer4-timer_start)&"秒"
End Function

  本文出自dreamever的51Testing软件测试博客:http://www.51testing.com/?31621

  代码中的SITEURL就是我们要进行测试的页面。

  这段代码虽然不长,但是却花了我整整4个小时的时间。一开始碰到的难题就是不知道VBS如何去调用document方法,在网上查了无数资料,大多是讲如何在HTML代码中进行调用,很少说到如何使用标准VBS去调用,其实到最后才明白,VBS调用访问document无非就是这样的一句代码:

  Set dom = CreateObject("InternetExplorer.Application")

  虽然简单,但是却花了我一个小时才明白。

  通过这样的一段代码时间,我现在清楚了两件事,第一:VBS作为脚本语言,它的强大之处在于它调用windows的COM能力,而VBS本身并没有什么复杂的技术和体系。第二:QTP永远只是一款工具,它能做什么取决于我们如何去使用。

本文出自dreamever的51Testing软件测试博客:http://www.51testing.com/?31621

版权声明:原创作品,转载请保留链接,标明本文原始出处、作者信息和本声明,否则将追究法律责任。

本周排行

别人正在浏览

强悍的草根IT技术社区,这里应该有您想要的!
Copyright © 2010 Gimoo.Net. All Rights Rreserved  京ICP备05050695号