私はこのコードからプロミスの配列を得ました: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);
});
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]);
}
});
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は最初に行うことであり、そのようなスクリプトの上で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);
});
});
ところで私は私の2番目のオプションはよりきれいだと思います。