热门标签 | 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




推荐阅读
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社区 版权所有