如何期望使用Protractor进行e2e测试中的元素动态计数

时间:2014-02-10 18:30:55

标签: javascript angularjs protractor

我目前正在为Protractor的谦逊Angular应用程序编写一些e2e测试。

我的应用程序工作正常,单元测试通过所有,e2e也使用...直到这一个:

appE2ESpec.js

describe('adding an item', function() {
  var items,
      addItemButton,
      startCount;

  beforeEach(function() {
    items = element.all(by.css('li.item'));
    addItemButton = element(by.id('addItemButton'));
    startCount = items.count();
  });

  it('should display a new item in list', function() {
    addItemButton.click();

    expect(items.count()).toEqual(startCount+1);
  });
});

这就是我写测试的方法,但

问题是: items.count()返回一个promise,我知道,但我无法强制Protractor解决它。所以我明白了:

Failures:

1) myApp adding an item should display a new item in list
  Message:
    Expected 6 to equal '[object Object]1'.

我尝试了什么:

items.count().then(function(count) {
  startCount = count;
  //console.log(startCount) --> "6" Perfect!
});

但最后得到了相同的结果......我无法将expect放入then,我也考虑过这一点。

  • 我搜索了Protractor GitHub存储库问题,StackOverflow和Google AngularJs组。

附录

console.log(startCount)输出:

{ then: [Function: then],
  cancel: [Function: cancel],
  isPending: [Function: isPending] }

我本可以编写.toEqual(6),但每次需要更改应用启动状态时,我都不想重写测试。

有什么想法吗?在此先感谢!!

2 个答案:

答案 0 :(得分:25)

您需要解决承诺,然后进行断言。

量角器将解析您传递给expect()的承诺,但它无法为承诺添加数字。您需要首先解决承诺的价值:

beforeEach(function() {
  ...
  items.count().then(function(originalCount) {
    startCount = originalCount;
  });
});

it('should display a new item in list', function() {
  ...
  expect(items.count()).toEqual(startCount+1);
});

答案 1 :(得分:2)

使用chai进行断言时,chai-as-promised允许以更易读的方式处理承诺。要使它工作,您首先需要声明:

var chai = require('chai');
var chaiAsPromised = require('chai-as-promised');
chai.use(chaiAsPromised);

然后在代码中:

// here is modified remaind of the code from the original question:
it('should display a new item in list', function() {
  addItemButton.click();

  expect(items.count()).should.eventually.equal(startCount+1);
});