关于QTP中的参数化

    技术2025-10-27  10

    方法一、DataTable方法

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

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

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

    Dialog("Login").WinEdit("Agent Name:").Set DataTable("UserName", dtGlobalSheet)

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

    For i=0 to DataTable.GetCurrentRow

    Dialog("Login").WinEdit("Agent Name:").Set DataTable("UserName", dtGlobalSheet)

    DataTable.SetNextRow

    Next

     

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

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

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

    首先说内部环境变量。它是QTP默认定义的一组变量,包括一些系统信息、项目信息等。目前用到最多的是TestDir,利用这个可以实现一个相对目录的目的。具体应用,在做一个数据驱动的脚本时,将数据文件放到脚本文件夹中,然后利用Environment("TestDir")+DataName导入数据文件。这样可以很方便的移植,而不需要考虑将数据文件放到具体目录下。

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

    Dialog("Login").WinEdit("Agent Name:").Set Environment("test1")

     

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

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

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

    1.      数据文件以Excel组织

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

    方式一、导入到DataTable

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

          DataStr= Environment("TestDir")&"/data.xls"

          DataTable.AddSheet("TestData")

          DataTable.ImportSheet DataStr,"Sheet1","TestData"

          '输入用户名和密码

          For i=1 to DataTable.GetSheet("TestData").GetRowCount

                 DataTable.SetCurrentRow i

                 UserName=DataTable.Value("UserName","TestData")

                 PassWord=DataTable.Value("PassWord","TestData")

                 Dialog("Login").WinEdit("Agent Name:").Set UserName

                 Dialog("Login").WinEdit("Password:").SetSecure PassWord

          Next

    方式二、利用com操纵Excel

          DataStr= Environment("TestDir")&"/data.xls"

          Set ExlObj=CreateObject("Excel.Application")

          ExlObj.Visible = True

          ExlObj.DisplayAlerts = FALSE

          Set book=ExlObj.Workbooks.Open(DataStr)

          Set sheet=book.Worksheets("Sheet1")

          For i=2 to sheet.usedrange.rows.count

                 UserName=ExlObj.WorkSheets("Sheet1").Cells(i,1)

                 PassWord=ExlObj.WorkSheets("Sheet1").Cells(i,2)

                 Dialog("Login").WinEdit("Agent Name:").Set UserName

                 Dialog("Login").WinEdit("Password:").SetSecure PassWord

          Next

          ExlObj.Quit

          Set ExlObj = nothing

     

    2.      数据文件以txt组织

    不多说,直接附上代码。

    Const ForReading=1

    TFilePath= Environment("TestDir")&"/data.txt"

    Set Fso3 = CreateObject("Scripting.FileSystemObject")

    Set DataFile= Fso3.OpenTextFile(TFilePath,ForReading,False)

    DataFile.SkipLine

    Do while DataFile.AtEndOfLine<>true

          ReadString = DataFile.ReadLine

          DataStr=split(ReadString,",")

          Dialog("Login").WinEdit("Agent Name:").Set DataStr(0)

          Dialog("Login").WinEdit("Password:").SetSecure DataStr(1)

    loop

    DataFile.close

    Set Fso3=Nothing

    3.      数据文件以数据库组织

    下面代码是用Access做的,其他类型数据库类似。不多说继续贴出代码。

    strDB="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:/Documents and Settings/zilingold/桌面/Testdata.mdb;Persist Security Info=False"

    strTableName="data"

    SetConn=createobject("adodb.connection")

    Set Rst=createobject("adodb.recordset")

    Conn.open strDB

    Rst.open "select * from "+strTableName,Conn,2,2

    Dim strTest(1)

    Rst.MoveFirst

    Do while not Rst.eof

          strTest(0)=trim(cstr(Rst.fields(0)))

          strTest(1)=trim(cstr(Rst.fields(1)))

          Dialog("Login").WinEdit("Agent Name:").Set strTest(0)

          Dialog("Login").WinEdit("Password:").SetSecure strTest(1)

          Rst.MoveNext

    Loop

    Rst.close

    SetConn=nothing

    4.      数据文件以XML组织

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

    Dim xmlDoc 'As DOMDocument需要引用xml对象

    set xmldoc=CreateObject("microsoft.xmldom")

    xmldoc.load(Environment("TestDir")&"/testdata.xml")

    Set Root=xmldoc.documentElement

    For i = 0 To Root.childNodes.Length-1

                 Set TestCases = Root.childNodes.Item(i)

                        For j = 0 To TestCases.childNodes.Length-1

                               Set TestCase = TestCases.childNodes.Item(j)

                                      If cstr(TestCase.nodeName)="UserName" Then

                                             Dialog("Login").WinEdit("Agent Name:").Set TestCase.text      

                                      end if

                                      If cstr(TestCase.nodeName)="PassWord" Then

                                             Dialog("Login").WinEdit("Password:").SetSecure TestCase.text                                                             End If                         

                        Next

          Next

    Set root=nothing

    Set xml=nothing

    <SPAN lang=EN-US style="mso-b

    最新回复(0)