Test15001_两位数加法器

Option Explicit
Dim num1,num2,result,ex
'result 实际结果 = 被测系统结果输入框中的值
'ex 预期结果 = num1 + num2
num1=RandomNumber(-99,99)
num2=RandomNumber(-99,99)
VbWindow("Form1").VbEdit("Text1").Set Cstr(num1)
VbWindow("Form1").VbEdit("Text2").Set Cstr(num2)
VbWindow("Form1").VbButton("计算(J)").Click
'被测系统在执行计算后,才显示计算结果
'所以在计算步骤后,使用GetROProperty获取结果
check num1,num2
Function check(n1,n2)
ex=n1+n2
result=VbWindow("Form1").VbEdit("Text3").GetROProperty("text")
' 对比实际值与预期值是否一致
If Cint(result)=Cint(ex) Then
Reporter.ReportEvent micPass,"验证计算结果","一致!"
else
Reporter.ReportEvent micFail,"验证计算结果","不一致!"
End If
End Function VbWindow("Form1").VbButton("重置(C)").Click
VbWindow("Form1").VbButton("退出(E)").Click
VbWindow("Form1").Dialog("退出提示").WinButton("确定").Click

一、Function函数、方法
  1、无参无返回值
    Function 函数名称()
    End Function
    函数名称()

  2、有参无返回值
    Function 函数名称(参数1,参数2,......)
    End Function
    函数名称 参数1,参数2,......

  3、有参有返回值
    Function 函数名称(参数1,参数2,......)
      函数名称=返回值
    End Function
    变量=函数名称(参数1,参数2,......)

  4、无参有返回值
    Function 函数名称()
      函数名称=返回值
    End Function
    变量=函数名称()
    Test15002_无参有返回值_Function案例

'功能:计算
'参数:无
'返回值:计算结果
Function sum()
Dim num1,num2
num1=Cint(Inputbox("请输入第一个数:"))
num2=Cint(Inputbox("请输入第二个数:"))
sum=num1+num2
End Function msgbox sum()

    (1)定义:
      Function 函数名称()
        函数体
        函数名称=值
      End Function
    (2)调用:
      变量=函数名称()
      练习1:Flight4a
        要求:
          a.录制Flight4a的登录+购票+退出业务流程
          b.把代码分别封装在3个Function
            login
            buy
            logout
          c.实现代码执行登录->购票->购票->退出
          d.使用自定义检查点验证第二次购票的订单号比第一次大1
          e.使用for循环实现5次订票,验证每次订票都比上一次订票的订单号大1

            Function buy()
              buy=order No.GetROProperty("text")
            End Function

      Test15003_无参有返回值_购票

Dim first,seconde
'first 保存第一次购票返回的订单号
'seconde 保存第二次购票返回的订单号
login()
'first=buy() '第一次购票 68
'seconde=buy() '第二次购票 69 -1
'使用for循环购票5次票,调用buy() 5次
'buy()=1
'buy()=2
'buy()=3
'buy()=4
'buy()=5
'订单号(1,2,3,4,5)
Dim orderNo(4) '下标从0开始
Dim i
For i= 0 to 4
orderNo(i)=buy()
If i>0 Then '第1次返回的订单号 第2次返回的订单号
'数组前一个值 数组后一个值
If Cint(orderNo(i-1)+1)=Cint(orderNo(i)) Then
Reporter.ReportEvent micPass,"验证订单号","第二次比第一次大1"
else
Reporter.ReportEvent micFail,"验证订单号","不大1"
End If
End If
Next logout()
'If Cint(first)=Cint(seconde)-1 Then
' Reporter.ReportEvent micPass,"验证订单号","第二次比第一次大1"
'else
' Reporter.ReportEvent micFail,"验证订单号","不大1"
'End If '1、login
'功能:登录
'参数:无
'返回值:无
Function login()
SystemUtil.Run "C:\Program Files\HP\QuickTest Professional\samples\flight\app\flight4a.exe","","C:\Program Files\HP\QuickTest Professional\samples\flight\app\","open"
Dialog("Login").WinEdit("Agent Name:").Set "jack"
Dialog("Login").WinEdit("Password:").SetSecure "5a67eb6c4f97c3ac86d7559af33f4c12473bb2cc"
Dialog("Login").WinButton("OK").Click
wait 8
End Function '2、buy
'功能:购票
'参数:无
'返回值:插入订单后生成的订单号
Function buy()
Window("Flight Reservation").ActiveX("MaskEdBox").Type "111119"
Window("Flight Reservation").WinComboBox("Fly From:").Select "Frankfurt"
Window("Flight Reservation").WinComboBox("Fly To:").Select "Los Angeles"
Window("Flight Reservation").WinButton("FLIGHT").Click
Window("Flight Reservation").Dialog("Flights Table").WinButton("OK").Click
Window("Flight Reservation").WinEdit("Name:").Set "jack"
Window("Flight Reservation").WinButton("Insert Order").Click
wait 6
buy=Window("Flight Reservation").WinEdit("Order No:").GetROProperty("text") Window("Flight Reservation").WinButton("Button").Click
End Function '3、logout
'功能:退出
'参数:无
'返回值:无
Function logout()
Window("Flight Reservation").Close
End Function

      练习2:Flight4a
        要求:
          a.录制Flight4a登录+购票+退出业务流程
          b.订票输入过期的日期再选择FlyFrom,使用自定义检查点验证提示信息
          c.将自定义检查点封装在Function中,无参无返回值
          d.保证脚本每天都能运行通过,所以检查点的提示信息日期部分应该是动态
      Test15004_Function练习_验证提示信息

SystemUtil.Run "C:\Program Files\HP\QuickTest Professional\samples\flight\app\flight4a.exe","","C:\Program Files\HP\QuickTest Professional\samples\flight\app\","open"
Dialog("Login").WinEdit("Agent Name:").Set "Jack"
Dialog("Login").WinEdit("Password:").SetSecure "5a6801062077f18cc5eae0605507ee0b8497972e"
Dialog("Login").WinButton("OK").Click
Window("Flight Reservation").ActiveX("MaskEdBox").Type "111117"
Window("Flight Reservation").WinComboBox("Fly From:").Select "Denver"
checkInfo()
Window("Flight Reservation").Dialog("Flight Reservations").WinButton("确定").Click
Window("Flight Reservation").Close '功能:获取提示信息Function
'参数:无
'返回值:提示信息
Function getInfo()
'获取当前日期 01/24/18 月/日/年
'msgbox date '今天的日期
'msgbox year(date) '年
'msgbox month(date) '月
'msgbox day(date) '日
Dim y,m,d
y=year(date) '2018
m=month(date) '1
d=day(date) '24
y=mid(y,3) '18
If Cint(m)<10 Then
m="0"&m '01
End If
If Cint(d)<10 Then
d="0"&d '02
End If
' 把日期返回给Function函数getInfo
getInfo="Valid flight dates are after "&m&"/"&d&"/"&y&""
msgbox mydate
End Function '自定义检查点验证提示信息
'参数:无
'返回值:无
Function checkInfo()
Dim ac,ex
' ac:实际结果
' ex:预期结果
ex=getInfo()
ac=Window("Flight Reservation").Dialog("Flight Reservations").Static("Valid flight dates are").GetROProperty("text")
If Cstr(ac)=Cstr(ex) Then
Reporter.ReportEvent micPass,"验证日期提示信息","正确"
Else
Reporter.ReportEvent micFail,"验证日期提示信息","失败"
End If
End Function

        date

        '获取当前日期 01/24/18 月/日/年
        'msgbox date '今天的日期
        'msgbox year(date) '年
        'msgbox month(date) '月
        'msgbox day(date) '日
        Dim y,m,d
        y=year(date) '2018
        m=month(date) '1
        d=day(date) '24
        y=mid(y,3) '18
        If Cint(m)<10 Then
          m="0"&m '01
        End If
        If Cint(d)<10 Then
          d="0"&d '02
        End If
        mydate=""&m&"/"&d&"/"&y&""
        msgbox mydate

  5、变量的作用域
    主代码
    Function 1()
      a
    End Function
    Function 2(m)
      b
    End Function
    (1)在Function的函数体内定义的变量,作用域就在该Function内部,其他Function或主代码无此变量,不能使用
    (2)Function的形参变量作用域就在该Function内部,在其他Function或主代码都无此变量,不能使用
    (3)在Action内部主代码中定义的变量,作用域在该Action内部,包括Action内的所有Function都可以使用,在其他Action中无此变量,不能使用

  6、Action间的传参
    Action:购票生成订单号
    Action:打开订单需要订单号
    (1)通过DataTable传参
      a.在前一个Action中向DataTable表写入数据
        语法:DataTable("列名","表名")=值
      b.在后一个Action中读取DataTable表的数据
        语法:变量=DataTable("列名","表名")

    (2)通过环境变量传参
      a.在前一个Action中向环境变量写入数据
        语法:Environment("参数名")=值
      b.在后一个Action中读取环境变量中的数据
        语法:变量=Environment("参数名")

    (3)使用Action传参
      Action1 ->属性->Parameter->out
      Parameter("out")="mercury"
      Action2->属性->Parameter->in
      ->Call Properties->Parameter->in=out
      msgbox Parameter("in")

      a.在第一个Action为Parameter变量赋值
        语法:Parameter("变量")=值
      b.在第二个Action读取Parameter的值
        语法:变量=Parameter("变量名")

      练习3:Flight4a
        要求:

          a.录制Flight4a登录+购票+打开订单+退出业务流程
          b.分别使用3种传参的方式,实现打开订单时使用购票生成的订单号
      Test15005_Flight4a_Action传参订单号

登录Action()
SystemUtil.Run "C:\Program Files\HP\QuickTest Professional\samples\flight\app\flight4a.exe","","C:\Program Files\HP\QuickTest Professional\samples\flight\app\","open"
Dialog("Login").WinEdit("Agent Name:").Set "jack"
Dialog("Login").WinEdit("Password:").SetSecure "5a6836099d2780743417f9b7340f765e2c108fb1"
Dialog("Login").WinButton("OK").Click
wait 6 购票Action()
Window("Flight Reservation").ActiveX("MaskEdBox").Click 0,5
Window("Flight Reservation").ActiveX("MaskEdBox").Type "111119"
Window("Flight Reservation").WinComboBox("Fly From:").Select "Denver"
Window("Flight Reservation").WinComboBox("Fly To:").Select "London"
Window("Flight Reservation").WinButton("FLIGHT").Click
Window("Flight Reservation").Dialog("Flights Table").WinList("From").Select "20264 DEN 12:12 AM LON 07:23 PM AA $112.20"
Window("Flight Reservation").Dialog("Flights Table").WinButton("OK").Click
Window("Flight Reservation").WinEdit("Name:").Set "jack"
Window("Flight Reservation").WinButton("Insert Order").Click
wait 6
Dim orderNo
'获取订票后生成的订单号
orderNo=Window("Flight Reservation").WinEdit("Order No:").GetROProperty("text")
''1、DataTable传参
'DataTable("订单号","购票")=orderNo
''2、Environment传参
'Environment("No")=orderNo
'3、Parameter传参
Parameter("out")=orderNo 打开订单Action()
Window("Flight Reservation").WinButton("Button").Click
Window("Flight Reservation").Dialog("Open Order").WinCheckBox("Order No.").Set "ON"
Window("Flight Reservation").Dialog("Open Order").WinEdit("Edit").Set Parameter("in")'Environment("No")'DataTable("订单号","购票")
Window("Flight Reservation").Dialog("Open Order").WinButton("OK").Click 退出Action()
Window("Flight Reservation").Close

二、DataTable表高级使用
  Test15006_两位数加法器_ImportSheet

'DataTable.ImportSheet "文件名称","文件中的sheet名称","DataTable表单名称"
DataTable.ImportSheet "C:\data.xls","计算","Action1" SystemUtil.Run "D:\两位数加法器V2.exe","","D:\","open"
VbWindow("Form1").VbEdit("Text1").Set DataTable("num1","Action1")
VbWindow("Form1").VbEdit("Text2").Set DataTable("num2","Action1")
VbWindow("Form1").VbButton("计算(J)").Click
'获取当前DataTable运行行,也就是当前读取DataTable
'的那行数据
Dim row
'表 获取当前行
row=DataTable.GetSheet("Action1").GetCurrentRow
desktop.CaptureBitmap "D:\计算结果"&row&".png",True
VbWindow("Form1").VbButton("重置(C)").Click
VbWindow("Form1").VbButton("退出(E)").Click
VbWindow("Form1").Dialog("退出提示").WinButton("确定").Click

  1、DataTable表的ImportSheet方法
    (1)作用:导入Excel指定表单中的数据,只在运行时导入
    (2)语法:DataTable.ImportSheet "文件名.xls","Excel表单名","DataTable表单名"
      如:把C盘下data.xls中的计算sheet页导入到DataTable的Action1表单中
        DataTable.ImportSheet "C:\data.xls","计算","Action1"
    (3)注意:
      a.QTP10.0只支持.xls后缀的文件
      b.在Excel中准备数据时,第一行将作为DataTable中的列名
      c.运行代码时一定要关闭Excel文档
      d.Excel的单元格不能合并
      e.只有运行时才会导入数据,运行后在Runtime DataTable中可以查看

  2、GetCurrentRow方法
    Get:获取
    Current:当前
    Row:行
    desktop.CaptureBatimap "D:\结果3.png",True
    1
    2
    3
    (1)作用:获取当前读取DataTable表中数据的行号
    (2)语法:变量=DataTable.GetSheet("表单名").GetCurrentRow
    (3)返回值:当前行号,迭代行的行号

  3、SetCurrentRow方法
    Test15007_Flight4a_SetCurrentRow

For i=5 to 10
Window("Flight Reservation").WinButton("Button").Click
Window("Flight Reservation").Dialog("Open Order").WinCheckBox("Order No.").Set "ON"
Window("Flight Reservation").Dialog("Open Order").WinEdit("Edit").Set Cstr(i)
Window("Flight Reservation").Dialog("Open Order").WinButton("OK").Click
' 设置当前行,运行第一次把数据输出到第1行,以此类推
DataTable.GetSheet("Action1").SetCurrentRow i
Window("Flight Reservation").WinEdit("Name:").Output CheckPoint("Name:")
Next

    (1)作用:设定指定表单的当前操作行为指定行
    (2)语法:DataTable.GetSheet("表单名").SetCurrentRow 行号
    (3)参数:Integer,只能是数字
    (4)返回值:无

    练习4:Flight4a
      要求:录制Flight4a登录+购票+退出业务流程
        a.使用For循环实现购票3次
        b.为订票日期、起飞城市、到达城市实现参数化,参数来自city.xls文档
        c.使用输出值输出购票后的订单号
        d.为每次购票后的界面进行截图,要求不能覆盖
    Test1508_Flight4a_DataTable高级使用

'导入city.xls Excel表中data表单的数据到Action1中
DataTable.ImportSheet "C:\city.xls","data","Action1" SystemUtil.Run "C:\Program Files\HP\QuickTest Professional\samples\flight\app\flight4a.exe","","C:\Program Files\HP\QuickTest Professional\samples\flight\app\","open"
Dialog("Login").WinEdit("Agent Name:").Set "jack"
Dialog("Login").WinEdit("Password:").SetSecure "5a68540da623868b5a48ca453f037e8a1d2ef4e6"
Dialog("Login").WinButton("OK").Click
wait 6
'循环购票3次
For i=1 to 3
Window("Flight Reservation").ActiveX("MaskEdBox").Type DataTable("订票日期","Action1")
Window("Flight Reservation").WinComboBox("Fly From:").Select DataTable("起飞城市","Action1")
Window("Flight Reservation").WinComboBox("Fly To:").Select DataTable("到达城市","Action1")
Window("Flight Reservation").WinButton("FLIGHT").Click
Window("Flight Reservation").Dialog("Flights Table").WinButton("OK").Click
Window("Flight Reservation").WinEdit("Name:").Set "jack"
Window("Flight Reservation").WinButton("Insert Order").Click
wait 8
'设置DataTable的当前行,让每次输出的订单号
' 保存到不同的行里
DataTable.GetSheet("Action1").SetCurrentRow i
Window("Flight Reservation").WinEdit("Order No:").Output CheckPoint("Order No:")
'把购票成功的界面进行截图
Dim row
row=DataTable.GetSheet("Action1").GetCurrentRow
desktop.CaptureBitmap "D:\购票成功"&row&".png",True
Window("Flight Reservation").WinButton("Button").Click
Next Window("Flight Reservation").Close

QTP(15)的更多相关文章

  1. 理解 neutron(15):Neutron linux-bridge-agent 创建 linux bridge 的简要过程

    学习 Neutron 系列文章: (1)Neutron 所实现的虚拟化网络 (2)Neutron OpenvSwitch + VLAN 虚拟网络 (3)Neutron OpenvSwitch + GR ...

  2. Web 在线文件管理器学习笔记与总结(15)剪切文件夹 (16)删除文件夹

    (15)剪切文件夹 ① 通过rename($oldname,$newname) 函数实现剪切文件夹的操作 ② 需要检测目标文件夹是否存在,如果存在还要检测目标目录中是否存在同名文件夹,如果不存在则剪切 ...

  3. Maven学习系列二(1-5)

    Maven学习系列二(1-5) 本文转自 QuantSeven 博客,讲解精炼易懂,适合入门,链接及截图如下 http://www.cnblogs.com/quanyongan/category/47 ...

  4. C语言的本质(15)——C语言的函数接口入门

    C语言的本质(15)--C语言的函数接口 函数的调用者和其实现者之间存在一个协议,在调用函数之前,调用者要为实现者提供某些条件,在函数返回时,实现者完成调用者需要的功能. 函数接口通过函数名,参数和返 ...

  5. Windows Phone开发(15):资源

    原文:Windows Phone开发(15):资源 活字印刷术是我国"四大发明"之一,毕昇在发明活字印刷术之后,他很快发现一个问题,随着要印刷资料的不断增加,要用到的汉字数目越来越 ...

  6. Android菜鸟的成长笔记(15)—— Android中的状态保存探究(下)

    原文:Android菜鸟的成长笔记(15)-- Android中的状态保存探究(下) 在上一篇中我们简单了解关于Android中状态保存的过程和原理,这一篇中我们来看一下在系统配置改变的情况下保存数据 ...

  7. MEF框架在Silverlight中应用(15)

    原文:MEF框架在Silverlight中应用(15) MEF框架在Silverlight中应用 代码下载 MEF框架是微软提供的一个插件框架.应用概括为一句话:输入,输出,组合.下面是具体在Silv ...

  8. redis入门(15)redis的数据备份和恢复

    redis入门(15)redis的数据备份和恢复

  9. 理解 neutron(15):Neutron Linux Bridge + VLAN/VXLAN 虚拟网络

    学习 Neutron 系列文章: (1)Neutron 所实现的虚拟化网络 (2)Neutron OpenvSwitch + VLAN 虚拟网络 (3)Neutron OpenvSwitch + GR ...

随机推荐

  1. STS中MyBatis的基本实现

    本文采用的是<深浅spring boot 2.x>中第5章的例子,用一个接口实现对一个表项的读取. 数据库:mysql下建立user数据库,表名为t_usr 1. 数据源设置 在appli ...

  2. 什么是MapReduce?

    [学习笔记] 什么是MapReduce?马 克-to-win @ 马克java社区:1)MapReduce是面向大数据并行程序设计的模型和方法,这一点很像我们前面讲的MVC,MVC解决动态网站问题而 ...

  3. hydra 使用

    Hydra介绍 Hydra是一个并行登录破解器,支持多种攻击协议.它非常快速和灵活,新模块易于添加.该工具使研究人员和安全顾问能够展示远程获得对系统未经授权的访问是多么容易. 它支持:Cisco AA ...

  4. 常用小技巧之PyCharm IDE

    Pycharm控制台窗口怎样可以显示不同程序的运行结果 默认情况下,每次运行会把之前的那个结果给清理掉. 有时候运行多个程序像对比结果,不太方便. 可以在pycharm的控制台那里点击右键,在弹出的菜 ...

  5. 截取铃声python代码

    from pydub import AudioSegment file_name = "张杰 - 这就是爱.mp3" sound = AudioSegment.from_mp3(f ...

  6. Consecutive Numbers Sum

    Given a positive integer N, how many ways can we write it as a sum of consecutive positive integers? ...

  7. 小记--------spark的两种提交模式

    spark的两种提交模式:yarn-cluster . yarn-client 图解

  8. 斜率优化DP(转载)

    转载自:https://www.cnblogs.com/ka200812/archive/2012/08/03/2621345.html 我们知道,有些DP方程可以转化成DP[i]=f[j]+x[i] ...

  9. Tensorflow安装错误Cannot uninstall wrapt

    解决办法:安装之前先执行:pip install wrapt --ignore-installed

  10. 并不对劲的CF1237D&E:Balanced Playlist and Binary Search Trees

    CF1237D Balanced Playlist 题意 有一个长度为\(n\)(\(n\leq 10^5\))的循环播放歌单,每首歌有一个优秀值\(a_i\)(\(a_i\leq 10^9\)). ...