当我解决它并改变页面(量角器测试)时,保证继续工作

时间:2018-03-03 07:15:33

标签: angular typescript promise protractor e2e-testing

我有一个表行,我想点击具有特定标签的行中的编辑按钮(测试服务器标签), a row that i want to click it

这是我的代码:

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正在工作并且循环那些不在新页面中的行! 我收到这个错误:

  

失败:陈旧元素引用:元素未附加到页面   文件

1 个答案:

答案 0 :(得分:3)

ElementFinderArray过滤器功能

这可能很好地利用element.all的过滤功能。当我们调用filter函数时,返回带有布尔值或承诺为布尔值的truthy的元素会被添加到ElementFinderArrayElementFinderArray也是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();
    });
}