QTP自动化测试脚本中常用的函数

2011-02-16  陈斌 

1.GetCellData函数

作用:获取单元格的值

例: rowCount = Browser("xxx ").Page("xxx ").Frame("xxx").WebTable("xxx").RowCount

For counter = 1 To rowCount

text = Browser("xxx").Page("xxx").Frame("xxx").WebTable("xxx").GetCellData(counter,1)

If (text = "xxx") Then

    counter = counter - 1

    selectNO = "#" & counter

    Browser("xxx").Page("xxx").Frame("xxx").WebRadioGroup("xxx").Select selectNO

    Exit For

End If

Next



2.把值插入datatable里

例:   datatable.setcurrentrow(i)

        datatable.value("name","Global")="name"

        datatable.value("passwd","Global")="passwd"



3.用代码来启动浏览器

Browser1 = "IE"

StartURL = "www.51testing.com"

IF Browser1 = "IE" THEN

     set IE = CreateObject("InternetExplorer.Application")

     IE.Visible = true

     IE.Navigate StartURL

END IF





4.ExecuteFile函数

作用:ExecuteFile 可以直接执行vbs文件,而不需要将其导入resource中

       ExecuteFile FileName

说明:where FileName is the absolute or relative path of your VBscrīpt file.



例:ExecuteFile("F:"test.vbs")



5.Strcomp函数

作用:比较文本

例:dim strtext1,strtext2,str ,str1,comp1

     strtext1 = "xxx"

     strtext2 = "xxx"

     str = VbWindow("xxx").VbWindow("xxx").VbLabe1("xxx").GetTOProperty("text")

     str1= VbWindow("xxx").VbWindow("xxx").VbLabel("xxx").GetTOProperty("text")

     comp1=strcomp(strtext1,str,0)

     If comp=0 Then

          msgbox “这两个串相等”

     else

       msgbox str

     End If



6.CaptureBitmap

作用:捕获屏幕



7. GetROProperty

作用:取对象属性值

例:VbWindow("xxx").VbWindow("xxx").VbWindow("xxx").ActiveX("xxx").GetROProperty("TextMatrix(1,0)") 



8.ExitAction - 退出当前操作,无论其循环属性如何。

ExitActionIteration - 退出操作的当前循环。

ExitRun - 退出测试,无论其循环属性如何。

ExitGlobalIteration - 退出当前全局循环。





9.如何使用Excel对象处理数据?

Dim xl

打开excel文件

Function OpenExcelFile(strFilePath)

Set xl = CreateObject("Excel.Application")

xl.Workbooks.Open strFilePath

End Function

获得指定单元格数据

Function GetCellData(strSheet,rwIndex,colIndex)

GetCellData = xl.WorkSheets(strSheet).Cells(rwIndex,colIndex)

End Function

填充单元格数据

Function PutCellData(strSheet,rwIndex,colIndex,varData)

xl.WorkSheets(strSheet).Cells(rwIndex,colIndex) = varData

End Function

保存并推出

Function SaveAndQuit()

xl.Activeworkbook.save

xl.Quit

Set xl = nothing

End Function



10.连接sql数据库

im res,cmd,sql

     Set Res=createobject("adodb.recordset")

     Set Cmd=createobject("adodb.command")

     Cmd.activeconnection="rovider=SQLOLEDB.1assword=111111ersist Security Info=True;User ID=sa;Initial Catalog=xhq;Data Source=192.168.191.142"  '这句话是连接数据库的数据源,要做修改

    Cmd.CommandType = 1

    sql="selec t * from 表 where name=username"

    Cmd.CommandText = sql

    Set res = Cmd.Execute()

    Set res = nothing

    Set cmd.ActiveConnection = nothing

Set Cmd= nothing



11 检查页面是否存在
对象exist可以检查某一个页面是否存在。
代码:
if Browser("…").Page(“…").Exist then
‘在运行结果中显示的报告, “micPass”的状态是通过, micFail是不通过
   reporter.ReportEvent micPass ,“页面存在“,”通过“  
   else
   reporter.ReportEvent micFail ,"页面不存在“,"不通过"
end if

12 防止程序中断的方法
在回放脚本的时候,有时因为错误导致运行的脚本中断,不能自动运行。为了能达到真正无人职守的状态可以在脚本的最前面加上如下的代码:
On error resume next  ‘遇到错误返回到脚本的下一行继续执行。
On error goto 0 ‘错误处理的控制权,平时是由QTP控制的(这个叫默认的),当有on error resume next 时,是交给on error处理,当on error goto 0时,就换给QTP

13 同步点的设定
等待某一对象出现后继续执行,为了防止qtp找不到对象而设定同步点。有2种方法:1种是用wait加等待的时间,如wait 5(qtp等待5秒钟后继续执行)。另一种方法是等待要执行对象的出现,如果出现就继续执行,否则一直等待,代码如下:
y=......waitproperty("visible",true,10000)
If y=true then
   ‘执行下一条语句
   else
    ’对象不出现就一直等待,直到过了10000秒后程序找不到对象报错
End if

14 截屏
在优化脚本时,如果想查看某一页面在执行后的页面效果,可以采取截屏的办法截取当前的操作页面并保存到本地。代码:
    desktop. capturebitmap “c:"***.bmp“,ture     ’在脚本中想要查看的一行插入,运行后图片保存到设置的路径下



15 导入execl文件并参数化数据方法
Qtp自带了datatable表,可以把要参数化的数据写在里面,但这样写脚本和数据不能分离,后期不好维护脚本。现在采用从外部导入execl文件的方法导入数据。代码如下:
   datatable.ImportSheet “D:"..."data.xls”,“sheet1”,“global“
   ‘第一个参数是要导入文件的路径,第二个是execl的第一个表格,第三个参数是在execl的全局范围内查找
   另外datatable对象还有很多操作,比如:获取表中字段的行数,插入表数据,删除数据等,下面是获取表中数据的代码:datatable("A","dtglobalsheet)



16 为描述性编程自动创建注释
   当希望在每一个新建action时都增加一些头部说明,比如作者、创建日期、说明等信息,那么用action template 来实现最简单快捷。 方法:用记事本等文本编辑器,输入如下类似的内容:           'Company:东方般若            'Date: Date          然后将文件保存为ActionTemplate.mst,并存放到QTP安装目录下的dat目录。

17 导入vbs文件
想要实现脚本的函数化,并更好的维护它,可以把一些公用的函数写到vbs里面,用qtp来调用它。
实现调用vbs的方法有2种:
1.函数executefile加vbs文件的路径
  executefile “c:"..."funcation.vbs”
2.设置QTP test/settings/resources/+函数目录

18 时间差函数
统计两个日期时间段之间的间隔,还有多少小时
Dim timediff
timediff=datediff(“H”,now,“2008-8-8” )
Print timediff
 

 

19 获取web下拉框中数据的行数和数据值
1.获取行数:首先将webtable添加到对象库中,查看对象库里有该webtable的属性后
count=Browser("…").Page("age").Frame("…").WebTable("...").RowCount
   Msgbox count ‘查看行数
2.获取数据值,
   for i=1 to  count   
value=Browser("…").Page("age").Frame("…").WebTable("...").getcelldata(i,1)
   msgbox value
   next
获取到列表中的数值后,qtp的对象库中没有这个WebElement的对象,一般采用描述性编程的方法获取对象,比如:用getcelldata获取的表中数据的innertext属性是“普通岗”,那么就可以用如下代码:
for i=1 to  count   
   value=Browser("…").Page("age").Frame("…").WebTable("...").getcelldata(i,1)

   Browser(“…”).Page(“Page”).Frame(“…”). WebElement(“innertext:=“&value,”index:=1”).click
next

20 对象获得焦点
判断某个webedit输入框是否获取了焦点,如果没有获取就给它焦点,然后输入数值。代码如下:

if not browser("**").page(“**").webedit(“
**").object.isdisabled  then
         .object.focus
         .object.set "输入数值“

21 获取对象当前属性值
用GetROProperty可以获取对象的当前属性值,比如一些对象的属性经常发生变化,用getroproterty就能定位对象当前的属性状态来执行相应的操作。
Dim pro
pro= browser("**").page(“**").webedit(“
  **“). GetROProperty(“property”,value)
Msgbox pro ‘弹出窗口,查看获取的属性。

22 Systemutil对象的应用
利用systemutil可以实现的功能:回放qtp脚本时禁止鼠标和键盘的输入;打开应用程序或web;通过句柄关闭进程;通过进程名关闭进程等。下面的代码是打开百度网页:
  systemutil.run “iexplore.exe”,“
http://www.baidu.com/”,“”,“”,“”,3        ‘打开百度的首页,最后面的参数“3” 代表打开ie后最大化

   SystemUtil.CloseProcessByName(“iexplore.exe”)      ‘关闭ie

   
23 Action的使用
action分为内部调用和外部调用2种方法:内部调用使用split划分;外部调用时被调用的action设置成share,并共享对象库。
   split action:RunAction "action", oneIteration

24.  随机数
在测试中有时会用到随即数,有多种方法:
第一种 :n=randomnumber.value(1,255)  ’n的值从1到255之间随即产生
第二种 :randomize      ‘更新反回的数据          dim n
             n=int (10*rnd())
             msgbox n        ‘n为10以内的整数


25 “is+*”类型功能
   isarray'是否是数组 isconnected'判断QTP是否连接到TD isdate'是否是合法的日期类型 isempty'判断是否初始化 isNull'判断是否为空值 isNumeric'判断是否是数字型 isobject'判断是否一个功能对象 isready'判断设备是否准备就绪 isRootFolder'是否是根目录

26 对象库
打开对象库resources->object repository,或者用快捷方式:ctrl+r来打开。
1.Qtp中的对象库和脚本是一一对应的,如果脚本中某个对象在对象库中不存在,则无法回放成功,会提示找不到对象。
2.对无法识别的对象用spy工具获得后添加到对象库中。
3.有时候脚本回放失败就是找不到对象的原因,可以通过用spy工具查看找不到对象的属性,然后打开对象库,比较二者的属性信息,如果属性有不相同的说明就是属性的原因,可以通过更改属性的方式统一对象属性。

27 调试脚本
1.脚本编写完毕,可以用按ctrl+f7来查看脚本是否有语法错误。
2. Msgbox和print:在回放脚本时可以方便的查看自己想看到的信息。
3.设置断点:为了测试某一小段脚本的功能,而当整个action很长的时
候,可以设置断点单步debug。


28 强制退出
遇到问题退出可以用exittest或 exit for,例如下面代码:
Public function text_exit()
     for i=0 to 10
            if i=3 then
                exittest
                ‘exit for
            end if
     next
End function

Text_exit()
      
29 连接数据库_增删改
Dim conn,strSql    '定义变量
set conn = CreateObject("ADODB.Connection")   '创建连接
conn.ConnectionString="rovider=SQLOLEDB.1assword=isaac121379ersist Security Info=True;User ID=sa;Initial Catalog=WisdomCRM;Data source=192.168.12.29"   '设置连接字符串
conn.open  '开启连接
'strSql="insert into UM_User  values(1,'UserID')"  '设置插入语句
strSql="drop  table TM_Task_14_Target"
'strSql="select *  from UM_User"
If conn.state=0 Then   '如果连接状态为0,表示连接失败,写入reporter对象中,否则表示连接成功
    Reporter.ReportEvent micFail,"testing","数据库连接失败"
    conn.close
    Set conn = nothing
else
   Reporter.ReportEvent micPass,"testing","数据库连接成功"
   conn.execute strSql    '执行更新语句
   conn.close
   Set conn = nothing
End If

 

 
1.WEB表格类型单元格,不能直接用set录入,需用以下函数
Function beizhu()
Dim MyWebElement
Set MyWebElement = Browser("费用申请单").Page("费用申请单").WebElement("备注").Object
'MyWebElement.innerHTML = DataTable("备注", dtLocalSheet)
MyWebElement.innerHTML = "已经修改"
End Function
2.登录判断
Function  login()
   Dim value
if Browser("EAS系统登录").Page("账号重复登录").WebButton("忽略").Exist        then
        Browser("EAS系统登录").Page("账号重复登录").WebButton("忽略").Click
End If
End Function
3.快捷键盘的函数
Set Wsh = CreateObject("Wscript.Shell")
        Wsh.SendKeys"{DOWN}"
        set oShell = Nothing
4.windows窗体TAB,简便切换
Browser("EAS Portal").Window("金蝶BI平台 - 主题配置 -- 网页对话框").Type micTab
5.启动IE
SystemUtil.Run DataTable("URL", dtLocalSheet)
6.选中表格
Browser("EAS Portal").Page("EAS Portal").Frame("content").WebElement("WebElement").Click
innertext的值为表格内容
7.自带了随机数参数,可用于赋值和检查
8.环境变量进行赋值
Environment("TCase") = testCaseName
1573°/15722 人阅读/1 条评论 发表评论

袁帅  2011-04-15

这文章很好! 不客气了、我收藏了、


登录 后发表评论