|
QTP连接数据库
(1) 首先要在控制面板中,加一个odbc数据源。
(2) 在qtp中建立连接和记录集
set cnn=createobject("adodb.connection")
set ōbjrsa=createobject("adodb.recordset")
(3) 连接数据库
cnn.open "provide=msdaora;userid=apts;password=apts;data source=afctwo"
userid/password,是登陆数据库的用户名和密码,这样数据库就连接上。
(4) 对数据库进行操作。
objrsa.open "select bustypefullname from bustypeinfo",cnn,3,2
a=objrsa("bustypefullname").value得到字段bustypefullname的值赋值给了变量a
在QTP中建立一个数据库检查点
与Robot相比,QTP直接提供了对数据库中的数据进行检查的检查点,这样如果在我们的测试中需
要对后台的业务数据进行检查,只需要建立一个数据库检查点就可以了。建立数据库检查点对于一些比
较复杂的业务逻辑的测试非常重要。
在QTP 8种,建立一个数据库检查点的基本步骤如下:
1、 从Insert菜单或工具条上选择新建一个Database Checkpoint
2、 接下来需要为这个Database Checkpoint建立相应的Database Query,这里我们可以通过QTP
8提供的向导完成建立Database Query的过程。
在QTP 8里,我们有两种建立数据库query的选择:一种是通过Microsoft Query建立,这种方法
比较简单,但是需要安装Microsoft Office中的Microsoft Query;另一种方法是手动建立,如果你对在
Windows中手动建立ODBC数据源和SQL语句比较熟悉,那么可以选择这种方法。
使用Microsoft Query建立数据库query的画面如下图,Microsoft Query可以帮助我们建立数据
连接,选择数据源并建立数据库的qeury:
最后Microsoft Query会把建立好的query返回给QTP 8。
3、 在query建立好之后,QTP 8将打开Database Checkpoint的属性对话框让我们决定如何建立
这个数据库检查点。
数据库检查点对话框上方的表格中有蓝色对号的单元格表示将会作为基准数据在执行测试时参加
检查,我们可以选择那些单元格的数据作为我们的基准数据。而在对话框下方有三个属性页,第一个属
性页表明当前选择的基准数据是怎样配置的,可以是常数,也可以从数据表中读取,或者从被测软件的
输出数据中读入。
第二个属性页用来设置比较数据的规则。
而第三个属性页用来设置在进行数据检查时怎样识别数据表的行,列以及单元格。如果我们选择
通过键值来定位行数据,那么被选择为主键的列标题会加上图标作为标识。
当属性设置完成以后,一个数据库检查点就建立成功了。
4、 修改数据库检查点
如果需要对建立好的数据库检查点进行修改,可以通过选择该数据库检查点,然后选择检查点的
Object Properties,在数据库检查点的Object Properties对话框中修改连接字串或者SQL query。
如果需要修改数据库检查点的数据或其它属性,也可以再次打开盖数据库检查点的Checkpoint
Properties对话框。
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对象就当场消失不见了!!!
QTP日志记录方法
QTP自动化脚本执行中,QTP工程师肯定要考虑如何记录运行中的信息,什么时间执行了什么,中间
遇到什么问题等等
1.通过Shell记录windows事件,在windows事件查看器中查看
优点是操作方便
Set WshShell = WScripit.CreateObject("Wscrīpt.Shell")
0是信息,1是错误,2是警告
WshShell.LogEvent 0, "Logon scrīpt Completed Successfully"
WshShell.LogEvent 1, "Logon scrīpt failed"
WshShell.LogEvent 2, "中文,且2"
2.通过FileSystemObject来打开文件来记录
优点是功能强大,想记录啥就是啥
3.利用Desktop.CaptureBitmap来记录当前Screen
填写问题单时,发生错误的页面抓图很有说服力,也便于查看,当出错时调用此函数
QTP专家视图
专家视图
专家视图,也叫脚本视图,属于QTP中比较高级的功能选项。在该视图中,测试人员可以直接修
改测试脚本(VB脚本)的代码,来增强测试脚本的功能,它要求测试人员具有一定VB脚本语法基础。
当然,测试脚本中也不完全是VB脚本,严格意义上来说,QTP的测试脚本应该是标准 VB脚本和
QTP测试对象的组合体。
所谓的QTP测试对象,就是QuickTest定义的用来表示Windows窗体元素的对象,如同窗口,命令
按钮等,每一个QTP测试对象都有若干个方法和属性,允许用户加以修改。
就是我们刚才录制的测试脚本的专家视图:
我们直接在该视图中修改和在关键字视图中修改的效果是一样的。
VB脚本是一种容易学习并且功能强大的脚本,它是VB的一个子集,遵循VB的语法。
如果读者原来没有接触过VB脚本的话,可以将关键字视图和专家视图中的对应项结合起来学习。
下面简单介绍一下其语法:
常见的对象名:
Dialog:对话框,括号里面的参数表示对话框标题栏上的名字
WinEdit:Windows窗体中的文本框
WinButton: Windows窗体中的命令按钮
ActiveX: ActiveX控件
WinComboBox: Windows窗体中列表框
常见的事件名:
Set:当在文本框中输入信息时会触发该事件
Click:当点击命令按钮时会触发该事件
Select:当选择列表框或是单选按钮时会触发该事件
Close:当关闭一个标准窗口或对话框时会触发该事件
本文章来自中国IT实验室 |
|