调整等待事件类结构,修改元素重新拉取方法
This commit is contained in:
parent
331ec824c0
commit
730a173392
|
@ -257,6 +257,11 @@ public abstract class AbstractBy {
|
||||||
* @return {@link WebElement}类对象{@link List}集合
|
* @return {@link WebElement}类对象{@link List}集合
|
||||||
*/
|
*/
|
||||||
protected List<WebElement> recognitionElement(ElementData elementData) {
|
protected List<WebElement> recognitionElement(ElementData elementData) {
|
||||||
|
//判断是否需要自动切换窗体,若需要,则对元素窗体进行切换
|
||||||
|
if (isAutoSwitchIframe) {
|
||||||
|
autoSwitchFrame(elementData.getIframeNameList());
|
||||||
|
}
|
||||||
|
|
||||||
//获取元素的定位类型及定位内容
|
//获取元素的定位类型及定位内容
|
||||||
ArrayList<ByType> elementByTypeList = elementData.getByTypeList();
|
ArrayList<ByType> elementByTypeList = elementData.getByTypeList();
|
||||||
ArrayList<String> elementValueList = elementData.getValueList();
|
ArrayList<String> elementValueList = elementData.getValueList();
|
||||||
|
|
|
@ -40,11 +40,6 @@ public class CommonBy extends AbstractBy {
|
||||||
elementData = new ElementData(elementName, read);
|
elementData = new ElementData(elementName, read);
|
||||||
elementData.addLinkWord(linkKeys);
|
elementData.addLinkWord(linkKeys);
|
||||||
|
|
||||||
//判断是否需要自动切换窗体,若需要,则对元素窗体进行切换
|
|
||||||
if (isAutoSwitchIframe) {
|
|
||||||
autoSwitchFrame(elementData.getIframeNameList());
|
|
||||||
}
|
|
||||||
|
|
||||||
//获取元素数据在页面上对应的一组元素,若无法查到元素,则记录elementList为null
|
//获取元素数据在页面上对应的一组元素,若无法查到元素,则记录elementList为null
|
||||||
try {
|
try {
|
||||||
elementList = recognitionElement(elementData);
|
elementList = recognitionElement(elementData);
|
||||||
|
|
|
@ -1,6 +1,9 @@
|
||||||
package pres.auxiliary.work.selenium.element;
|
package pres.auxiliary.work.selenium.element;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.openqa.selenium.NoSuchElementException;
|
import org.openqa.selenium.NoSuchElementException;
|
||||||
|
import org.openqa.selenium.TimeoutException;
|
||||||
import org.openqa.selenium.WebElement;
|
import org.openqa.selenium.WebElement;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -94,11 +97,16 @@ public class Element {
|
||||||
* 重新根据元素信息,在页面查找元素
|
* 重新根据元素信息,在页面查找元素
|
||||||
*/
|
*/
|
||||||
public int againFindElement() {
|
public int againFindElement() {
|
||||||
//重新拉取元素
|
|
||||||
abstractBy.elementList = abstractBy.recognitionElement(elementData);
|
|
||||||
//切换当前读取的元素信息
|
//切换当前读取的元素信息
|
||||||
abstractBy.elementData = elementData;
|
abstractBy.elementData = elementData;
|
||||||
|
|
||||||
|
//重新拉取元素数据在页面上对应的一组元素,若无法查到元素,则记录elementList为null
|
||||||
|
try {
|
||||||
|
abstractBy.elementList = abstractBy.recognitionElement(elementData);
|
||||||
|
} catch (TimeoutException e) {
|
||||||
|
abstractBy.elementList = new ArrayList<>();
|
||||||
|
}
|
||||||
|
|
||||||
return abstractBy.elementList.size();
|
return abstractBy.elementList.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -64,11 +64,6 @@ public abstract class MultiBy<T extends MultiBy<T>> extends AbstractBy {
|
||||||
elementData = new ElementData(elementName, read);
|
elementData = new ElementData(elementName, read);
|
||||||
elementData.addLinkWord(linkKeys);
|
elementData.addLinkWord(linkKeys);
|
||||||
|
|
||||||
//判断是否需要自动切换窗体,若需要,则对元素窗体进行切换
|
|
||||||
if (isAutoSwitchIframe) {
|
|
||||||
autoSwitchFrame(elementData.getIframeNameList());
|
|
||||||
}
|
|
||||||
|
|
||||||
//获取元素数据在页面上对应的一组元素,若无法查到元素,则记录elementList为null
|
//获取元素数据在页面上对应的一组元素,若无法查到元素,则记录elementList为null
|
||||||
try {
|
try {
|
||||||
elementList = recognitionElement(elementData);
|
elementList = recognitionElement(elementData);
|
||||||
|
|
|
@ -68,7 +68,7 @@ public class WaitEvent extends AbstractEvent{
|
||||||
//调用isDisplayed()方法,判断元素是否存在
|
//调用isDisplayed()方法,判断元素是否存在
|
||||||
try {
|
try {
|
||||||
return !element.getWebElement().isDisplayed();
|
return !element.getWebElement().isDisplayed();
|
||||||
} catch (NoSuchElementException e) {
|
} catch (NoSuchElementException | TimeoutException e) {
|
||||||
//若在调用获取页面元素时抛出NoSuchElementException异常,则说明元素本身不存在,则直接返回true
|
//若在调用获取页面元素时抛出NoSuchElementException异常,则说明元素本身不存在,则直接返回true
|
||||||
return true;
|
return true;
|
||||||
} catch (StaleElementReferenceException e) {
|
} catch (StaleElementReferenceException e) {
|
||||||
|
|
Loading…
Reference in New Issue