protractor - как получить результат массива обещаний в другой массив

17

У меня есть ряд обещаний из этого кода: element.all(by.repeater('unit in units')) , и мне действительно сложно получить данные в другом массиве:

element.all(by.repeater('unit in units')).then(function (arr) {
    var items = [];

    for (var i = 0; i < arr.length; i++) {
      arr[i].getText().then(function(text) {
        items.push(text);
      });
    }

   //PROBLEM ITEMS is Empty
   console.log(items);
});
    
задан Acosta 12.02.2014 в 19:13
источник

3 ответа

33

Удалось добиться того же результата на более простом пути, избегая использования Q и повторителя. Использование встроенной карты делает трюк.

var tabs = element.all(by.css('.unitTabs li a')).map(function (elm) {
    return elm.getText();
});

tabs.then(function (result) {
    var sorted = _.sortBy(result, function (name) { return name; });
    for (var i = 0; i < result.length; i++) {
        expect(result[i]).toBe(sorted[i]);
    }
});
    
ответ дан Acosta 13.02.2014 в 12:42
источник
7

Исправлено использование Q

var Q = require('q');

element.all(by.repeater('unit in units')).then(function (arr) {
    var promises = [];
    for (var i = 0; i < arr.length; i++) {
        promises.push(arr[i].getText());
    }

    Q.all(promises).done(function (result) {
        // print the results when the lookups and processing are done                
        console.log(result.length);
        console.log(result);                
    });
});
    
ответ дан Acosta 12.02.2014 в 19:40
источник
2

npm Q - первое, что нужно сделать, а затем используйте requirejs поверх вашего скрипта, подобного

      var Q = require('q');

      element.all(by.repeater('object in objects')).then(function (arr) {
          var promises = [];
          for (var i = 0; i < arr.length; i++) {
              promises.push(arr[i].getText());
          }

          Q.all(promises).done(function (result) {
              // print the results when the lookups and processing are done
              console.log(result.length);
              console.log(result);
          });
      });

Кстати, я думаю, что мой второй вариант чище.

    
ответ дан Acosta 14.02.2014 в 14:35
источник

Ознакомьтесь с другими вопросами по меткам