QTP常见运行错误问题解答

上一篇 / 下一篇  2007-12-15 20:26:35 / 个人分类:—— QuickTest Pro

QTP常见运行错误问题解答51Testing软件测试网 t1G/qN.uk

51Testing软件测试网{t(PG Dy

 51Testing软件测试网td0iKDNlPt0p

51Testing软件测试网j$\)FH`A%K

1. 不能识别对象(Cannot identify object)出现了这个错误时,就表示当前被测程序的窗口中没有符合条件的对象。51Testing软件测试网nd|_p

%C*p'| OgW-PV0出现这种错误,可能的原因有以下两种:51Testing软件测试网2z6CL[/ue$gyF

X[$H~} \ ^^9KL^)]0>>> 对象此时在程序中没有显示或不存在。

bvD#JIN}051Testing软件测试网:s9Y*R Zy#X.n-@7rn

>>> 在程序中存在该对象,但是它的描述在后来发生了改变,导致与对象仓库中存储的信息不匹配,从而QTP无法识别对象。51Testing软件测试网`.TEQZ!e[:g-y!Oy!e

l:\ D B g!J+k0如果你正遇到“Cannot identify object”的问题,解决方法见1.1。51Testing软件测试网^\9Ga }%rU;C.k3d[

X4F_(ixI:p.c$O01.1 如何去识别对象描述(Identifying Test Object Descrīption Problems)     如果你能在被测程序中看到对象,但仍出现了“Cannot Identify Object”错误信息,这就表示仓库中对象的描述与程序中对象的描述一定存在着差异。

7J t/]6I_K0

D`9pS8N7G:w0    解决对象描述问题的第一步是找到差异,最简单的方法是将仓库中对象的属性值与程序中对象的属性值进行比较。(仓库中对象的属性值可在Object Repository窗口中查看,程序中对象的属性值可用Object Spy功能查看。)

m4|W"kJ ku&qV0

[P/a5G4L i.s0比较仓库中对象的属性值与程序中对象的属性值的操作见1.3。

h&LT2ee051Testing软件测试网 L[Q,e |S+tF

在完成比较后,是否发现存在差异?

q7tC/ugW@ o051Testing软件测试网 O7}Go eu/_

如果是,请参考1.4;51Testing软件测试网 x*PGNQ

51Testing软件测试网2d9`0R*lv5@2v

如果否,请参考1.5。 

Y,g%qU8K9N9n;k0

mW6s{V g4H!t1Zd01.2 处理对象丢失问题(Solving Missing Object Problems)在运行脚本时,QTP尝试进行某种操作,而该操作的对象在程序中却没有出现,出现这种情况的原因有以下几种:51Testing软件测试网"{ W(m3g rA

!Ob6S8V `!~5Q3t|2V0>>> 对象不再存在。对象已经被从程序中删除。51Testing软件测试网+\@#tC!?.T#z

51Testing软件测试网)[]blo0R$Du'm

解决方法:见1.2.1。

Xs4_z'n$fXBH051Testing软件测试网X#f3TF7c$HT

>>> 对象还没有装载。51Testing软件测试网?:bwBe7n

E&vIi4u)Fg1k0解决方法:见1.2.2。51Testing软件测试网Z)t?e6XvB,]

51Testing软件测试网$ib)JI8J'E&w

>>>当前的程序页面(或窗口)不正确,不是对象所在的页面(或窗口)。

^8n$b/`#{ i.m0

&M _!|9|"OWX0解决方法:见1.2.3。

I+}\6B3?(~k ]0

G*G-a.h7oXTQ/[0>>>前一个步骤没有正确执行。51Testing软件测试网wB6Oj D/aL'T

3lw*Z R4iJ0解决方法:见1.2.3。51Testing软件测试网"I6k?6wmm`7\

*XV9IUlOn01.2.1 解决对象不再存在的问题如果对象已经不再在被测程序中存在,则应在脚本中修改或删除相关步骤。51Testing软件测试网zHZ;Q2Z m

51Testing软件测试网N YUN'c k.B;`5in2G

1.2.2 解决对象装载超时的问题如果对象丢失的原因是因为没有足够的时间装载,尝试以下解决方案:51Testing软件测试网.oS5g-H0d ~\

51Testing软件测试网^U|i)?N

a.对于Web对象,增加Browser Navigation Timeout(File>Setting>Web页签)时间。

"fn"ct;]:rd0

Y F(ePa0b.在包括该对象的步骤前使用Wait语句,让QTP在执行该步骤之前等待一段时间。

3k1zc@6si.ky'Q0

DY_ N%Gm%\d+{M01.2.3 检查前面步骤的执行情况如果是因为打开了错误的页面(或窗口)导致对象丢失问题,或因为前一步骤执行措误导致对象丢失问题,则请按以下方法检查原因:

'f7|L/d1sW;U%@:m051Testing软件测试网'gP4fL8jd ox~1O

a. 如果怀疑在完成脚本后,被测程序又发生了改变,则检查对象的继承关系以及对象描述。参考1.1。

Oz ZuPC4yl8P051Testing软件测试网Y#xY kOB"r

b. 如果怀疑脚本错误,则检查脚本的每一个步骤。你可能是遗失了某个步骤,也可能是使用了不正确的方法或参数51Testing软件测试网Ky5qY2z^

51Testing软件测试网!X H)m*Xpg%a

1.3 测试对象的属性值与Run-time对象的属性值的比较(Comparing Test Object and Run-Time Object Property Values)根据以下的步骤比较测试对象与Run-time对象的属性值:

+h4t dbEil051Testing软件测试网*Abq r ] v1H/up%z

1) 进入Obecjt Repository窗口(Resources>Object Repository),选择对象。

7z W\$A"mG }w7Et2_ r0

-I$io"KW5c9q02) 用笔记下对象的class以及它的各个属性及属性值。51Testing软件测试网#Ssi_mfm

51Testing软件测试网 W$c*JR H$n

3) 打开被测程序,并打开包含被测对象的页面或窗口。51Testing软件测试网C!AI%l:IXS f6v

51Testing软件测试网:\)~+D ZVf(Z:Hq

4) 在QTP中选择菜单Tools>Object Spy或点击Object Spy按钮,打开Object Spy对话框。

hL:_6R4sw3s C0

!`8b2eDm$]05) 选择“Test Object Properties”选项。51Testing软件测试网Gc$t(j?/Ep

(woHZ#P7]\_Y06) 点击右上角的按钮(带有手图标的),这时QTP窗口以及Object Spy对话框都被最小化。

*qlw~4_0

3k'~J+WV-^ZIA07) 在程序页面(或窗口)中点击目标对象,恢复Object Spy对话框,并在对话框中显示对象及其父对象(以树的形式显示),并在Properties页签中显示当前对象的属性及属性值。

d,N3|4g8ZI2{051Testing软件测试网UCe$HlGU,y"VE

8) 这时Object Spy对话框的Properties页签中显示Run-time对象的所有属性,在此查看对象的class,以及它的属性及属性值,并将它与第2步中记下的内容进行比较。 

C(Ok+@ _j;Mg0

bqj6k;JgsZHG+L01.4 解决对象描述存在的问题(Solving Object Descrīption Problems)     如果发现仓库中对象的属性值与程序中对象的属性值存在不同,你应该判断这个不同是个别对象的问题,还是其它同类对象也存在相同的问题。

N7?KWkx,}0

6U!QTF N K$A0是所有(或多个)同类对象都存在问题吗?

/t5](U*R,E)i*z(^W0

m#S3avA'u0如果是,则参考1.651Testing软件测试网0u?` { ps

N$ON$N:`2[2Rl*X&n1`0如果否,则参考1.7 51Testing软件测试网5x;MJc!PE@ir

kuwfs,t3t.M/|)L01.5 关于父对象描述的识别问题(Identifying Parent Object Descrīption Problems)对象的识别还与它所继承的父对象有关。51Testing软件测试网C,a[o.P`H|A1hLN%d

iu ]x VPj0    如果你能在被测程序中看到对象,而且程序中对象的属性值与仓库中对象的属性值也是一致的,但仍然遭遇到了“Cannot identify object”错误,则这个错误可能与它的父对象有关(如仓库中父对象的属性值与程序中父对象的属性值不一致),也可能是仓库中的对象与程序中对象的继承关系不相同导致的。51Testing软件测试网5x*DjUt'~K{ V:G

;i;cv z t\2f0要判断是继承关系中的哪个父对象出现了问题,请偿试下面的方法之一:

jDt7|)FP0|.~051Testing软件测试网 gZ/i_8X

>>>重新录制对象,比较新旧对象的父对象。51Testing软件测试网(B-oe*aU/hr}

1X"s{6Yyn+Ry0欲了解如何完成比较,参考1.8。

7z#l7ELs5S }0

n0u4\E:}E0>>>对继承关系中的每个父对象,分别插入一个Exist语句,并运行该部分脚本。51Testing软件测试网cIMd1T)?

51Testing软件测试网fR!zekmp}

欲了解如果创建Exist语句,参考1.9。51Testing软件测试网|YSrsJ&G

:J(h |Y0v+T5\0注:你也可以使用Object Repository窗口中的Highlight in Application功能,在被测程序中定位对象。

.g#U:pS&Ih#F Y(a051Testing软件测试网5?LR!mE5r

一旦找到了存在问题的父对象,接下来偿试以下方法:

I-Q%v/Y GV g051Testing软件测试网Lr4Z5gk/J}W

>>>修复存在问题的父对象的描述。方法见1.4。51Testing软件测试网 a#r1D7qD"yVuw

51Testing软件测试网vG R5\Y*W?

>>>在专家视图的模式下,查找所有继承存在问题的实例并进行修正。

Yd-TsqEd/P3m051Testing软件测试网SR^JG i;Q.?w2jf

举例:1.8.1。 51Testing软件测试网+O w O obbV[So

51Testing软件测试网_^8H+n2EA

1.6 解决某类对象的识别问题(Soving Object Identification Problems for a Test Object Class)     如果你发现某类对象的对象描述对于被测程序来说都不是很合理,或你预期到对象描述中的某属性值是经常变化的,你可以在Object Identification对话框中改变该类的识别属性的设置,或定义该类的Smart Identification设置并启用Smart Identification机制,这样QTP就可以唯一识别对象了。

w X3~ A+qZ051Testing软件测试网 q.QM#C,K4Dl@%C

1.7 解决单个对象的描述问题(Solving Individual Test Object Descrīption Problems)51Testing软件测试网y f!hZOu{

选择下列方法之一来解决对象的描述问题:

gSl sh!NC ]d0>>>如果被测程序中对象描述发生了改变,并且你也清楚改变的内容,并且该改变是永久性或长期性的,你可以直接手工修改仓库中对象描述中的相关属性值。51Testing软件测试网"ry| k$giM(BP

IKKg({b0>>>如果被测程序中的对象的属性值依赖于前面的步骤或其它对象,则将该属性值参数化,这样就可以使用其它步骤的输出值为属性值。51Testing软件测试网 j5T_ujgA1@*v0w

51Testing软件测试网E[$L.US6b!Q H5b

>>>如果属性值的组成部分中,部分是固定的,部分是动态改变的,则可以将属性值设计为正则表达式。

(tG*] }~@M0

*ro[(qX?pBx0>>>如果属性值是遵循某种规则变化的,或者是不可预期的,则从对象描述中移除该属性,并向对象描述中添加一个或多个属性以便于QTP进行对象识别。51Testing软件测试网0zF;x7R*@7}n

t r$B6jdZ'H0>>>If you can only access the information on the property values during the run session, you can create and use functions that use programmatic descrīptions to identify the object using property values retrieved earlier in the run session.51Testing软件测试网y l#d^Pqf|L

51Testing软件测试网{ S-Ip:Dvx

For more information on programmatic descrīptions, see Using Programmatic Descrīptions.

&E Q]V3X z Oy0

s5u*{ MS#h6x%yv0>>>如果在录制过程中对象是唯一的,但现在程序中出现了两个或多个描述相同的对象,但是它们在页面(或窗口)中的位置不相同,则应在Object Properties或Object Repository窗口中,向对象描述中添加一个ordinal identifier(index或location)。

h#zP0Mn+G0

t U+c'Q X0tt'LH6~k0 51Testing软件测试网EWY X$a-R

1R3dCu9M:Y \b1S:R,W01.8 重新录制对象,以判断父对象描述是否存在问题(Re-recording an Object to Identify Parent Object Descrīption Problems)根据下面的指引,来判断父对象的问题。51Testing软件测试网 B Y!R!a Z9e

51Testing软件测试网]%\&mle

通过重新录制对象,来判断它的父对象是否存在问题:51Testing软件测试网R-X-W~5I t-o?`

]1`5i6w{b-]g.{01) 打开浏览器或程序,来到包含被测对象的页面或窗口。51Testing软件测试网6p7o7Ei+h:[ K

"O-zc?f7M?ei02) 在关键字视图模式,选择最后一个组件(component),或在专家视图模式,将光标放在最后一个脚本步骤的下面。51Testing软件测试网'p%fx/]X]

51Testing软件测试网d+Hx q RTb

3) 点击Record按钮,或选择Automation>Record。51Testing软件测试网8x*u+jtM D

(W.d4X@(eB7_{!W!^z04) 点击(或操作)页面或窗口中的目标对象。

&j9}4mhRk E|051Testing软件测试网r!L'Lrv4gd

5) 点击Stop按钮,或选择Automation>Stop,完成步骤添加。

k g+[YEK"F#p+^)oN051Testing软件测试网Z2EDW6G"kZ ?

6) 右击新添加的步骤,并选择Object Properties右键菜单。

l6f[Xxz}q2s"N0

0Wn~2S1J07) 在Object Properties对话框中,点击Repository,打开Object Repository窗口,并选中了新对象。注意记下该对象的继承关系。51Testing软件测试网Z'l FgG3M-N6f

51Testing软件测试网POz$ZpQ

8) 在Object Repository窗口中找到旧的对象(即存在问题的对象),将它的继承关系与新对象的继承关系进行比较。

}jqP,bN0

0y u)hl,t+bYh2t0通过比较,可以检查到新旧对象是父对象的描述存在不同,还是它们的继承关系根本就不同。51Testing软件测试网6U&Y?u/Q?3v0b

c:bs8YRs0a. 如果是父对象的描述问题,则修改父对象的描述。参见1.4.51Testing软件测试网3iwiFg

t$Dg_[1J0b. 如果是对象的继承关系不正确(即具有不同的父对象)引起的问题,则在脚本中找到所有使用该继承关系的实例,将它们替换为正确的继承关系。51Testing软件测试网3zXR,W0W1N.A

*O O$fc!d5f0举例:参见1.8.1。

`$p8~8eT0

"Q;KP&y5L bS01.8.1 举例     假设有一个带有Frame的网站,你录制了一个操作针对Image对象“Poster”的操作步骤。在Object Repository窗口,你可以Image对象的继承关系如下所示:

cC7y+D0@!]?6I/Va051Testing软件测试网Gq?#`w

MyCompany(Browser)

^Nv;NGJ4||0

D#R6I co[+^-D,}0    MyCompany(Page)51Testing软件测试网C3f#oVk^Xz

!s+hA Sv:?0        Main(Frame)51Testing软件测试网%nw^%|Y\

FM.B4xk^*vu0             Poster(image)51Testing软件测试网!YE-^,Fr/`

51Testing软件测试网3?`6|U xd

    当你运行脚本时,网页看起来没有什么不同,但是识别Image对象时却出现了“Cannot identiry object”的错误提示。当你重新录制操作步骤,然后在Object Repository窗口中查看新的Image对象时,发现该对象的继承关系如下所示:

Uu:ea5B051Testing软件测试网%Awp_1M(In

MyCompany(Browser)51Testing软件测试网o2e/Zli q,MA"|

4? V;RfS.j1y0    MyCompany(Page)

e NVGgy6i^[051Testing软件测试网!r\e be

         Poster(image)

f^[ \J:u$H6Vo~,m051Testing软件测试网YQa4|?3E^

    从中可以看出,Frame已经从Web Page中移除,所以尽管Image对象“Poster”的描述没有发生任何改变,但它的继承关系已经改变了。

B^2TeZMF"HQ051Testing软件测试网9HH9K+d }3S}Y%aX

    在Object Repository窗口,你可以看到新旧Image对象“Poster”是两个完全不同的对象:旧的位于已经被移除的Frame对象之下,而新的则直接位于Page“Mycompany”对象之下。

8P,K8?(L3c+{V-M2r051Testing软件测试网{.OfIah

    修复这个问题,可以在脚本步骤中将旧的对象替换为新的对象。51Testing软件测试网p2] bCW,]

51Testing软件测试网x5F4I+VamD

    为了保持Object Repository窗口的整洁,你应删除那些已不再存在的对象(如本例中的Frame)。

q r*RX r,TT%R051Testing软件测试网NV0o-IP/G)H

1.9 创建Exist语句,以判断父对象的描述是否存在问题     QTP在录制发生在某个对象上的操作时,也会同时去了解对象以及它的继承关系。因此,如果在运行过程中,QTP不能识别继承关系中的任何一个父对象,都会导致目标对象的识别失败。

*q2C:c$OR1D0

oI\rw E}R0    使用带有Exist方法的Msgbox语句,可以方便的检查出是继承关系中的哪个父对象出现了问题。51Testing软件测试网-d| P0~f

2TT1dHC9F'tr0    假设在运行下面脚本时,你遇到了“Cannot identify Object”错误信息(但是可以确定对象仓库中Link对象的描述与当前程序中对象的描述是完全一致的):

"i7I}M9OS0

%LJ S9m w&W#yB z0Browser("Yahoo!").Page("Yahoo!").Link("Arts & Humanities").Click51Testing软件测试网$^:F"Z*EJ9`

51Testing软件测试网X!L6m`lgXq

你可以在该语句前面插入以下语句:51Testing软件测试网T/E4h;m9Z

Hi UB5mb"s$O2X0Msgbox Browser("Yahoo!").Exist51Testing软件测试网1nHp d T'v

51Testing软件测试网 a7fnGw/SU

Msgbox Browser("Yahoo!").Page("Yahoo!").Exist

mBO-]5Mt X nm051Testing软件测试网-j ?.V#P#F@,r

Msgbox Browser("Yahoo!").Page("Yahoo!").Link("Arts & Humanities").Exist51Testing软件测试网8J S4To#{R

6HZYO9uk j0然后你从头开始运行脚本,发现第1行语句运

s3K0BG,f3m Z4~v0

E$g\q1RKr"N6_\0

1J!Tm1BrG*M(N0

\E']6G7~zp0    但是,当QTP运行到第2步时,就弹出信息框,内容为“False”,表示不能找到Page object。这就证明Page对象存在问题。

9Lb$h9IVz5WW X0

Y7|5W | p1pq |0    确定了出现问题的父对象以后,修复该问题。参见1.4。

*fh!UL(f0

IofJ_m02. 对象不唯一(The object is not unique)在被测页面或窗口中的同一父对象下,找到多个与仓库中对象描述相符的Run-tim对象。51Testing软件测试网F^a Rh2V

51Testing软件测试网h1q/r q1@

请确定是只有个别对象存在此问题,还是此类对象的所有对象(或部分对象)存在此问题。

J+T?\&`'zX051Testing软件测试网 lG4TdBK

此类对象的所有对象(或部分对象)都存在此问题吗?51Testing软件测试网w](E"[ UT

51Testing软件测试网UjD:K6[,S

如果是,参考2.1;

hm1O~ }hm${2G0

0Gdgx`S|0如果否,参考2.2。 

&c+[dF T051Testing软件测试网 SOPzpn#w

2.1 为某对象类设置能唯一识别对象的描述规则(Configuring Unique Test Object Descrīptions for a Test Object Class)     如果你发现某类对象的对象描述都不足以唯一识别对象,你可以在Object Identification对话框中,改变该类的识别属性的设置,或定义该类的Smart Identification设置并启用Smart Identification机制,这样QTP就可以唯一识别对象了。51Testing软件测试网3E ~0^ K5jD;agB.X

51Testing软件测试网x9X5j s_\qm

 51Testing软件测试网\%pj ?mqs

51Testing软件测试网V H/a|}tq

2.2 设置通唯一识别对象的对象描述(Creating a Unique Test Object Descrīption for an Object)查看当前对象的描述,并偿试在程序中找到其它具有相同描述的对象并查看它们的描述。

o#Qz de+xc.x0

WL~M1?G3M5U0>>>如果你找到了可以将它们区别开来的一个或多个属性,则修改仓库中对象的相关属性(如向描述中添加属性等),以使QTP在运行时可以唯一识别它。51Testing软件测试网$i1Fza1e+K})m

51Testing软件测试网"T2^e3Z4~7n?E0r&e

>>>如果它们的识别属性完全相同,则在对象描述中为对象添加一个ordinal identifier(index或location)。 51Testing软件测试网 ] n}q JT

B[ U5z$_Qz9RY03. 找不到父对象(Parent not found)识别对象时,会先识别它的父对象是否正确。如果遇到“Parent not found”的错误信息,请偿试以下解决方法:51Testing软件测试网;Ge(}u^U

51Testing软件测试网F S s#`X0t

>>>修复出现问题的父对象的描述。参见1.4。

U4a`$I o fh0

#s*e\P{#o:^(l?B0>>>在脚本中找到继承关系不正确的实例,并修改为正确的继承关系。例如1.8.1。

p2p'`)j o$V}|!k0\051Testing软件测试网DJ N7MM+Y

4. 无效的参数(Invalid arguments)一个或多个方法的参数是无效的。

|vyAp%Om&JhL m051Testing软件测试网 w4C` E|kf}

参数无效可能是参数类型错误,也可能是参数个数不正确。51Testing软件测试网Aa+{8uH nNJ8h

51Testing软件测试网!X!CH*ttV

根据以下建议,找到方法的正确语法:51Testing软件测试网CPV`m%Hi

7z1`B?Ga1?P0>>>在Keyword模式,如果方法包括参数,则在Value栏会显示该方法的参数提示。51Testing软件测试网o s;H c`dy$V

51Testing软件测试网xYxO)N)l k

B CIW&TF?{8M051Testing软件测试网G7A7fXe m3C

>>>在Expert模式,如果方法包括参数,则当你插入方法然后按下Shift+Ctrl+Space键时,QTP会显示该方法的参数的提示信息。(注:只有在Editor Options对话框的General页签中打开了Statement completion功能时才可以看到参数的提示信息。) 51Testing软件测试网#b h\2AE6]I

51Testing软件测试网 x$\.R5UG

51Testing软件测试网 |@t Wc)}/oX[U)k

#lM;E"iK(R/`.Q05. 不能识别item(Cannot identify item) QTP不能识别方法参数中指定的列表或树对象的item时,请确认指定的item是否存在于对象之中。51Testing软件测试网[5n2{]c2d Q`

51Testing软件测试网T@ c4Qx(v

>>>如果item不存在,则删除相关脚本步骤,或修改item。51Testing软件测试网 a{$U At mYu N7f

51Testing软件测试网VO{`s

>>>如果item存在,但被测程序中它的名字发生了改变,则修改item的名称,或在脚本中使用item的index而不是名字(如“#4”)。51Testing软件测试网R"C)^|)pt'{(f

"S.EO F.}"bku0注意,不同的对象或方法,它们使用index的语法可能不同。 

3ew$_"eg$~4y0

T?0f5uI;h&d"O(y ?7_06. 对象的item不唯一(The object’s item is not unique)在列表或树对象中,可能有多个名字相同的item。

O-VS\G/\ u}0

Do3RH%w b D0在这种情况下,可以指定item使用index(例如“#4”)。 51Testing软件测试网+d4EnP1jynUJ&g

WD.[ G#QFl;S07. 运行失败(Test run failed)测试运行失败,还有可能是其它未知错误造成的。检查出现错误时的脚本步骤。51Testing软件测试网d3jc+U4A#~E

V[x$|+K6A@1i0如果错误出现在执行检查点或输出值时,请查阅关于检查点与输出值的帮助。

4g)wu1G0Q,vA^Wb&T051Testing软件测试网C0a7L3y0C8jv

如果错误出现在使用外部文件时,如数据库表、数据库、环境变量文件、或关联仓库文件等,则检查是否可以正常获取并使用文件,或这些文件的存储格式是否正确。

?R5N#r?.KDS]0

%FY k B#_ wL B0如果错误出现在完成某个脚本动作时,请参考QuickTest Object Model Reference帮助,以确认方法或函数的使用是否正确。51Testing软件测试网#Z9UP0K@

pb-QjM D0f;K0

6E;U^Pi;B)\0Y0如果错误出现在执行一个标准的VBscrīpt语句时,参考Microsoft VBscrīpt Reference以获得帮助

w\vpIA$}0

TAG:

 

评分:0

我来说两句

Open Toolbar