百度搜索框输入值后自动弹出的下拉框的测试(可应用到很多场景)
2013-09-01 00:46
274 查看
百度搜索框输入内容后,会匹配相关数据,弹出下拉框(共10条数据),看一下:
看一下如何测试:
import java.util.List;
import java.util.concurrent.TimeUnit;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
/*
*
* 测试百度搜索框输入某个数据之后自动弹出的下拉列表
* author:Kiven
* 部分信息参考于网络
*/
public class BaiduTable {
private WebDriver driver;
BaiduTable(WebDriver driver){
this.driver = driver;
}
public static void main(String args[]) throws InterruptedException{
WebDriver driver;
String DriverPath = "D:\\软件测试\\软件测试资料\\selenium\\chromedriver.exe";
System.setProperty("webdriver.chrome.driver",DriverPath);
driver = new ChromeDriver();
driver.get("http://www.baidu.com");
//搜索框
driver.findElement(By.id("kw")).sendKeys("test");
//等待元素出现
driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);
BaiduTable table = new BaiduTable(driver);
//table的ID
By by = By.id("st");
//String address = "2.0"; //取第三行第一列的值(该table只有一列)
//取出全部10行的数据
String address[] = {"0.0","1.0","2.0","3.0","4.0","5.0","6.0","7.0","8.0","9.0"};
for(int i=0;i<address.length;i++){
System.out.println(table.getCellText(by, address[i]));
}
driver.quit();
}
/** 从一个table的单元格中得到文本值. 参数tableCellAddress的格式为row.column, 行列从0开始.
@param by 用于得到table对象
@param tableCellAddress 一个单元格地址, 如. "1.4" 行 列
@return 从一个table的单元格中得到文本值
*/
public String getCellText(By by,String tableCellAddress){
//得到table元素对象
WebElement table = driver.findElement(by);
//对所要查找的单元格位置字符串进行分解,得到其对应行、列。
int index = tableCellAddress.trim().indexOf('.');
int row = Integer.parseInt(tableCellAddress.substring(0, index));
int cell = Integer.parseInt(tableCellAddress.substring(index+1));
//得到table表中所有行对象,并得到所要查询的行对象
List<WebElement> rows = table.findElements(By.tagName("tr"));
WebElement theRow = rows.get(row);
//调用getCell方法得到对应的列对象,然后得到要查询的文本。
String text = getCell(theRow, cell).getText();
return text;
}
private WebElement getCell(WebElement Row,int cell){
List<WebElement> cells;
WebElement target = null;
//列里面可能有"<th>"、"<td>"两种标签,所以分开处理。
if(Row.findElements(By.tagName("th")).size()>0){
cells = Row.findElements(By.tagName("th"));
target = cells.get(cell);
}
if(Row.findElements(By.tagName("td")).size()>0){
cells = Row.findElements(By.tagName("td"));
target = cells.get(cell);
}
return target;
}
}
经验证,测试通过,可看一些我的截图:
看一下如何测试:
import java.util.List;
import java.util.concurrent.TimeUnit;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
/*
*
* 测试百度搜索框输入某个数据之后自动弹出的下拉列表
* author:Kiven
* 部分信息参考于网络
*/
public class BaiduTable {
private WebDriver driver;
BaiduTable(WebDriver driver){
this.driver = driver;
}
public static void main(String args[]) throws InterruptedException{
WebDriver driver;
String DriverPath = "D:\\软件测试\\软件测试资料\\selenium\\chromedriver.exe";
System.setProperty("webdriver.chrome.driver",DriverPath);
driver = new ChromeDriver();
driver.get("http://www.baidu.com");
//搜索框
driver.findElement(By.id("kw")).sendKeys("test");
//等待元素出现
driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);
BaiduTable table = new BaiduTable(driver);
//table的ID
By by = By.id("st");
//String address = "2.0"; //取第三行第一列的值(该table只有一列)
//取出全部10行的数据
String address[] = {"0.0","1.0","2.0","3.0","4.0","5.0","6.0","7.0","8.0","9.0"};
for(int i=0;i<address.length;i++){
System.out.println(table.getCellText(by, address[i]));
}
driver.quit();
}
/** 从一个table的单元格中得到文本值. 参数tableCellAddress的格式为row.column, 行列从0开始.
@param by 用于得到table对象
@param tableCellAddress 一个单元格地址, 如. "1.4" 行 列
@return 从一个table的单元格中得到文本值
*/
public String getCellText(By by,String tableCellAddress){
//得到table元素对象
WebElement table = driver.findElement(by);
//对所要查找的单元格位置字符串进行分解,得到其对应行、列。
int index = tableCellAddress.trim().indexOf('.');
int row = Integer.parseInt(tableCellAddress.substring(0, index));
int cell = Integer.parseInt(tableCellAddress.substring(index+1));
//得到table表中所有行对象,并得到所要查询的行对象
List<WebElement> rows = table.findElements(By.tagName("tr"));
WebElement theRow = rows.get(row);
//调用getCell方法得到对应的列对象,然后得到要查询的文本。
String text = getCell(theRow, cell).getText();
return text;
}
private WebElement getCell(WebElement Row,int cell){
List<WebElement> cells;
WebElement target = null;
//列里面可能有"<th>"、"<td>"两种标签,所以分开处理。
if(Row.findElements(By.tagName("th")).size()>0){
cells = Row.findElements(By.tagName("th"));
target = cells.get(cell);
}
if(Row.findElements(By.tagName("td")).size()>0){
cells = Row.findElements(By.tagName("td"));
target = cells.get(cell);
}
return target;
}
}
经验证,测试通过,可看一些我的截图:
相关文章推荐
- WPF 之 实现TextBox输入文字后自动弹出数据(类似百度的输入框)
- AJAX基本应用之:根据输入内容自动填充下拉框
- AJAX基本应用之:根据输入内容自动填充下拉框。(ASP.NET版)[转]
- WPF实现TextBox输入文字后自动弹出数据(类似百度的输入框)
- 自定义弹出窗口,实现可输入可过滤自动选择下拉框
- AJAX基本应用之:根据输入内容自动填充下拉框。(ASP.NET版)[转]
- WPF 之 实现TextBox输入文字后自动弹出数据(类似百度的输入框)
- Jquery UI简单应用——自动完成(Autocomplete)实现类似百度输入提醒效果
- 像百度搜索框一样,在文本框中输入字符后,自动出现提示下拉框 [问题点数
- AJAX基本应用之:根据输入内容自动填充下拉框
- Excel 应用04_下拉框的自动过滤
- 考试系统——可输入并自动匹配的下拉框(一)——实现可输入并自动匹配
- EditText不自动获得输入焦点(以及 获得焦点但不弹出输入法软键盘的方法)
- Android入门教程(十二)之仿百度谷歌搜索自动提示框-----AutoCompleteTextView的应用(转)
- 实际应用场景之 - 百度
- Andoid自动判断输入是电话,网址或者Email的方法----Linkify的应用!
- android自动弹出软键盘(输入键盘)
- Mock 测试应用场景
- android自动弹出软键盘(输入键盘)
- JQuery EasyUI+Struts2自动匹配输入下拉框(combobox)