【转帖】GetROProperty、GetTOProperty的区别

为了便于记忆可以这样理解:R,就是Runtime,T就是Testtime,O就是Object。因此顾名思义,RO就是在测试执行时的对象,TO就是录制/编写测试时的对象。是同一个类在不同的时间生成的不同的实例,一般来说TO是静态的,而RO是动态的(每次执行测试都会生成新的实例)。
TO是仓库文件里定义的仓库对象,RO是被测试软件的实际对象
QTP要求先在仓库文件里定义仓库对象,里面存有实际对象的特征属性的值,
运行的时候,QTP会根据仓库对象的特征属性描述,寻找到实际对象,然后操作实际对象。

仓库对象TO一般在录制/编写脚本时加入仓库文件,它不仅可以在编写时进行修改,
也可以在运行过程中进行动态修改,以匹配实际对象。

相关的几个函数有:

GetTOProperty():取得仓库对象的某个属性的值
GetTOProperties():取得仓库对象的所有属性的值
SetTOProperty():设置仓库对象的某个属性的值

GetROProperty():取得实际对象的某个属性的值

理解了TO的含义,你就可以自由的用SetTOProperty()定义TO,以灵活的操作RO

比如有个测试任务,窗口上有很多待检查的记录,每条记录右边都有一个Check按钮,用来检查各条记录。
记录个数不定,所以Check按钮个数也就不定,只有一个Edit显示记录个数。
我们要对每条记录进行检查,也就是要点击每个Check按钮。
但是Check按钮个数不定,不好录制,而且个数可能也很多(上百个),即使能一一录制,那也很麻烦。

那我有一个好办法,只录制一个按钮对象,它设有两个特征属性 label=OK, index=0
然后用下面的脚本,就可以完成测试

buttonNum = CInt(JavaWindow(“Test”).JavaEdit(“Record Num”).GetROProperty(“value”))
For buttonIndex = 0 to buttonNum – 1
  JavaWindow(“Test”).JavaButton(“Check”).SetTOProperty(“index”, buttonIndex)
  JavaWindow(“Test”).JavaButton(“Check”).Click
Next

或者窗口上有New、Modify、Delete、Check等好几个按钮,要把这几个按钮一一按过去
我在对象仓库里只设置一个按钮对象AnyButton,label特征属性值填任意值,然后用下面脚本执行测试

JavaWindow(“Test”).JavaButton(“AnyButton”).SetTOProperty(“label”, “New”)
JavaWindow(“Test”).JavaButton(“AnyButton”).Click

JavaWindow(“Test”).JavaButton(“AnyButton”).SetTOProperty(“label”, “Modify”)
JavaWindow(“Test”).JavaButton(“AnyButton”).Click

JavaWindow(“Test”).JavaButton(“AnyButton”).SetTOProperty(“label”, “Delete”)
JavaWindow(“Test”).JavaButton(“AnyButton”).Click

JavaWindow(“Test”).JavaButton(“AnyButton”).SetTOProperty(“label”, “Check”)
JavaWindow(“Test”).JavaButton(“AnyButton”).Click

另外,QTP还支持脚本描述的方法来定义和访问对象,即不需要在仓库里定义,也能访问和操作实际对象

如上面两个任务,可以如下实现

1. 不需要在仓库里定义Check按钮对象,直接用下面脚本来实现测试

buttonNum = CInt(JavaWindow(“Test”).JavaEdit(“Record Num”).GetROProperty(“value”))
For buttonIndex = 0 to buttonNum – 1
  JavaWindow(“Test”).JavaButton(“label:=Check”, “index:=”+CStr(buttonIndex)).Click
Next

2. 不需要在仓库里定义New、Modify、Delete、Check按钮对象,直接用下面脚本来实现测试

JavaWindow(“Test”).JavaButton(“label:=New”).Click
JavaWindow(“Test”).JavaButton(“label:=Modify”).Click
JavaWindow(“Test”).JavaButton(“label:=Delete”).Click
JavaWindow(“Test”).JavaButton(“label:=Check”).Click

现在讲讲QTP操作对象的原理!

QTP为用户提供了两种操作对象的接口,一种就是对象的封装接口,另一种是对象的自身接口。
对象的自身接口是对象控件本身的接口,只要做过软件开发,使用过控件的人应该很清楚。
对象的封装接口是QTP为对象封装的另一层接口,它是QTP通过调用对象的自身接口来实现的。

两种接口的脚本书写格式的差别在于:
  自身接口需要在对象名后面加object再加属性名或方法名,
  封装接口就不用在对象名后面加object。

比如操作JavaEdit对象,通过QTP封装的封装接口,脚本如下:
  设置JavaEdit的内容:
     JavaDialog(“Add NE”).JavaEdit(“NE Name”).Set “NE1”
  读取JavaEdit的内容:
     msgbox JavaDialog(“Add NE”).JavaEdit(“NE Name”).GetROProperty(“value”)

如果通过JavaEdit的自身接口,脚本如下:
  设置JavaEdit的内容:
     JavaDialog(“Add NE”).JavaEdit(“NE Name”).object.setText(“NE1”)
  读取JavaEdit的内容:
     Msgbox JavaDialog(“Add NE”).JavaEdit(“NE Name”).object.getText()

QTP执行JavaEdit().Set语句时,是通过执行JavaEdit().object.setText()来实现的。
QTP执行JavaEdit().GetROProperty(“value”),是通过执行JavaEdit().object.getText()来实现的。
JavaEdit对象的封装接口Set()和GetROProperty(“value”),是QTP封装JavaEdit对象的自身接口setText()和getText()而得来的。

对象的封装接口是QTP使用的缺省接口,我们录制出来的脚本都是使用封装接口,大家用的也都是封装接口。
但是封装接口不如自身接口丰富,因为QTP只是封装了部分常用的自身接口嘛。
所以我们在需要时,可以绕过封装接口,直接调用对象的自身接口。
不过有些自身接口不够稳定,在实践中偶尔会出现问题,但是概率很少。
封装接口有相应功能的话,就尽量用封装接口吧!

理解了封装接口和自身接口的原理,我们就可以更加灵活的操作对象了。

但是我们怎么知道对象都有哪些封装接口和自身接口呢?
其实很简单,用对象查看器(Object Spy)查看对象,在查看窗口里有列出这些接口,包括属性和方法。
窗口中间有选择栏让你选择Run-time Object或者Test Object,
当你选择Run-time Object时,它显示的就是对象的自身接口(自身的属性和方法)
当你选择Test Object时,它显示的就是对象的封装接口(封装的属性和方法)

明白了这些,你还等什么呢?快拿起对象查看器,看看对象都有哪些封装接口和自身接口,肆意的操作它,玩弄它吧!

比如执行
  JavaDialog(“Add NE”).JavaEdit(“NE Name”).object.setVisible(false)
哈哈,你的JavaEdit对象就当场消失不见了!!!

你可以拿这个做恶作剧,指着这个窗口逼问开发人员,JavaEdit对象哪去了?
开发人员肯定瞪大眼睛看着这个窗口,当场翘掉!!

发表评论

电子邮件地址不会被公开。