我想从网页中提取所有输入字段与他们的标题和元素的细节,并把它们放在一个HashMap中,以便以后在像JUnit测试WebDriver - 无法找到元素,提取网页输入字段
这是测试类中的示例代码:
accountDetails.chooseField("Date of Birth");
accountDetails.changeValueTo(dateOfBirth);
这就是网页的源文件的一部分。我试图让标签名称为“输入”的所有字段。不幸的是,同时运行测试,我发现了以下硒错误:
org.openqa.selenium.NoSuchElementException: Unable to locate element: **{"method":"tag name","selector":"input"}
<tbody>
<tr>
<tr class="subtitle">
<tr>
<tr class="subtitle">
<tr>
<tr class="subtitle">
<tr>
<tr>
<td class="caption">Staff Member</td>
<td>
<input id="StaffMember" type="text" maxlength="6" size="6" value="" name="StaffMember">
</td>
<tbody>
这就是提取类:
public class AccountDetails {
WebDriver driver;
WebElement accountDetailsTable;
WebElement radioButton;
HashMap<String, WebElement> fields = new HashMap<String, WebElement>();
WebElement addCustomerButton;
public AccountDetails(WebDriver driver) {
this.driver = driver;
driver.switchTo().defaultContent();
driver.switchTo().frame(driver.findElement(By.name("officePane")));
driver.switchTo().frame(driver.findElement(By.name("MainArea")));
accountDetailsTable = driver.findElement(By.tagName("tbody"));
addCustomerButton = accountDetailsTable.findElements(By.className("btn_def")).get(0);
List<WebElement> tr = accountDetailsTable.findElements(By.tagName("tr"));
for (WebElement el : tr) {
List<WebElement> td = el.findElements(By.tagName("td"));
if (td.size() > 0) {
fields.put(td.get(1).getText(), td.get(0).findElement(By.tagName("input")));
}
}
}
只是好奇,在webelements存储会导致staleelementexceptions。无论如何,你不需要再次找到这个元素。 – 2013-02-26 17:11:55