编程语言
首页 > 编程语言> > javascript-了解量角器和WebDriverJS控制流程

javascript-了解量角器和WebDriverJS控制流程

作者:互联网

有人可以帮助我了解WebDriverJS /量角器在这种情况下的工作方式吗?

function MyPageObject(buttonElementFinder) {
  this.getButtonByIndex = function(index) {
    return {
      myButton: buttonElementFinder.get(index)
    }
  }
}

1. describe('My button', function() {
2. 
3.   it('should contain the text foo', function() {
4.     var myElementFinder = element.all(by.css('.foo'));
5.     var pageObject = new MyPageObject(myElementFinder);
6.     var button = pageObject.getButtonByIndex(0);
7.     expect(button.text()).toBe('foo');
8.  });
9. 
10. });

由于ElementFinders的.get方法,WebDriverJS控件流是否在第6行上添加了动作?

我想期望也在第7行上也向控制流添加另一个项目吗?

编辑:我已经更新了代码以使用element.all.

解决方法:

var myElementFinder = element.all(by.css('.foo'));

myElementFinder是ElementArrayFinder,并且只是一个对象.这里没有异步发生.

var pageObject = new MyPageObject(myElementFinder);

明显.

var button = pageObject.getButtonByIndex(0);

这将从buttonElementFinder.get返回ElementFinder.这里没有异步发生.

expect(button.text()).toBe('foo');

button.text()从Webdriver.schedule返回一个承诺,而该承诺又使用了通过webdriver.promise.controlFlow()检索的控制流,该控制流公开了执行功能.

标签:selenium,protractor,javascript,webdriverjs
来源: https://codeday.me/bug/20191120/2041400.html