不是因为有些事情难以做到,我们才失去自信,而是我们失去了自信,这些事情才难以做到!

QTP-Oracle链接资料

上一篇 / 下一篇  2009-02-13 14:35:45 / 个人分类:功能测试

 

QTP连接数据库
J+L2neM0       (1)   首先要在控制面板中,加一个odbc数据源。
T3Up(rR*o0Xjp0       (2)   在qtp中建立连接和记录集51Testing软件测试网js0Sj W WF
       set cnn=createobject("adodb.connection")51Testing软件测试网l&~k4cb|
       set ōbjrsa=createobject("adodb.recordset")51Testing软件测试网7jP+z*R~#B3]^4X
       (3)   连接数据库
6ry,B)MdI!Sj0       cnn.open "provide=msdaora;userid=apts;password=apts;data source=afctwo"51Testing软件测试网"zi2T$Y?J I9]
       userid/password,是登陆数据库的用户名和密码,这样数据库就连接上。
"^s?b4NI-V0f0pl0       (4)   对数据库进行操作。
#D&^rRGu-KB0       objrsa.open "select bustypefullname from bustypeinfo",cnn,3,2
}/Y C8U1e.]EJ9r0       a=objrsa("bustypefullname").value得到字段bustypefullname的值赋值给了变量a
f+_d$vLh0       在QTP中建立一个数据库检查点
5@up E/k2SClw0       与Robot相比,QTP直接提供了对数据库中的数据进行检查的检查点,这样如果在我们的测试中需
^c r va[.o0要对后台的业务数据进行检查,只需要建立一个数据库检查点就可以了。建立数据库检查点对于一些比
?+VAz:o0较复杂的业务逻辑的测试非常重要。
7uEb,LUtT0       在QTP 8种,建立一个数据库检查点的基本步骤如下:51Testing软件测试网p {9\!A,oj2z k
       1、 从Insert菜单或工具条上选择新建一个Database Checkpoint
t:w} L8?0       2、 接下来需要为这个Database Checkpoint建立相应的Database Query,这里我们可以通过QTP
eS |*ei$^+U08提供的向导完成建立Database Query的过程。51Testing软件测试网/DlJA`$F
       在QTP 8里,我们有两种建立数据库query的选择:一种是通过Microsoft Query建立,这种方法
g/iJF:R HS0比较简单,但是需要安装Microsoft Office中的Microsoft Query;另一种方法是手动建立,如果你对在51Testing软件测试网!?0_ ?wPdT
Windows中手动建立ODBC数据源和SQL语句比较熟悉,那么可以选择这种方法。51Testing软件测试网^ S@*v0|
       使用Microsoft Query建立数据库query的画面如下图,Microsoft Query可以帮助我们建立数据
3F9x7VX F0连接,选择数据源并建立数据库的qeury:51Testing软件测试网7nT+@O2j.dw
       最后Microsoft Query会把建立好的query返回给QTP 8。51Testing软件测试网@-oX1}X&Y
       3、 在query建立好之后,QTP 8将打开Database Checkpoint的属性对话框让我们决定如何建立51Testing软件测试网-N"A%d lZ XKF
这个数据库检查点。
)Q'o'~X,t0       数据库检查点对话框上方的表格中有蓝色对号的单元格表示将会作为基准数据在执行测试时参加
f ~]'J$wZ _s0检查,我们可以选择那些单元格的数据作为我们的基准数据。而在对话框下方有三个属性页,第一个属51Testing软件测试网 co C&F,KT @,[
性页表明当前选择的基准数据是怎样配置的,可以是常数,也可以从数据表中读取,或者从被测软件的51Testing软件测试网7MiQ lT/^0}1W k
输出数据中读入。51Testing软件测试网 ei9M*J k(eD
       第二个属性页用来设置比较数据的规则。
,y5A:ZEs0       而第三个属性页用来设置在进行数据检查时怎样识别数据表的行,列以及单元格。如果我们选择
Scd!}jV2F0通过键值来定位行数据,那么被选择为主键的列标题会加上图标作为标识。51Testing软件测试网z1\(}hQ(r
       当属性设置完成以后,一个数据库检查点就建立成功了。
tt`l o9c0       4、 修改数据库检查点51Testing软件测试网c-UlEzxR%G
       如果需要对建立好的数据库检查点进行修改,可以通过选择该数据库检查点,然后选择检查点的
`({*b1z|)J|@0Object Properties,在数据库检查点的Object Properties对话框中修改连接字串或者SQL query。51Testing软件测试网F e8~7V b
       如果需要修改数据库检查点的数据或其它属性,也可以再次打开盖数据库检查点的Checkpoint
~|^+c7X;Z\dt/V0Properties对话框。51Testing软件测试网(LjP;U3c x
       QTP识别和操作对象的原理51Testing软件测试网*bT"T B1F%lS
       QTP为用户提供了两种操作对象的接口,一种就是对象的封装接口,另一种是对象的自身接口。51Testing软件测试网,`S2fOP!e
对象的自身接口是对象控件本身的接口,只要做过软件开发,使用过控件的人应该很清楚。
E(g)a0K&l5j aEw0           对象的封装接口是QTP为对象封装的另一层接口,它是QTP通过调用对象的自身接口来实现的51Testing软件测试网H![|0OAyq x
51Testing软件测试网D u|R8M;G
           两种接口的脚本书写格式的差别在于:
$n/s D6C/M0           自身接口需要在对象名后面加object再加属性名或方法名,   封装接口就不用在对象名后
u!zZPI'e1Gh0m0面加object。
Y.jT`6z3mQo0           比如操作JavaEdit对象,通过QTP封装的封装接口,脚本如下:
n kz6`+K^0           设置JavaEdit的内容:51Testing软件测试网(n?0L[aT
            JavaDialog("Add NE").JavaEdit("NE Name").Set "NE1"51Testing软件测试网wN*_|{#wB,u
           读取JavaEdit的内容:51Testing软件测试网3H(v"p$k,T
            msgbox JavaDialog("Add NE").JavaEdit("NE Name").GetROProperty("value")51Testing软件测试网h$p-Wa$f;d{B(v#a
           如果通过JavaEdit的自身接口,脚本如下:51Testing软件测试网`:c!l&cWU k
           设置JavaEdit的内容:51Testing软件测试网A*s3t]Kp2`7z
           JavaDialog("Add NE").JavaEdit("NE Name").object.setText("NE1")
(ey$X y q _:UTc0           读取JavaEdit的内容:51Testing软件测试网fOq n z N7j*bV
           Msgbox JavaDialog("Add NE").JavaEdit("NE Name").object.getText()51Testing软件测试网2k#E)P VY*s U?
           QTP执行JavaEdit().Set语句时,是通过执行JavaEdit().object.setText()来实现的。
RJ;V1y+w:Er0           QTP执行JavaEdit().GetROProperty("value"),是通过执行JavaEdit().object.getText()来51Testing软件测试网Lu+f f)Iv7Z`
实现的。
^ E"zo:at,_;P0           JavaEdit对象的封装接口Set()和GetROProperty("value"),是QTP封装JavaEdit对象的自身51Testing软件测试网ZWZ k+nJ
接口setText()和getText()而得来的。
WJj5bAk%b0           对象的封装接口是QTP使用的缺省接口,我们录制出来的脚本都是使用封装接口,大家用的51Testing软件测试网Ki?rm ry3\a x
也都是封装接口。但是封装接口不如自身接口丰富,因为QTP只是封装了部分常用的自身接口嘛。所以我51Testing软件测试网O;r^h,AN:I7`
们在需要时,可以绕过封装接口,直接调用对象的自身接口。不过有些自身接口不够稳定,在实践中偶
3{Q9u R1t1Khq0尔会出现问题,但是概率很少。封装接口有相应功能的话,就尽量用封装接口吧!
CE.|x6I l~/XI4[EC8v0           理解了封装接口和自身接口的原理,我们就可以更加灵活的操作对象了。51Testing软件测试网IAVS w1@V|
           但是我们怎么知道对象都有哪些封装接口和自身接口呢?
`%v)tM` m8`M2E0           其实很简单,用对象查看器(Object Spy)查看对象,在查看窗口里有列出这些接口,包括
D i5yVZ-F0属性和方法。
L0Z q ser6x(\0           窗口中间有选择栏让你选择Run-time Object或者Test Object,   当你选择Run-time51Testing软件测试网%J[r Rtu"W t
Object时,它显示的就是对象的自身接口(自身的属性和方法)当你选择Test Object时,它显示的就是51Testing软件测试网5c-~\k[L.Ep
对象的封装接口(封装的属性和方法)51Testing软件测试网:Y'k7AO#x s q2L
           明白了这些,你还等什么呢?快拿起对象查看器,看看对象都有哪些封装接口和自身接口,
(G"uA D0m |%]!`0肆意的操作它,玩弄它吧!51Testing软件测试网 E!f#P4B8xM%g`t
比如执行51Testing软件测试网:d\?b-jS] a/yn~
           JavaDialog("Add NE").JavaEdit("NE Name").object.setVisible(false)
4\&wX)Y;O:e'CE0            哈哈,你的JavaEdit对象就当场消失不见了!!!
.ia9xXT^0       QTP日志记录方法
7{`jQ3Y0       QTP自动化脚本执行中,QTP工程师肯定要考虑如何记录运行中的信息,什么时间执行了什么,中间
^*m NtEa1b p+M0遇到什么问题等等51Testing软件测试网7F3t#v$H;~nX
       1.通过Shell记录windows事件,在windows事件查看器中查看
DXa] ~H1q0       优点是操作方便
3]d[ N%u,W0       Set WshShell = WScripit.CreateObject("Wscrīpt.Shell")
2|(P k$L6w }4q DF1Z0       0是信息,1是错误,2是警告51Testing软件测试网J8n;i2q h/xc9JP,D
       WshShell.LogEvent 0, "Logon scrīpt Completed Successfully"
NFDK&Si y8I0       WshShell.LogEvent 1, "Logon scrīpt failed"51Testing软件测试网,~n&~8f?"W
       WshShell.LogEvent 2, "中文,且2"
V Kl \4?$?1k0       2.通过FileSystemObject来打开文件来记录
&e\AO,J+Sk,V0       优点是功能强大,想记录啥就是啥51Testing软件测试网t wo!HH Lh7fo9j
       3.利用Desktop.CaptureBitmap来记录当前Screen51Testing软件测试网u)\5F%AK^e TQ
       填写问题单时,发生错误的页面抓图很有说服力,也便于查看,当出错时调用此函数51Testing软件测试网_S3{ N{"n
       QTP专家视图51Testing软件测试网5k0vk|cJ/l%Yl
       专家视图51Testing软件测试网vXKY:~1^:zED)P#Q
       专家视图,也叫脚本视图,属于QTP中比较高级的功能选项。在该视图中,测试人员可以直接修
Rgp4iI0改测试脚本(VB脚本)的代码,来增强测试脚本的功能,它要求测试人员具有一定VB脚本语法基础。51Testing软件测试网P:K Y-y7lV2?
       当然,测试脚本中也不完全是VB脚本,严格意义上来说,QTP的测试脚本应该是标准 VB脚本和51Testing软件测试网9N+Rf-RW a
QTP测试对象的组合体。51Testing软件测试网 x3}J m.m};}'zm4Q
       所谓的QTP测试对象,就是QuickTest定义的用来表示Windows窗体元素的对象,如同窗口,命令51Testing软件测试网 Q[ f[)rGD]e*g
按钮等,每一个QTP测试对象都有若干个方法和属性,允许用户加以修改。51Testing软件测试网 PS$^-n6}O$K
       就是我们刚才录制的测试脚本的专家视图:51Testing软件测试网qN:t,C8u)o6{
       我们直接在该视图中修改和在关键字视图中修改的效果是一样的。
,LI~f{2V0       VB脚本是一种容易学习并且功能强大的脚本,它是VB的一个子集,遵循VB的语法。
-APSP)G g7Cc P8{0       如果读者原来没有接触过VB脚本的话,可以将关键字视图和专家视图中的对应项结合起来学习。51Testing软件测试网:IpXEk
       下面简单介绍一下其语法:
Lk@p4v b0       常见的对象名:51Testing软件测试网Dm8tN$wU
       Dialog:对话框,括号里面的参数表示对话框标题栏上的名字51Testing软件测试网~ J@N7l;FW$\_
       WinEdit:Windows窗体中的文本框51Testing软件测试网&X K$a5I-c [G
       WinButton: Windows窗体中的命令按钮
D(C;}6L@fR9f;L0       ActiveX: ActiveX控件51Testing软件测试网8?(Ag#J].J },FNZ3W
       WinComboBox: Windows窗体中列表框
6LQ;_ Ew~0       常见的事件名:
;J]~rUX9Ry+\I0       Set:当在文本框中输入信息时会触发该事件51Testing软件测试网.rD@{7w W7c
       Click:当点击命令按钮时会触发该事件51Testing软件测试网g__Q8~O)IC
       Select:当选择列表框或是单选按钮时会触发该事件51Testing软件测试网&zh-mCXr T
       Close:当关闭一个标准窗口或对话框时会触发该事件51Testing软件测试网C^Tw#j#R%kFE

TAG: 功能测试

 

评分:0

我来说两句

Open Toolbar