51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 3123|回复: 9
打印 上一主题 下一主题

[原创] 请教关于QTP对象识别原理的问题。

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2012-9-24 20:38:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
请教一个QTP识别原理的问题
描述:
我学习QTP大半年时间了,对QTP是如何识别对象的原理仍然很模糊.QTP的识别过程,应该是通过调用add-in插件,将应用的对象属性与add-In的控件‘类属性’做映射,将应用的QTP对象转换成add-in对象,这样就可以使用对象类的方法和属性了。我理解这就是QTP的AOM、OLE、关键字驱动等等的由来,不知我这样理解是否有问题。
问题:
假如以上是对的,那么QTP中肯定存在一个 QTP对象 与 add-in对象‘映射的切入点’。这部分知识我可以从哪里了解,请不吝赐教,谢谢~
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2012-9-25 11:56:15 | 只看该作者
你说的应该是QTP的实现原理,但对象识别的话,不同的语言,开发平台会有不同,.NET可能会用到反射,delphi应该是打桩来识别的~
有兴趣的话,可以自己写个东西来识别IE,一般识别是整个IE就是winobject, 如果你可以实现识别里面的对象,那么着就是识别原理,不过这个还是挺有深度的~
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2012-9-25 16:39:26 | 只看该作者
回复 1# xjwldlover

你是不是想得太复杂了?
而且你的描述我有点没有看明白, 比如“应用的QTP对象”何解? 还有OLE和关键字驱动怎么也能扯在一起?

我对QTP对象识别的理解是这样的。 被测试产品的GuI对象就是所谓的“native object”, QTP对“native object”封装了, 提供了一个所谓的“QTP object”。

一般我们直接操作“QTP object, 但是QTP也提供接口你能“访问”native object, 比如调用javaobject的方法, 或者获取dom对象的属性等。   但一般不建议这么做, 因为 “QTP object”具有更容易使用, 更有效率的接口,比如其childObjects就是一个非常有用的方法。

至于”映射是如何完成的“, 对于不同类型的GUI, 肯定有不同的实现机制。 最笨的方法, 就是遍历Native GUI element tree来匹配。 以html为例, 底层就是Dom tree,如果你熟悉Dom的接口, 那么你也完全写一个类似QTP object的接口的封装Dom对象的”自动化测试工具“, 其实Watir就是这么干的, 你可以去看看Watir的源代码。 当然, 为了提高识别效率, 或许QTP用了一些特殊的hook也说不定, 但除非你对此有特殊的兴趣, 对于我们测试开发人员来说, 不用探究其细节了。
回复 支持 反对

使用道具 举报

该用户从未签到

4#
 楼主| 发表于 2012-9-25 17:52:36 | 只看该作者
感谢您的回答~
首先OLE、关键字驱动、AOM,我自己理解他们都是使用对 对象的引用。
ole对象连接嵌入,是使用dll\ocx\exe来获取对象、方法、属性;
关键字驱动我理解是qtp调用add-in插件中的对象,将对象的方法、属性封装,映射给QTP对象,通过操作QTP对象来操作应用对象,映射结果就是我们看到的Object Identification;
AOM 就是把QTP的对象也做成ole插件供其他程序调用,控制。
他们本质上都是对对象的引用,所以我把它们关联一起理解了。

了解映射的目的:系统存在大量被开发人员修改的的控件,QTP原来是识别成treeView,开发人员修改属性后,却被QTP识别为WinObject,无法使用对象的方法。如果是web程序还比较好整、肯定能找到对象改变的源头,直接使用dom调用原始对象。但如果是window标准控件,.net控件,应该就不好弄了(写到这里,突然感觉我是想当然了,WEB页面既然有DOM这样的标准,。net和其他应该也有,也能通过自定义对象来解决,这块以后需要多接触~)。
    这么一想,觉得更应该把应用对象(插件对象) 与 QTP对象的映射方式搞清楚了
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2012-9-26 03:17:08 | 只看该作者

fs

儿孙自有儿孙福,莫为儿孙做远忧
去濠锋会又赢了几百快。不错 民办文凭 www.zhinangedu.com 优享时尚 www.uugoods.net 不锈钢席型网www.buxiugangsw.com 棋牌游戏 www.qianlei.cc
回复 支持 反对

使用道具 举报

该用户从未签到

6#
发表于 2012-9-26 13:12:42 | 只看该作者
回复 4# xjwldlover


    我还是不明白最后你是怎么解决这个问题的,就是你说的开始是treeview后来qtp一识别就变成了winObject这个问题。因为我的软件是flex开发的,有时候会被qtp识别为FlexObject。。。
回复 支持 反对

使用道具 举报

该用户从未签到

7#
发表于 2012-10-9 16:56:53 | 只看该作者
没接触过
回复 支持 反对

使用道具 举报

该用户从未签到

8#
发表于 2012-10-9 16:57:02 | 只看该作者
我还是不明白最后你是怎么解决这个问题的,就是你说的开始是treeview后来qtp一识别就变成了winObject这
回复 支持 反对

使用道具 举报

该用户从未签到

9#
发表于 2012-10-9 16:57:05 | 只看该作者
怎么解决这个问题的,就是你说的开始是treeview后来qtp一识别就变成了winObject这
回复 支持 反对

使用道具 举报

该用户从未签到

10#
发表于 2012-10-9 16:57:24 | 只看该作者
学习了
回复 支持 反对

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-4-28 12:26 , Processed in 0.074222 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表