我从这段代码中得到了一系列承诺: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);
});
发布于 2014-02-13 19:42:04
设法以一种更简单的方式获得相同的结果,避免使用Q和中继器。使用内置的map可以做到这一点。
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]);
}
});
发布于 2014-02-13 02:40:40
已使用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);
});
});
发布于 2014-02-14 21:35:06
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);
});
});
顺便说一句,我想我的第二个选择是更干净。
https://stackoverflow.com/questions/21736191
复制相似问题