练习1:Flight4a
要求:
a.录制Flight4a登录+购票+退出业务流程
b.实现登录1次,购票3次,退出1次
c.对Fly From、Fly to、航班实现随机参数化
随机参数化:RandomNumber
控件:Fly From
总数:items count
获取运行时的值:GetRoProperty("属性名")
Test13001_Flight4a_for循环购票
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 "5a653b3a0f6bbea696af1a25046189d3d3608901"
Dialog("Login").WinButton("OK").Click
wait 6
'开始购票
For i=1 to 3
Window("Flight Reservation").WinButton("Button").Click
Window("Flight Reservation").ActiveX("MaskEdBox").Type "111119"
' FromCount保存起飞城市的总数
Dim FromCount
FromCount=Window("Flight Reservation").WinComboBox("Fly From:").GetROProperty("items count")
Window("Flight Reservation").WinComboBox("Fly From:").Select RandomNumber(0,FromCount-1)
' ToCount保存到达城市的总数
Dim ToCount
ToCount=Window("Flight Reservation").WinComboBox("Fly To:").GetROProperty("items count")
Window("Flight Reservation").WinComboBox("Fly To:").Select RandomNumber(0,ToCount-1)
Window("Flight Reservation").WinButton("FLIGHT").Click
' FlyCount保存航班的总数
Dim FlyCount
FlyCount=Window("Flight Reservation").Dialog("Flights Table").WinList("From").GetROProperty("items count")
Window("Flight Reservation").Dialog("Flights Table").WinList("From").Select RandomNumber(0,FlyCount-1)
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
'结束购票
Next
Window("Flight Reservation").Close
练习2:Flight4a
要求:
a.录制Flight4a登录+购票+退出业务流程
b.对购票时输入的Tickets实现随机参数化
c.使用自定义检查点检查票数*单价=总价
reporter.ReportEvent micPass,"",""
reporter.ReportEvent micFail,"",""
Test13002_Flight4a_自定义检查票价
Option Explicit '强制检查语法
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 "5a654f4183d15630c35108a1e6230bd4bcbde035"
Dialog("Login").WinButton("OK").Click
Window("Flight Reservation").ActiveX("MaskEdBox").Type "111119"
Window("Flight Reservation").WinComboBox("Fly From:").Select "Frankfurt"
Window("Flight Reservation").WinComboBox("Fly To:").Select "Denver"
Window("Flight Reservation").WinButton("FLIGHT").Click
Window("Flight Reservation").Dialog("Flights Table").WinList("From").Select "20178 FRA 12:48 PM DEN 01:33 PM SR $162.80"
Window("Flight Reservation").Dialog("Flights Table").WinButton("OK").Click
Window("Flight Reservation").WinEdit("Name:").Set "Jack"
'1、随机生成1到10的数字,输入Tickets时使用
Dim Tickets
Tickets=Cint(RandomNumber(1,10))
'2、把代码中输入的Tickets替换为随机生成的数字
Window("Flight Reservation").WinEdit("Tickets:").Set Tickets
'3、获取Price的值 $100.10
Dim Price
Price=Window("Flight Reservation").WinEdit("Price:").GetROProperty("text")
'4、获取Total的值 $100.20
Dim Total
Total=Window("Flight Reservation").WinEdit("Total:").GetROProperty("text")
'5、 去掉$符号,转换为double子类型
Price=Cdbl(mid(Price,2))
Total=Cdbl(mid(Total,2))
'6、判断Tickets*Price=Total
If abs(Tickets*Price-Total)<0.01 Then
Reporter.ReportEvent micPass,"检查票价","票数*票价=总价,票数是:"&Tickets&",票价是:"&Price&",总价是:"&Total
else
' 给失败的界面截图
Dim pic
pic="D:\检查票价.png"
desktop.CaptureBitmap pic,True
'desktop.CaptureBitmap "路径",True
' True表示截图存在,就覆盖,False就不覆盖
Reporter.ReportEvent micFail,"检查票价","票数*票价=总价,票数是:"&Tickets&",票价是:"&Price&",总价是:"&Total,pic
End If
Window("Flight Reservation").WinButton("Insert Order").Click
Window("Flight Reservation").Close
补充:如何判断浮点数是否相等
abs(浮点数1-浮点数2)<精度
abs:取绝对值
精度:自己定义
Tickets=Cint(RandomNumber(1,10))
"票数*票价=总价,票数是:"&Tickets&",票价是:"&Price&",总价是:"&Total
Reporter.ReportEvent micPass
Reporter.ReportEvent micFail
Reporter.ReportEvent micPass,"步骤名称","成功",pic
"票数*票价=总价,票数是:"&Tickets&",票价是:"&Price&",总价是:"&Total&""
练习3:Flight4a
要求:
a.录制Flight4a登录+购票+打开订单+退出业务流程
b.把购票生成的订单号获取,打开订单时使用
c.使用自定义检查点验证打开的订单是否为购票生成的订单
Test13003_Flight4a_自定义检查打开订单
Option Explicit
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 "5a6580d62c2a67817dc9888c1e89d3529f4cf0c7"
Dialog("Login").WinButton("OK").Click
Window("Flight Reservation").ActiveX("MaskEdBox").Type "111119"
Window("Flight Reservation").WinComboBox("Fly From:").Select "Frankfurt"
Window("Flight Reservation").WinComboBox("Fly To:").Select "Paris"
Window("Flight Reservation").WinButton("FLIGHT").Click
Window("Flight Reservation").Dialog("Flights Table").WinList("From").Select "12670 FRA 09:34 AM PAR 11:29 AM AF $175.60"
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
'1、获取购票生成的订单号
Dim No
No=Window("Flight Reservation").WinEdit("Order No:").GetROProperty("text")
Window("Flight Reservation").WinButton("Button").Click
Window("Flight Reservation").Dialog("Open Order").WinCheckBox("Order No.").Set "ON"
'2、打开订单时使用购票生成的订单号
Window("Flight Reservation").Dialog("Open Order").WinEdit("Edit").Set No
Window("Flight Reservation").Dialog("Open Order").WinButton("OK").Click
'3、获取打开订单后的订单号
Dim afterNo
afterNo=Window("Flight Reservation").WinEdit("Order No:").GetROProperty("text")
'4、判断打开的订单号是否与购票生成的订单号一致
If afterNo=No Then
Reporter.ReportEvent micPass,"验证订单号","一致"
else
Dim pic
pic="D:\验证订单号.png"
desktop.CaptureBitmap pic,True
Reporter.ReportEvent micFail,"验证订单号","不一致",pic
End If
Window("Flight Reservation").Close
练习4:Flight4a
要求:
a.录制Flight4a登录+打开不存在的订单+退出业务流程
b.打开订单实现随机参数化,500-1000
c.使用自定义检查点,验证打开不存在订单时的提示信息中是否包含输入的订单号
d.使用for循环打开5次订单
Test13004_Flight4a_自定义检查提示信息
Option Explicit
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 "5a658eb213d5d0a5a9c2b75936eb475fa60b4d08"
Dialog("Login").WinButton("OK").Click
Dim i
For i=1 to 5
Window("Flight Reservation").WinButton("Button").Click
Window("Flight Reservation").Dialog("Open Order").WinCheckBox("Order No.").Set "ON"
'1、获取500-1000之间的随机数
Dim orderNo
orderNo=RandomNumber(500,1000)
'2、把打开订单输入的订单号替换为随机数
Window("Flight Reservation").Dialog("Open Order").WinEdit("Edit").Set orderNo
Window("Flight Reservation").Dialog("Open Order").WinButton("OK").Click
'3、点击OK按钮打开订单号后,获取提示信息内容
Dim info
info=Window("Flight Reservation").Dialog("Open Order").Dialog("Flight Reservations").Static("Order number 500 does not exist").GetROProperty("text")
'4、判断info是否包含orderNo
If instr(info,orderNo)<>0 Then
Reporter.ReportEvent micPass,"判断提示信息","提示信息包含订单号"
else
Reporter.ReportEvent micFail,"判断提示信息","提示信息不包含订单号"
End If
Window("Flight Reservation").Dialog("Open Order").Dialog("Flight Reservations").WinButton("确定").Click
Window("Flight Reservation").Dialog("Open Order").WinButton("Cancel").Click
Next
Window("Flight Reservation").Close
一、Exist属性)
1、Exist属性时动态属性,记录被测系统控件对象是否出现\存在于被测系统中
2、Exist属性值:
True:代表存在\出现
False:代表不存在\未出现\消失
项目老师在不在
If 项目经理.Exist Than
叫他过来
else
不叫
3、应用场景:
a.页面跳转(从A页面跳转到B页面),需要检查B页面的控件对象是否出现
b.检查某个对象控件是否出现
c.检查某个对象控件消失
练习5:Flight4a
要求:
a.录制Flight4a登录+退出业务流程
b.使用Exist属性验证登录是否成功
Test13005_Flight4a_Exist属性验证登录
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 "5a65978beafbf13bba1cf5d969e498d6e4ec59b6"
Dialog("Login").WinButton("OK").Click
'1、验证登录是否成功,
'只要Flight Reservation窗口对象存在,就表示登录成功
'如果不存在,就表示登录失败
If Window("Flight Reservation").Exist(8) Then
Reporter.ReportEvent micPass,"验证登录是否成功","成功!"
else
Reporter.ReportEvent micFail,"验证登录是否成功","失败!"
End If
Window("Flight Reservation").Close
练习6:Flight4a
要求:
a.录制Flight4a系统打开后关闭系统
b.验证登录对话框已经被关闭
Test13006_Flight4a_Exist登录消失
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").WinButton("Cancel").Click
'1、判断Login对话框不存在
If Not Dialog("Login").Exist(3) Then
msgbox "登录框不存在"
else
msgbox "登录框存在"
End If
'1+1=2
'判断1+1等于2 要判断 等于
'If 1+1=2 Then
' 等于
'else
' 不等于
'End If
'
'
'判断1+1不等3 要判断 不等于
'If 1+1 !=3 Then
' 不等于
'else
' 等于
'End If
4、Exist属性用自定义检查点中的语法:
(1)检查对象存在:
if 对象.Exist(秒数) Then
记录成功
else
记录失败
End if
(2)检查对象消失,不存在
if Not 对象.Exist(秒数) Then
记录成功
else
记录不成功
End if
5、注意:Exist属性QTP封装的每个控件对象的动态属性,可以直接使用对象.Exist获取属性的值,值是True或者False,不需要使用GetRoProperty
练习7:Flight4a系统
要求:
a.判断Flight Reservation窗口对象是否存在
如果存在就关闭
如果不存在,就判断Login对话框是否存在
如果存在,就输入用户名、密码登录系统,关闭系统
如果不存在,就打开被测系统,关闭被测系统
Window("Flight Reservation")
练习8:Flight4a
要求:
a.录制时在登录界面,不输入任何信息,点击OK按钮
b.使用自定义检查点验证提示信息框对象是否存在
c.如果b步骤的提示框对象存在,使用文本检查点检查提示框中提示的信息内容是否正确,点击确认按钮,关闭提示框,验证提示框是否消失
Test13007_Flight4a_Exist验证登录提示信息
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").WinButton("OK").Click
'1、判断Dialog("Flight Reservations")是否存在
If Dialog("Login").Dialog("Flight Reservations").Exist(3)Then
' 存在
Dialog("Login").Dialog("Flight Reservations").Static("Please enter agent name").Check CheckPoint("Please enter agent name")
Dialog("Login").Dialog("Flight Reservations").WinButton("确定").Click
' 2、判断信息提示框是否消失
If Not Dialog("Login").Dialog("Flight Reservations").Exist(3) Then
Reporter.ReportEvent micPass,"验证提示框","关闭"
else
Reporter.ReportEvent micFail,"验证提示框","未关闭"
End If
else
' 不存在
Reporter.ReportEvent micFail,"验证提示框","未打开"
End If
Dialog("Login").WinButton("Cancel").Click
浙公网安备 33010602011771号