我有一个表行,我想点击具有特定标签的行中的编辑按钮(测试服务器标签),
这是我的代码:
public selectOnRow( textSelector:string , clickableSelector : string , value:string) {
let promise = new Promise(resolve => {
element.all(by.css(textSelector)).each((elem, i) => {
elem.getText().then(function (text) {
if (text === value) {
resolve(i);
}
});
});
});
promise.then(i => {
element.all(by.css(clickableSelector)).get(i).click();
})
}
我称之为:
beforeAll(async () => {
page = new AppPage;
page.navigateTo('/asset/server');
page.selectOnRow('.column-label div', '.edit-action-btn', 'test server label')
baseUrl = page.baseUrl;
});
问题是它点击了正确的行但是当页面被更改时仍然selectOnRow
正在工作并且循环那些不在新页面中的行!
我收到这个错误:
失败:陈旧元素引用:元素未附加到页面 文件
答案 0 :(得分:3)
这可能很好地利用element.all
的过滤功能。当我们调用filter函数时,返回带有布尔值或承诺为布尔值的truthy的元素会被添加到ElementFinderArray
。 ElementFinderArray
也是element.all
将返回的相同类型的对象。
当文本匹配时,我们在文本匹配时设置变量索引。仅在索引为空时设置索引值。接下来我们将等待过滤功能完成。然后,我们点击clickableSelector
,其值为index
。
最后要做的是在selectOnRow上返回整个promise。所以你可以致电await selectOnRow(textSeector, clickableSelector, value);
public selectOnRow(textSelector:string, clickableSelector: string, value: string) {
let index: number;
return element.all(by.css(textSelector)).filter((elem, i) => {
return elem.getText().then(text => {
// test if index is not set
// also, if the text matches, update the index
if (!index && text === value) {
index = i;
}
return text === value;
});
}).then(() => {
// wait for the filter function to complete
// at this point, the index should be set.
return element.all(by.css(clickableSelector)).get(index).click();
});
}