QTP数据表参数化.docxVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

方法一、DataTable方法

这是QTP提供的一种方法,也是最容易实现参数化的一种方式。QTP针对DataTable对象提供了不少方法,可以对DataTable进行灵便的操作。DataTable分为Global和Active两种,Global所有的Action都可以用,而Active就是只能Action自己用。

通过DataTable做参数化最直接的方法就是在KeywordView视图下通过选项进行,这样即方便又减少出错的几率。单击要参数化项目的value列,选择浮现的箭头弹出ValueConfigurationOption对话框,在这里可以很方便的进行参数化。

Parameters选择数据来源类型。DataTable是从数据表中取值,Environment是从环境变量中取值,RandomNumber是选择随机值。下拉列表选择DataTable后,选择所要使用的数据表Global还是local,最后选择name,参数取自哪列,点击确定后即可完成参数化过程。

dtGlobalSheet)

这是最简单最直接的方式。用这种方式需要注意,在File---Seting---Run需要做相应设置,否则运行结果很容易出错,使实际取到的参数值和预期的不一样或者是循环不正确的错误。最好的方式是通过写语句来控制迭代过程中的取值。在脚本开辟过程中,这种方式是最常用的。类似如下代码:

Fori=0toDataTable.GetCurrentRow

dtGlobalSheet)

DataTable.SetNextRow

Next

DataTable提供了不少相关的方法和属性,具体参考匡助文档。匡助目录下的Utility.chm文档中有关于DataTable对象的详细介绍。

方法二、环境变量实现参数化

Environment对象提供对环境变量的访问。环境变量的来源有两种方式:内部环境变量和用户定义的环境变量,其中后者支持从外部导入,格式为XML文件。用环境变量做参数化有一定的局限性,因为环境变量对数据的操作没有方法一灵便,所以环境变量用的最多还是数据的共享。在此暂作为一种方式来学习,灵便运用就好。

首先说内部环境变量。它是QTP默认定义的一组变量,包括一些系统信息、项

目信息等。目前用到最多的是TestDir,利用这个可以实现一个相对目录的目的。具体应用,在做一个数据驱动的脚本时,将数据文件放到脚本文件夹中,然后利用导入数据文件。这样可以很方便的移植,而不需要考虑将数据文件放到具体目录下。

用户定义的环境变量,需要自己定义变量名和值。定义好后就可以用这些变量去参数化脚本中的常量。

这样做参数时,每一个参数值都需要指定,而且不能批量的生成。所以它有一定的应用场景:当一个Test中的不同Action需要同样一个参数,用环境变量去参数化常量是很好的一种方式;其次就是不同的Test需要用到同样的参数时,用环境变量可以很好的解决这个问题。

方法三、外部数据源实现参数化

利用外部数据驱动脚本的运行,这是时常用到的方法,这样可以很方便的组织测试数据。相对前两种方法,这种方式数据的读取、控制稍有些麻烦。下面以常见的几种方式进行说明。(以下代码并不复杂,没做注释)

1.数据文件以Excel组织

用Excel组织测试数据是最常用的了。此种驱动可以采用两种方式,将数据Import到DataTab中或者是利用com来控制Excel文件。下面给出这两种方式的示例代码。(输入flight用户名和密码)

方式一、导入到DataTable中

获得数据文件路径,并将数据文件导入到DataTable运行表中

输入用户名和密码

DataTable.SetCurrentRowi

Next

方式二、利用com控制Excel

ExlObj.Visible=True

ExlObj.DisplayAlerts=FALSE

Setbook=ExlObj.Workbooks.Open(DataStr)

Fori=2tosheet.usedrange.rows.count

4.数据文件以XML组织

XML也是会时常用到的一种方式。继续贴代码。

DimxmlDocAsDOMDocument需要引用xml对象

SetRoot=xmldoc.documentElement

Fori=0ToRoot.childNodes.Length-1

Set

文档评论(0)

188****3111 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档