随着科技的进步,“下载-安装-运行”这经典的三步曲已离我们远去。web应用的高速发展,改变了我们的思维和生活习惯,同时也使web方面的自动化测试越来越重要。今天,介绍一下我对web对象的识别,为以后的对象库编程打下基础。

Browser

Browser对象即浏览器对象,例如IE,FF,Chrome。Browser对象是所有web对象的父级对象,是金字塔的顶端,我在Description properties中对它也没有什么约束。使用Object Spy查看Browser对象

Properties中可以看到浏览器的相关属性,因为我现在测试的系统需要测试IE6的兼容性,大家看到我的IE版本还是6-_-! Operations列出了Browser对象可以使用的方法,下面介绍几个常用的方法(先将Browser对象加入对象库)。

1.SystemUtil.Run,打开浏览器,具体使用方式可以F1查看。

2.Sync,同步方法,意思是等待浏览器完全打开再进行下一步的操作。

3.Navigate,打开URL。

4.Close,关闭浏览器。

 Systemutil.Run "iexplore.exe"
Browser("Browser").Sync
Browser("Browser").Navigate ("http://localhost/qtp/demo-login.php")
Browser("Browser").Close

tips:打开指定网址还可以用Systemutil.Run方法,上述代码可以简化为

 Systemutil.Run "iexplore.exe","http://localhost/qtp/demo-login.php"
Browser("Browser").Close

Page

Page对象一般是Browser的子对象,每一个页面就是一个Page对象,Page对象的Name值是HTML标签中Title的值。Page对象的重要方法有Exist、Sync、Childobjects等。实际工作中对Browser和Page的操作很少,大多是一些打开关闭和同步的操作。

WebEdit

网页中的输入框可以被我识别为WebEdit对象,Operations里依然有很多方法,大家可以自行查看。

 <html>
<head>
<title>web对象演示</title>
<meta http-equiv="Content-type" content="text/html" charset="utf-8">
<style>
.content{
width:260px;
height:30px;
}
.edit{
width:170px;
}
span{
width:70px;
}
</style>
</head>
<body>
<form action="" method="POST">
<div class="content">
<span>text</span><input type="text" name="web" class="edit">
</div>
<div class="content">
<span>password</span><input type="password" name="web" class="edit">
</div>
<div class="content">
<span>textarea</span><textarea rows="5" cols="20" class="edit"></textarea>
</div>
</form>
</body>
</html>

WebEdit中使用较多的set和GetROProperty方法,set用来设置输入框中的值,GetROProperty获取运行时对象的值。

Browser("web对象演示").Page("web对象演示").WebEdit("text").Set ""
Browser("web对象演示").Page("web对象演示").WebEdit("password").Set ""
Browser("web对象演示").Page("web对象演示").WebEdit("textarea").Set ""
a=Browser("web对象演示").Page("web对象演示").WebEdit("text").GetROProperty("value")
b=Browser("web对象演示").Page("web对象演示").WebEdit("password").GetROProperty("value")
c=Browser("web对象演示").Page("web对象演示").WebEdit("textarea").GetROProperty("value")
msgbox "text="+a+";password="+b+";textarea="+c

运行后输出如下

Link

顾名思义,Link是网页中的链接,我们在刚才的网页中加入如下代码

<div class="content">
<span>link</span><a href="http://www.baidu.com">点这里跳转到百度</a>
</div>

对Link对象的操作主要有Click、CheckProperty。CheckProperty方法是检查Link对象的url属性是否正确,click就是点击操作,运行下方代码,页面会自动跳转至百度。

'检查url属性是否正确
Browser("web对象演示").Page("web对象演示").Link("点这里跳转到百度")_
.CheckProperty "url","http://www.baidu.com/"
'如果正确执行Click方法
If Reporter.RunStatus=Pass Then
Browser("web对象演示").Page("web对象演示").Link("点这里跳转到百度").Click
End If

WebButton

WebButton对象就是页面中各式各样的按钮啦,主要操作就是Click:)

WebElement

WebElement主要是页面中的div,span,p等标签包涵的内容,一般用来验证数据的正确性,例如上面例子中的span标签。

If Browser("web对象演示").Page("web对象演示")_
.WebElement("password").GetROProperty("innerhtml")="password" then
msgbox "ok"
end if

WebList

我将页面中的下拉框识别为WebList对象,在我们的演示网页中加入以下代码。

 <div class="content">
<span>select</span>
<select>
<option value ="php">php</option>
<option value ="java">java</option>
<option value="vbs">vbs</option>
<option value="python">python</option>
</select>
</div>

注意Properties中的all items属性,它包括了list中的所有选项,选择WebList中的选项用的是Select方法,用法和set方法一样。

WebRadioGroup && WebCheckBox

WebRadioGroup单选框对象,WebCheckBox复选框对象,加入如下代码。

 <div class="content">
<span>radio</span>
<input type="radio" name="sex" value="boy" checked="checked">男
<input type="radio" name="sex" value="girl">女
</div>
<div class="content">
<span>checkbox</span>
<input type="checkbox" name="swim" value="swim" id="swim">游泳
<input type="checkbox" name="game" value="game" id="game">游戏
<input type="checkbox" name="read" value="read" id="read">阅读
</div>


选择单选框和复选框的代码如下

Browser("web对象演示").Page("web对象演示").WebRadioGroup("sex").Select "girl"
Browser("web对象演示").Page("web对象演示").WebCheckBox("read").Set "ON"
Browser("web对象演示").Page("web对象演示").WebCheckBox("swim").Set "ON"

WebTable

WebTable对象是网页控件中的重点与难点,在网页布局中table一般用于数据的展示,这也是我们测试的重点所在。老样子,现在网页中创建table控件,加入以下代码。

<table>
<tr><td>text1</td><td>textarea1</td><td>sex1</td><td>hobby1</td></tr>
<tr><td>text2</td><td>textarea2</td><td>sex2</td><td>hobby2</td></tr>
<tr><td>text3</td><td>textarea3</td><td>sex3</td><td>hobby3</td></tr>
</table>

并在style标签中加入

table{
border: 1px solid black;
padding:;
margin:0 auto;
border-collapse: collapse;
} td{
border: 1px solid black;
font-size:12px;
padding: 3px 3px 3px 8px;
color: black;
}

从图中可以看到,我将td中识别为WebElement对象,将td的父级元素即table识别为WebTable对象。WebTable对象的方法有很多,这里列举几个常用的方法,参考下面的代码。

 '获取列数
col=Browser("web对象演示").Page("web对象演示").WebTable("table").ColumnCount()
'获取行数
row=Browser("web对象演示").Page("web对象演示").WebTable("table").RowCount
'获取指定单元格的值
info=Browser("web对象演示").Page("web对象演示").WebTable("table").GetCellData(,)
'得到指定单元格内的测试对象的数目
Dim obj
obj=Browser("web对象演示").Page("web对象演示").WebTable("table").ChildItemCount(,,"WebEdit")
msgbox "列数="+CStr(col)+" 行数="+CStr(row)+" 第一行第一列="+info+_
"有"+CStr(obj)+"个WebEdit对象"

运行结果如下

对于WebTable对象大部分情况下使用描述性编程,至于什么是描述性编程,那又是另一个故事了。

QTP自传之web常用对象的更多相关文章

  1. QTP之web常用对象

    web对象是我做自动化以来最早学习,最早接触的.对现在而言也是最熟悉不过的了,但是为了以后更稳健的前进,对基础的东西搞扎实,相信以后的路会顺畅许多,下边简单汇总下web的常用几类对象: Browser ...

  2. JavaScript常用对象的方法和属性

    ---恢复内容开始--- 本文将简单介绍JavaScript中一些常用对象的属性和方法,以及几个有用的系统函数. 一.串方法 JavaScript有强大的串处理功能,有了这些串方法,才能编写出丰富多彩 ...

  3. dotweb框架之旅 [二] - 常用对象-App(dotweb)

    dotweb属于一个Web框架,希望通过框架行为,帮助开发人员快速构建Web应用,提升开发效率,减少不必要的代码臃肿. dotweb包含以下几个常用对象: App(dotweb) App容器,为Web ...

  4. dotweb框架之旅 [三] - 常用对象-HttpServer

    dotweb属于一个Web框架,希望通过框架行为,帮助开发人员快速构建Web应用,提升开发效率,减少不必要的代码臃肿. dotweb包含以下几个常用对象: App(dotweb) App容器,为Web ...

  5. dotweb框架之旅 [四] - 常用对象-HttpContext

    dotweb属于一个Web框架,希望通过框架行为,帮助开发人员快速构建Web应用,提升开发效率,减少不必要的代码臃肿. dotweb包含以下几个常用对象: App(dotweb) App容器,为Web ...

  6. MVC5中Model层开发数据注解 EF Code First Migrations数据库迁移 C# 常用对象的的修饰符 C# 静态构造函数 MSSQL2005数据库自动备份问题(到同一个局域网上的另一台电脑上) MVC 的HTTP请求

    MVC5中Model层开发数据注解   ASP.NET MVC5中Model层开发,使用的数据注解有三个作用: 数据映射(把Model层的类用EntityFramework映射成对应的表) 数据验证( ...

  7. Java的常用对象①②

    Java的常用对象① Java的常用对象有很多,这里只对lang包中常用的Object,Date(Calendar,DateFormat,Math),System,Runtime进行介绍.㈠Objec ...

  8. DOM_05之DOM、BOM常用对象

    1.HTML DOM常用对象之Table:①创建:createTHead():createTBody():createTFoot():②删除:deleteTHead():deleteTFoot():③ ...

  9. DOM_04之常用对象及BOM

    1.添加:①var a=document.createElement("a"):②设置关键属性:③将元素添加到DOM树:a.parent.appendChild(a):b.pare ...

随机推荐

  1. Android App优化建议(转载)

    假如要Google Play上做一个最失败的案例,那最好的秘诀就是界面奇慢无比.耗电.耗内存.接下来就会得到用户的消极评论,最后名声也就臭了.即使你的应用设计精良.创意无限也没用. 耗电或者内存占用等 ...

  2. 添加Appicon的方法

    1.将设计好的图片,拖拽到Groups&Files的Resources目录下: 2.修改Resources目录下的“工程名-info.plist”文件 3.修改该文件的Iconfile属性,填 ...

  3. [转]Delphi Form的释放和隐藏:free,hide,close

    form.Free - 释放Form占用的所有资源.Free后,Form指针不能再使用,除非对Form重新赋值. form.Hide - 隐藏Form.可以调用form.Show再一次显示. form ...

  4. Java hashCode 和 equals()

    1 Object中定义的hashCode() public int hashCode() Returns a hash code value for the object. This method i ...

  5. .net程序员必须知道的知识

    A while back, I posted a list of ASP.NET Interview Questions. Conventional wisdom was split, with ab ...

  6. pojo和JavaBean的区别

    javabean可以处理业务,pojo不可以. pojo就是get 和set 例如: Student{ id; name; get();... set();...} javabean可以实现业务逻辑 ...

  7. Html5的<button>标签

    1.标签是双标签,其内可添加文字,图片等复杂的样式. ​2.不仅可以在表单中使用,还可以在其他块元素和内联元素中使用. 3.一般在input标签内添加name属性,否则提交后不显示.

  8. php中文字符串反转

    <?php header("content-type:text/html;charset=utf-8"); /** 此函数的作用是反转中文字符串 mb_strlen() 获取 ...

  9. MySQL中删除重复数据只保留一条

    用SQL语句,删除掉重复项只保留一条 在几千条记录里,存在着些相同的记录,如何能用SQL语句,删除掉重复的呢 1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 SELECT ...

  10. JQuery select控件的相关操作

    JQuery获取和设置Select选项方法汇总如下: 获取select 先看看下面代码: $("#select_id").change(function(){//code...}) ...