web-dev-qa-db-fra.com

rapporteur - comment obtenir le résultat d'un tableau de promesses dans un autre tableau

J'ai reçu un tableau de promesses de ce code: element.all(by.repeater('unit in units')), et je trouve qu'il est vraiment difficile de placer les données dans un autre tableau:

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);
});
17
Acosta

Géré pour obtenir le même résultat d'une manière plus simple en évitant d'utiliser Q et le répéteur. L'utilisation de la carte intégrée fait l'affaire.

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]);
    }
});
33
Acosta

Correction à l'aide de 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);                
    });
});
8
Acosta

npm Q est la première chose à faire, puis utilisez requirejs au-dessus de votre script comme ça

      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);
          });
      });

BTW Je pense que ma deuxième option est plus propre.

2
Acosta