WebDriver高级应用实例(9)
9.1封装操作表格的公用类
目的:能够使自己编写操作表格的公用类,并基于公用类进行表格中的元素的各类操作
被测网页的网址的HTML代码:
<html>
<body>
<table width="400" border="1" id="table">
<tr>
<td align="left"><p>第一行第一列</p><input type="text"></input></td>
<td align="left"><p>第一行第二列</p><input type="text"></input></td>
<td align="left"><p>第一行第三列</p><input type="text"></input></td>
</tr>
<tr>
<td align="left"><p>第二行第一列</p><input type="text"></input></td>
<td align="left"><p>第二行第二列</p><input type="text"></input></td>
<td align="left"><p>第二行第三列</p><input type="text"></input></td>
</tr>
<tr>
<td align="left"><p>第三行第一列</p><input type="text"></input></td>
<td align="left"><p>第三行第二列</p><input type="text"></input></td>
<td align="left"><p>第三行第三列</p><input type="text"></input></td>
</tr>
</table>
</body>
</html>
Java语言版本的API实例代码
Table类为封装了各种表格操作方法的公用类内容如下
package cn.table; import java.util.List;
import org.openqa.selenium.By;
import org.openqa.selenium.NoSuchElementException;
import org.openqa.selenium.WebElement; public class Table {
// 声明一个WebEelment对象,用于存储页面的表格元素对象
private WebElement _table; // 为构造函数传入页面表格元素对象参数,调用table的set_table方法,将页面表格元素复制给_table
public Table(WebElement table) {
set_table(table);
}
//获取页面表格的对象方法
public WebElement get_table() {
return _table;
} public void set_table(WebElement _table) {
this._table = _table;
} // 返回表格的行数
public int getRowCount() {
List<WebElement> tableRow = _table.findElements(By.tagName("tr"));
return tableRow.size();
}
//获取表格的列数
public int getColumnCount() {
List<WebElement> tableRows = _table.findElements(By.tagName("tr"));
return tableRows.get(0).findElements(By.tagName("td")).size();
} // 获取表格中某行某列的单元格对象
public WebElement getCell(int rowNo, int colNo) {
try {
List<WebElement> tableRows = _table.findElements(By.tagName("tr"));
System.out.println("行总数:" + tableRows.size());
System.out.println("行号:" + rowNo); List<WebElement> tableColumns = tableRows.get(rowNo - 1).findElements(By.tagName("td"));
System.out.println("列总数:" + tableColumns.size());
System.out.println("列号:" + colNo); return tableColumns.get(colNo - 1);
} catch (NoSuchElementException e) {
// TODO: handle exception
throw new NoSuchElementException("没有找到相关的元素");
}
} // 获取表格中某行某列的单元格中的某个页面元素对象,by参数用于定位某个表
public WebElement getWebElementInCell(int rowNo, int colNo, By by) {
try {
List<WebElement> tableRows = _table.findElements(By.tagName("tr"));
WebElement currentRow = tableRows.get(rowNo - 1);
List<WebElement> tablecols = currentRow.findElements(By.tagName("td"));
WebElement cell = tablecols.get(colNo - 1);
return cell.findElement(by);
} catch (NoSuchElementException e) { throw new NoSuchElementException("没有找到相关的元素");
}
}
}
测试类:调用封装的Table类进行基于表格元素的各类操作
package cn.table; import org.testng.annotations.Test;
import org.testng.annotations.BeforeMethod;
import org.openqa.selenium.By;
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.testng.Assert;
import org.testng.annotations.AfterMethod; public class testTable {
WebDriver driver;
String url = "file:///E:/%E6%9D%90%E6%96%99/selenium/table.html";
@Test
public void testTableDome() {
WebElement webTable=driver.findElement(By.tagName("table"));
Table table=new Table(webTable);
WebElement cell=table.getCell(3, 2);
Assert.assertEquals(cell.getText(), "第三行第二列");
WebElement cellInut=table.getWebElementInCell(3, 2, By.tagName("input"));
cellInut.sendKeys("第三行的第二列表格被找到"); }
@BeforeMethod
public void beforeMethod() {
System.setProperty("webdriver.chrome.driver", "D:\\WebDriver\\chromedriver_win32\\chromedriver.exe");
driver = new ChromeDriver();
driver.manage().window().maximize();
driver.navigate().to(url);
} @AfterMethod
public void afterMethod() {
driver.quit();
} }
WebDriver高级应用实例(9)的更多相关文章
- WebDriver高级应用实例(10)
10.1控制HTML5语言实现的视频播放器 目的:能够获取html5语言实现的视频播放器视频文件的地址.时长.控制进行播放暂停 被测网页的网址: http://www.w3school.com.cn/ ...
- WebDriver高级应用实例(8)
8.1使用Log4j在测试过程中打印日志 目的:在测试过程中,使用Log4j打印日志,用于监控和后续调试测试脚本 被测网页的网址: http://www.baidu.com 环境准备: (1)访问ht ...
- WebDriver高级应用实例(7)
7.1在测试中断言失败的步骤进行屏幕截图 目的:在测试过程中,在断言语句执行失败时,对当前的浏览器进行截屏,并在磁盘上新建一个yyyy-mm-dd格式的目录,并在断言失败时新建一个已hh-mm-ss格 ...
- WebDriver高级应用实例(6)
6.1精确比较网页截图图片 目的:对于核心界面进行截屏,并且使用测试过程中的截图和以前测试过程中的截图进行比较.确认页面是否发生了改变 被测网页的网址: http://www.baidu.com Ja ...
- WebDriver高级应用实例(5)
5.1对象库(UI Map) 目的:能够使用配置文件存储被测试页面上的元素的定位方式和定位表达式,做到定位数据和程序的分离.方便不具备编码能力的测试人员进行修改和配置. 被测网页的网址: http:/ ...
- WebDriver高级应用实例(4)
4.1操作web页面的滚动条 被测网页的网址: http://v.sogou.com Java语言版本的API实例代码 import org.testng.annotations.Test; impo ...
- WebDriver高级应用实例(3)
3.1自动化下载某个文件 被测网页的网址: https://pypi.org/project/selenium/#files Java语言版本的API实例代码 import java.util.Has ...
- WebDriver高级应用实例(2)
2.1在日期选择器上进行日期选择 被测网页的网址: https://www.html5tricks.com/demo/Kalendae/index.html Java语言版本的API实例代码 impo ...
- WebDriver高级应用实例(1)
1.1使用JavaScriptExecutor单击元素 被测网页的网址: http://www.baidu.com Java语言版本的API实例代码 import org.testng.annotat ...
随机推荐
- 2018.11.06 bzoj1912: [Apio2010]patrol 巡逻(树形dp)
传送门 一道挺妙的题啊. 对于K==1K==1K==1的直接求树的直径. 对于K==2K==2K==2的先求一次直径,然后考虑到如果两条边加进去形成的两个环重叠就会有负的贡献. 因此把之前那条直径上的 ...
- ajax +jsp+iframe无刷新上传文件[转]
http://hi.baidu.com/zj360202/blog/item/f23e3711f929c774cb80c475.html ajax jsp 无刷新上传文件 2009-10-26 16: ...
- 计算误差函数的积分--erf(x)
注意exp(-x^2-y^2) 可以拆成exp(-x^2) * exp(-y^2) 对 dx积分时,另外一个可以当常数提出到积分号外,另外 -b到b的积分看做常数提取到积分号外
- redis 部分操作
http://pan.baidu.com/s/1eRXdbUy 下载安装地址 打开一个cmd窗口,使用cd命令切换到指定目录(D:\ruanjian\redis\64bit)运行 redis-ser ...
- 华为机试-iNOC产品部-杨辉三角的变形
题目描述 1 1 1 1 1 2 3 2 1 1 3 6 7 6 3 11 4 10 16 19 16 10 4 1以上三角形的数阵,第一行只有一个数1,以下每行的每个数,是恰好是它上面的数,左上角数 ...
- HDU 1404 Digital Deletions (暴力博弈)
题意:给定一个数字串,最长是6,然后有两种操作. 第一种是,把该串中的一个数字换成一个比该数字小的数,比如 5 可以换成 0,1,2,3,4. e.g. 12345 --> 12341 第二 ...
- 微信小程序之下拉加载和上拉刷新
微信小程序下拉加载和上拉刷新两种实现方法 方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新 首先要在json文件里设置window属性 ...
- CVO实现过程
module vid_cvo #( , , , , , )( input clk, input rst_p, :] idata, input ivalid, input vid_sop, input ...
- AngularJS实战之ng-repeat的详细用法
一.基本语法 {{$index}}:获取元素的下标. {{$first}}:判断当前元素是否是第一个元素,是则为true,否则:false: {{$last}}:判断当前元素是否是最后一个元素,是则为 ...
- HTTP文件上传服务器-支持超大文件HTTP断点续传的实现办法
最近由于笔者所在的研发集团产品需要,需要支持高性能的大文件http上传,并且要求支持http断点续传.笔者在以前的博客如何实现支持大文件的高性能HTTP文件上传服务器已经介绍了实现大文件上传的一些基本 ...