热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Selenium2学习010WebUI自动化实战实例008Se

此文主要讲述用 Java 编写 Selenium 自动化测试脚本编写过程中,对下拉列表框 Select 的操作。




此文主要讲述用 Java 编写 Selenium 自动化测试脚本编写过程中,对下拉列表框 Select 的操作。





下拉列表是 Web UI 自动化测试过程中使用率非常高的,通常有两种形式的下拉列表,一种是 Select 的下拉列表,此种操作的时候比较简单,定位到元素后直接操作即可;还有的下拉列表是以多个 div + js + input 的形式实现,input 用于存储选择的项的 value 值;当然也会有其他方式实现的下拉列表。



希望能对初学 Selenium2 WebUI 自动化测试编程的亲们有所帮助。若有不足之处,敬请大神指正,不胜感激!


以下为 Selenium 操作下拉列表 Select 的 Java 自动化测试脚本实例源代码,敬请参阅!






1


package


main.aaron.demo.droplist;


2


3


import


main.aaron.sele.core.TestCase;


4


5


import


org.openqa.selenium.By;


6


import


org.openqa.selenium.WebElement;


7


import


org.openqa.selenium.support.ui.Select;


8


import


org.testng.annotations.Test;


9


10


/**


11


* Selenium 操作下拉列表实例-Select


12


*


13


*


@author


Aaron.ffp


14


*


@version


V1.0.0: autoSeleniumDemo main.aaron.demo.droplist Droplist01.java, 2015-6-16 19:03:51 Exp $


15


*/


16


public


class

Droplist01

extends


TestCase{


17


//


获取需要打开的链接的 URL 路径


18


private


final

String baseUrl =

this

.PROJECTHOME +

this

.FILESEPARATOR + "source" +

19


this

.FILESEPARATOR + "html" +

this

.FILESEPARATOR + "selectDemo.html"

;


20


21


@Test


22


public


void


testDropList(){


23


this

.webdriver.get(

this


.baseUrl);


24


25


//


获取元素-下拉列表


26

WebElement goodsTypeList =

this

.webdriver.findElement(By.id("goodsType"

));


27


28


//


将元素转换为 Select


29

Select gtl =

new


Select(goodsTypeList);


30


31


//


模拟用户点击动作展开下拉列表,也可不执行直接选择;


32


//


若是执行此步再选择下拉列表之后无其他操作时,列表会一直存在;执行其他操作时,列表收起


33


goodsTypeList.click();


34


35


//


通过列表项的 option 索引选择,也可不执行


36

gtl.selectByIndex(3

);


37


38


this

.webdriver.findElement(By.id("goods"

)).clear();


39


this

.webdriver.findElement(By.id("goods")).sendKeys(

this


.selectSelected(gtl));


40


41


/**


42


// 通过列表项的 option 的 value 值选择


43


gtl.selectByValue("3v");


44


45


// 通过列表项的 option 的 text 值选择


46


gtl.selectByVisibleText("汽车精品");


47


48


// 遍历列表项的所有可选项,并选择对应的项


49


for (int i = 0; i


50


gtl.getOptions().get(i).click();


51


}


52


53


// 遍历列表项的所有可选项,并选择对应的项


54


for (WebElement item : gtl.getOptions()) {


55


item.click();


56


}


57


*/


58


}


59

}



Selenium 操作下拉列表实例-Select 源代码

以下为上述代码中调用的方法源码






1


/**


2


* 获取 Select 已选中的项的 text 值


3


*


4


* @author Aaron.ffp


5


* @version V1.0.0: autoSeleniumDemo main.aaron.sele.core SeleniumCore.java selectSelected, 2015-6-16 19:40:02 Exp $


6


*


7


* @param select : Select 下拉列表对象


8


* @return 已选择项的 text 值


9


*/


10


public String selectSelected(Select select){


11


String text = "";


12


13

for (int i = 0; i

<


select


.getOptions().size(); i++) {


14


if (select.getOptions().get(i).isSelected()) {


15


text


= select.getOptions().get(i).getText();


16


17


return text;


18


}


19


}


20


21


return text;


22


}




selectSelected 方法

以下为 Select 下拉列表源码(selectDemo.html):






1


<


html


>


2


<


head


>


3


<


meta


charset


='utf-8'


>


4


<


title


>

下拉列表框



title


>


5




head


>


6


7


<


body


>


8


<


a


id


="goodtype"


>

商品分类:



a


>


9


<


select


id


="goodsType"


>


10


<


option


value


="0v"


>

请选择...



option


>


11


<


option


value


="1v"


>

笔记本



option


>


12


<


option


value


="2v"


>

硬件外设



option


>


13


<


option


value


="3v"


>

大家电



option


>


14


<


option


value


="4v"


>

创意小电



option


>


15


<


option


value


="5v"


>

个护电器



option


>


16


<


option


value


="6v"


>

汽车精品



option


>


17


<


option


value


="7v"


>

办公文具



option


>


18




select


>


19


20


<


input


id


="goods"


type


="text"


>


input


>


21




body


>


22




html


>




Select 下拉列表源码 selectDemo.html

  由上述源码可知,操作下拉列表-Select 时,首先要获得 Select 元素(Selenium 自动化页面操作的基础),再 new 一个 Select 对象,然后对 Select 对象进行操作,即可正确的进行下拉列表的操作,以及获取下拉列表当前已选择的项值。动手能力强的亲们,也可以自己封装一下 Selenium 对 Select 的操作几个有用方法,例如:判断 option 的 value 是否存在;判断 option 的 text 值是否存在;判断 index 值是否超出 option 的数组边界。。。等等,用于后续的 WEB UI 自动化。

  选择下拉列表项的方法有三种:(1)option 的 index,(2)option 的 value,(3)option 的 text。无论选择哪种方法,建议对三者的值进行校验判断,否则易出现元素不存在的错误,当然也可以对代码 try...catch 一下,以处理异常。

  PS:使用上述源码时,注意一下几点:

  1、替换源码中的 baseUrl 为实际路径;

  2、将 selectSelected 方法正确添加到源码,否则执行的时候会报错

  3、自行添加启动浏览器的代码

 

下拉列表框操作下期精彩: Selenium2学习-014-WebUI自动化实战实例-012-Selenium 操作下拉列表实例-div+{js|jquery}

 


至此,

WebUI 自动化功能测试脚本


第 008 篇-下拉列表框 Select 操作

顺利完结,希望此文能够给初学 Selenium 的您一份参考。


最后,非常感谢亲的驻足,希望此文能对亲有所帮助。热烈欢迎亲一起探讨,共同进步。非常感谢! ^_^

 


Selenium2学习-010-WebUI自动化实战实例-008-Selenium 操作下拉列表实例-Select




推荐阅读
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 安卓select模态框样式改变_微软Office风格的多端(Web、安卓、iOS)组件库——Fabric UI...
    介绍FabricUI是微软开源的一套Office风格的多端组件库,共有三套针对性的组件,分别适用于web、android以及iOS,Fab ... [详细]
  • 基于事件驱动的并发编程及其消息通信机制的同步与异步、阻塞与非阻塞、IO模型的分类
    本文介绍了基于事件驱动的并发编程中的消息通信机制,包括同步和异步的概念及其区别,阻塞和非阻塞的状态,以及IO模型的分类。同步阻塞IO、同步非阻塞IO、异步阻塞IO和异步非阻塞IO等不同的IO模型被详细解释。这些概念和模型对于理解并发编程中的消息通信和IO操作具有重要意义。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 测绘程序设计Excel度分秒转换模板附代码超实用版
    本文介绍了测绘程序设计Excel度分秒转换模板附代码超实用版的相关知识,包括准备工作、编写表达式和注意事项。在实际工作中,将GPS实测的经纬度度转换为度分秒是常见需求,本文提供了在Excel中快速进行转换的方法,以提高工作效率。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
author-avatar
寄到家的_259
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有