WebDriver中使用JQuery选择器
作者:网络转载 发布时间:[ 2015/2/16 14:37:05 ] 推荐标签:软件测试工具 选择器
1.在已加载了JQuery的页面上可以直接使用JQuery选择器
例如www.jquery.com网站,如果我们想定位红框中导航栏中的偶数为可以使用jquery的伪选择器:even
WebDriver中使用JQuery选择器
具体实现如下
packagecom.example.tests;
importstaticorg.junit.Assert.*;
importjava.util.*;
importorg.junit.*;
importorg.openqa.selenium.*;
importorg.openqa.selenium.ie.InternetExplorerDriver;
publicclasstest{
WebDriverdriver=newInternetExplorerDriver();
JavascriptExecutorjse=(JavascriptExecutor)driver;
@Test
publicvoidjQueryTest(){
driver.get("http://www.jquery.com/");
//在executeScript中调用jQuery.find(jquerySelector);
List<WebElement>elements=
(List<WebElement>)jse.executeScript("returnjQuery.find"+"('.menu-itema:even')");
assertEquals(3,elements.size());
assertEquals("Download",elements.get(0).getText());
assertEquals("Blog",elements.get(1).getText());
assertEquals("BrowserSupport",elements.get(2).getText());
driver.close();
}
}
2.另一种情况是页面没有另载jQuery,我们需要先判断再自已手动注入,以百度为例,百度首页是没有加载的
packagecom.example.tests;
importstaticorg.junit.Assert.*;
importjava.util.*;
importorg.junit.*;
importorg.openqa.selenium.*;
importorg.openqa.selenium.ie.InternetExplorerDriver;
publicclassSelenium2{
WebDriverdriver=newInternetExplorerDriver();
JavascriptExecutorjse=(JavascriptExecutor)driver;
@Test
publicvoidjQueryTest(){
driver.get("http://www.baidu.com/");
injectjQueryIfNeeded();
List<WebElement>elements=(List<WebElement>)jse
.executeScript("returnjQuery.find('#nva')");
assertEquals(7,elements.size());//验证超链接的数量
for(inti=0;i<elements.size();i++){
System.out.print(elements.get(i).getText()+"、");
}
driver.close();
}
privatevoidinjectjQueryIfNeeded(){
if(!jQueryLoaded())
injectjQuery();
}
//判断是已加载jQuery
publicBooleanjQueryLoaded(){
Booleanloaded;
try{
loaded=(Boolean)jse.executeScript("return"+"jQuery()!=null");
}catch(WebDriverExceptione){
loaded=false;
}
returnloaded;
}
//通过注入jQuery
publicvoidinjectjQuery(){
jse.executeScript("varheadID="
+"document.getElementsByTagName("head")[0];"
+"varnewScript=document.createElement('script');"
+"newScript.type='text/javascript';"+"newScript.src="
+"'http://ajax.googleapis.com/ajax/"
+"libs/jquery/1.7.2/jquery.min.js';"
+"headID.appendChild(newScript);");
}
}
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11