修改列表元素断言机制,添加元素重新获取方法

This commit is contained in:
彭宇琦 2020-12-05 10:56:22 +08:00
parent fd9fd6c369
commit 40ad893020
1 changed files with 29 additions and 7 deletions

View File

@ -359,11 +359,8 @@ public final class DataTableEvent extends AbstractEvent {
//根据下标获取元素并进行存储 //根据下标获取元素并进行存储
ArrayList<Element> elementList = new ArrayList<>(); ArrayList<Element> elementList = new ArrayList<>();
tableMap.forEach((key, value) -> { tableMap.forEach((key, value) -> {
//重新获取元素
Element element = value.get(toElementIndex(listSize(key), rowIndex));
element.againFindElement();
//存储元素 //存储元素
elementList.add(element); elementList.add(value.get(toElementIndex(listSize(key), rowIndex)));
}); });
return elementList; return elementList;
@ -411,13 +408,16 @@ public final class DataTableEvent extends AbstractEvent {
//获取第一行元素并将其转换为文本后存储 //获取第一行元素并将其转换为文本后存储
getRowElement(1).stream().map(textEvent :: getText).forEach(oldTextList :: add); getRowElement(1).stream().map(textEvent :: getText).forEach(oldTextList :: add);
} }
//获取当前集合的长度
int oldListSize = listSize();
//执行操作并获取操作的返回结果若返回值为true则需要进行元素断言操作 //执行操作并获取操作的返回结果若返回值为true则需要进行元素断言操作
if (action.getAsBoolean()) { if (action.getAsBoolean()) {
//若当前未获取原元素的内容则不进行列表断言 //若当前未获取原元素的内容则不进行列表断言
if (oldTextList.size() != 0) { if (oldTextList.size() != 0) {
//断言元素并返回结果 //断言元素并返回结果
return assertDataChange(oldTextList); return assertDataChange(oldTextList, oldListSize);
} else { } else {
return true; return true;
} }
@ -432,10 +432,18 @@ public final class DataTableEvent extends AbstractEvent {
* @param oldElement 原始数据第一个元素的{@link WebElement}对象 * @param oldElement 原始数据第一个元素的{@link WebElement}对象
* @return 元素是否存在改变 * @return 元素是否存在改变
*/ */
protected boolean assertDataChange(ArrayList<String> oldTextList) { protected boolean assertDataChange(ArrayList<String> oldTextList, int oldListSize) {
//重新获取集合元素
againFindDataList();
//获取操作后的第一行元素 //获取操作后的第一行元素
ArrayList<Element> newElementList = getRowElement(1); ArrayList<Element> newElementList = getRowElement(1);
//若集合的长度发生改变则表示集合存在变化
if (oldListSize != listSize) {
return true;
}
//为避免不进行翻页时列表也会进行一次刷新则获取信息对每个文本数据进行比对 //为避免不进行翻页时列表也会进行一次刷新则获取信息对每个文本数据进行比对
for (int index = 0; index < oldTextList.size(); index++) { for (int index = 0; index < oldTextList.size(); index++) {
if (assertEvent.assertNotEqualsText(newElementList.get(index), oldTextList.get(index))) { if (assertEvent.assertNotEqualsText(newElementList.get(index), oldTextList.get(index))) {
@ -446,14 +454,21 @@ public final class DataTableEvent extends AbstractEvent {
return false; return false;
} }
/**
* 用于重新获取元素信息
*/
private void againFindDataList() { private void againFindDataList() {
//用于判断当前数列元素的个数 //用于判断当前数列元素的个数
AtomicInteger nowListSize = new AtomicInteger(-1); AtomicInteger nowListSize = new AtomicInteger(-1);
tableMap.forEach((key, value) -> { tableMap.forEach((key, value) -> {
//获取原集合个数
int oldSize = value.size();
//对列表第一个元素进行重新获取 //对列表第一个元素进行重新获取
Element element = value.get(0); Element element = value.get(0);
//重新获取当前元素并存储当前列表长度 //重新获取当前元素并存储当前列表长度
int elementListSize = element.againFindElement(); int elementListSize = element.againFindElement();
//判断当前size是否为初始化的状态若为初始化的状态则直接存储重新获取后的集合元素个数 //判断当前size是否为初始化的状态若为初始化的状态则直接存储重新获取后的集合元素个数
if (nowListSize.get() == -1) { if (nowListSize.get() == -1) {
nowListSize.set(elementListSize); nowListSize.set(elementListSize);
@ -473,7 +488,14 @@ public final class DataTableEvent extends AbstractEvent {
} }
//判断当前元素个数与重新获取前元素个数是否一致不一致则需要对数组进行处理 //判断当前元素个数与重新获取前元素个数是否一致不一致则需要对数组进行处理
int nowSize = nowListSize.get();
if (nowSize != oldSize) {
//根据元素返回的元素查找对象强转为DataListBy后再重新获取所有元素
value = ((DataListBy) (element.getBy())).getAllElement();
//根据是否进行严格检查来对listSize进行赋值若无需严格检查则取两者之间最小者
listSize = isExamine ? nowSize : Math.min(nowSize, listSize);
}
}); });
} }