练习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 FilesHPQuickTest Professionalsamplesflightappflight4a.exe","","C:Program FilesHPQuickTest Professionalsamplesflightapp","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 FilesHPQuickTest Professionalsamplesflightappflight4a.exe","","C:Program FilesHPQuickTest Professionalsamplesflightapp","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 FilesHPQuickTest Professionalsamplesflightappflight4a.exe","","C:Program FilesHPQuickTest Professionalsamplesflightapp","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 FilesHPQuickTest Professionalsamplesflightappflight4a.exe","","C:Program FilesHPQuickTest Professionalsamplesflightapp","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 FilesHPQuickTest Professionalsamplesflightappflight4a.exe","","C:Program FilesHPQuickTest Professionalsamplesflightapp","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 FilesHPQuickTest Professionalsamplesflightappflight4a.exe","","C:Program FilesHPQuickTest Professionalsamplesflightapp","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 FilesHPQuickTest Professionalsamplesflightappflight4a.exe","","C:Program FilesHPQuickTest Professionalsamplesflightapp","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