我从这段代码得到了一系列的承诺: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);
});
答案 0 :(得分: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]);
}
});
答案 1 :(得分: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);
});
});
答案 2 :(得分: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);
});
});
BTW我认为我的第二个选择是更清洁。