使用量角器获取相同元素的不同值的数组

时间:2015-07-25 02:19:14

标签: javascript selenium-webdriver jasmine promise protractor

我试图使用人力车和d3测试显示图形的应用程序。使用量角器和茉莉花实现测试。作为旁注,我认为这个问题并不是特定于这个用例,而且更为通用。

因此,测试应该将鼠标悬停在图表上并收集为每个点显示的文本(example)。然后将该数组与给定数组进行匹配。

我希望这个伪代码说明问题:

var graph = ... //
var promises = [];
var promise = graphElement.getSize().then(function(size){
    _.times(size, function(i) {
        moveMouse(i, 0); // move mouse to i-th pixel
        promises.push(graph.element(by.css('.hover-text')).getText());
    });
    return promises;
});

promise.magicallyWaitForAllOfThem();

_.each(promises, function(textPromise){
    expect(textPromise).toBe('something');
});

所以,问题是因为我需要首先解析大小,所以我没有办法等待所有的promises解析并返回一个文本promise的数组,以后可以与expect()一起使用

编辑:明确提到了量角器/茉莉。

1 个答案:

答案 0 :(得分:3)

你不能简单地使用selenium webdriver' promise.all吗?

var graph = ... //
var webdriver = require("selenium-webdriver");

graphElement.getSize().then(function(size){
    var promises = [];
    _.times(size, function(i) {
        moveMouse(i, 0); // move mouse to i-th pixel
        promises.push(graph.element(by.css('.hover-text')).getText());
    });
    return webdriver.promise.all(promises);
}).then(function(promiseResultArray){
    _.each(promiseResultArray, function(textPromise){
        expect(textPromise).toBe('something');
    });
});

清洁方式:

声明:

collectHoverText: function(elem) {
  var strings = [];
  var promises = [];

  return elem.getSize().then(function(size) {
    _.times(0/*logic for number of steps*/, function(i) {
      var x = 0; // logic for step
      browser.actions().mouseMove(elem, {x: x, y: 0}).perform();
      promises.push(elem.element(by.css('.hover-text')).getText().then(function(text) {
        strings.push(text);
      }));
    });

    return protractor.promise.all(promises).then(function() {
      return _.uniq(strings);
    });
  });

并使用它:

var hoverTextPromise = collectHoverText(graph);
expect(hoverTextPromise).toContain('value'); // resolved array here