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