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. vue添加滚动事件,解决简书Carol_笑一笑方案中vue移除滚动事件失效的问题

    在写项目的时候,遇到了需要添加滚动事件的问题,在简书Carol_笑一笑这里找到了解决方案.代码如下 <script> export default { name:"vue-scr ...

  2. Chrome F12 谷歌开发者工具解析

    一.工具简单介绍 F12可用于网站界面.性能测试,bug定位等 以 www.baidu.com 为例: Elements:查看页面元素属性(多用于自动化元素定位) Console:记录日志信息(用于定 ...

  3. PJzhang:如何缓解Mimikatz从Windows2008 R2内存中读取域控密码?

    猫宁!!! 参考: https://xz.aliyun.com/t/4180 https://www.anquanke.com/post/id/156299 https://www.cnblogs.c ...

  4. 李宏毅 Tensorflow解决Fizz Buzz问题

    提出问题 一个网友的博客,记录他在一次面试时,碰到面试官要求他在白板上用TensorFlow写一个简单的网络实现异或(XOR)功能.这个本身并不难,单层感知器不能解决异或问题是学习神经网络中的一个常识 ...

  5. 【神经网络与深度学习】转-caffe安装吐血总结

    这周安装了caffe的windows版本和Linux版本,依赖关系太多,如果系统选对了,安装起来很easy,选错了,就会遇见各种坑. 1.操作系统最好使用ubuntu desktop 14.04 64 ...

  6. IDEA安装maven

    1.先到maven的官网下载安装包:http://maven.apache.org/download.cgi 解压安装包 2.配置环境变量 新建变量名MAVEN_HOME 变量值    D:\Soft ...

  7. [转帖]加强Linux服务器安全的20项建议

    加强Linux服务器安全的20项建议 2017-10-19 22:15:01作者:Linux编辑稿源:系统极客 https://ywnz.com/linuxyffq/99.html 一般情况下用 Li ...

  8. 【0.4】mysql版本特性(5.6-8.0)【转】

    转自:http://blog.itpub.net/15498/viewspace-2650661/ MySQL 5.6 1).支持GTID复制 2).支持无损复制 3).支持延迟复制 4).支持基于库 ...

  9. BigData进阶--Spark中的函数与符号

    转自:https://blog.csdn.net/YSC1123/article/details/78905090 1.Character.isDigit() 判断是否为数字 2.Character. ...

  10. PAT B1011 A+B 和 C (15)

    AC代码 #include <cstdio> int main() { int T, tcase = 1; scanf("%d", &T); for(int i ...