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




推荐阅读
  • CSS3 @font-face 字体应用技术解析与实践
    在Web前端开发中,HTML教程和CSS3的结合使得网页设计更加多样化。长期以来,Web设计师受限于“web-safe”字体的选择。然而,CSS3中的`@font-face`规则允许从服务器端加载自定义字体,极大地丰富了网页的视觉效果。通过这一技术,设计师可以自由选择和使用各种字体,提升用户体验和页面美观度。本文将深入解析`@font-face`的实现原理,并提供实际应用案例,帮助开发者更好地掌握这一强大工具。 ... [详细]
  • 在Java分层设计模式中,典型的三层架构(3-tier application)将业务应用细分为表现层(UI)、业务逻辑层(BLL)和数据访问层(DAL)。这种分层结构不仅有助于提高代码的可维护性和可扩展性,还能有效分离关注点,使各层职责更加明确。通过合理的设计和实现,三层架构能够显著提升系统的整体性能和稳定性。 ... [详细]
  • 如何利用Java 5 Executor框架高效构建和管理线程池
    Java 5 引入了 Executor 框架,为开发人员提供了一种高效管理和构建线程池的方法。该框架通过将任务提交与任务执行分离,简化了多线程编程的复杂性。利用 Executor 框架,开发人员可以更灵活地控制线程的创建、分配和管理,从而提高服务器端应用的性能和响应能力。此外,该框架还提供了多种线程池实现,如固定线程池、缓存线程池和单线程池,以适应不同的应用场景和需求。 ... [详细]
  • 提升 Kubernetes 集群管理效率的七大专业工具
    Kubernetes 在云原生环境中的应用日益广泛,然而集群管理的复杂性也随之增加。为了提高管理效率,本文推荐了七款专业工具,这些工具不仅能够简化日常操作,还能提升系统的稳定性和安全性。从自动化部署到监控和故障排查,这些工具覆盖了集群管理的各个方面,帮助管理员更好地应对挑战。 ... [详细]
  • 提升Android开发效率:Clean Code的最佳实践与应用
    在Android开发中,提高代码质量和开发效率是至关重要的。本文介绍了如何通过Clean Code的最佳实践来优化Android应用的开发流程。以SQLite数据库操作为例,详细探讨了如何编写高效、可维护的SQL查询语句,并将其结果封装为Java对象。通过遵循这些最佳实践,开发者可以显著提升代码的可读性和可维护性,从而加快开发速度并减少错误。 ... [详细]
  • 如何精通编程语言:全面指南与实用技巧
    如何精通编程语言:全面指南与实用技巧 ... [详细]
  • Java环境中Selenium Chrome驱动在大规模Web应用扩展时的性能限制分析 ... [详细]
  • 在本节课程中,我们将深入探讨 JSP 编程中的实际案例,通过具体代码示例 `code316.java` 来解析数据库连接的实现。该示例展示了如何使用 Java 的 JDBC API 进行数据库操作,包括加载数据库驱动、建立连接等关键步骤。通过本课程的学习,读者将能够更好地理解和应用 JSP 中的数据库连接技术。 ... [详细]
  • 本文全面解析了JavaScript中的DOM操作,并提供了详细的实践指南。DOM节点(Node)通常代表一个标签、文本或HTML属性,每个节点都具有一个nodeType属性,用于标识其类型。文章深入探讨了DOM节点的创建、查询、修改和删除等操作,结合实际案例,帮助读者更好地理解和掌握DOM编程技术。 ... [详细]
  • 在开发过程中,我最初也依赖于功能全面但操作繁琐的集成开发环境(IDE),如Borland Delphi 和 Microsoft Visual Studio。然而,随着对高效开发的追求,我逐渐转向了更加轻量级和灵活的工具组合。通过 CLIfe,我构建了一个高度定制化的开发环境,不仅提高了代码编写效率,还简化了项目管理流程。这一配置结合了多种强大的命令行工具和插件,使我在日常开发中能够更加得心应手。 ... [详细]
  • 本文深入解析了Java面向对象编程的核心概念及其应用,重点探讨了面向对象的三大特性:封装、继承和多态。封装确保了数据的安全性和代码的可维护性;继承支持代码的重用和扩展;多态则增强了程序的灵活性和可扩展性。通过具体示例,文章详细阐述了这些特性在实际开发中的应用和优势。 ... [详细]
  • Java学习第10天:深入理解Map接口及其应用 ... [详细]
  • 本文探讨了如何利用 jQuery 的 JSONP 技术实现跨域调用外部 Web 服务。通过详细解析 JSONP 的工作原理及其在 jQuery 中的应用,本文提供了实用的代码示例和最佳实践,帮助开发者解决跨域请求中的常见问题。 ... [详细]
  • 在日常的项目开发中,测试环境和生产环境通常采用HTTP协议访问服务。然而,从浏览器的角度来看,这种访问方式会被标记为不安全。为了提升安全性,当前大多数生产环境已经转向了HTTPS协议。本文将详细介绍如何在Spring Boot应用中配置SSL证书,以实现HTTPS安全访问。通过这一过程,不仅可以增强数据传输的安全性,还能提高用户对系统的信任度。 ... [详细]
  • 将JavaScript文件嵌入HTML文档是Web开发中的基本操作。常见的方法是通过在HTML文件中使用``标签来引用外部的.js文件。这种方法不仅保持了代码的整洁性,还便于管理和维护。此外,还可以利用模块化脚本和异步加载技术进一步提升页面性能。 ... [详细]
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社区 版权所有