Selenium2学习-010-WebUI自动化实战实例-008-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 < gtl.getOptions().size(); 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 的您一份参考。

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

 

你可能感兴趣的:(selenium)