如何在then语句中返回一组promise

时间:2015-11-25 16:34:11

标签: javascript asynchronous promise protractor deferred

所以在过去的几个小时里,我一直在寻找异步的东西并使用promises。我正在使用测试框架量角器,还有一些我遇到麻烦的异步问题。

在这个保存功能中,我异步调用cm.org1.all(),然后使用then来获取响应。我循环响应,我需要调用响应中的每个元素调用getNewElement(),它也有一个异步调用,所以每个元素都返回一个promise。

所以我有这一系列的承诺,但我不知道如何归还它。 cm.save()的返回是[]。我需要它是['foo',foo',foo',foo']

下面的代码不起作用,但这是我到目前为止所做的。

 var cm = companyManagement() {
    //whatever is initialized below is initialized up here

    this.save = function() {
        cm.saveButton.click(); 
        var elements;
        var promises = [];
        var defer = protractor.promise.defer();
        cm.org1.all(by.repeater('brand in vm.brands'))
        .then(function(response) {
            //elements is of length 4
            elements = response;
            for(var i=0; i<elements.length;i++) {
                promises.push(getNewElement(elements, i));
            }
            //defer.fulfill(promises); not correct?
        });
        return protractor.promise.all(promises); //not correct?
    };

    function getNewElement(elements, i) {
         var defer = protractor.promise.defer();
        var alias = elements[i].element(by.binding('brand.alias'));
        alias.getText().then(function(aliasText) {
            defer.fulfill('foo');
        });
        return defer.promise;
    }
}
    cm.save()
    .then(function(response){
       console.log("my new array is",response);
    });

2 个答案:

答案 0 :(得分:2)

在测试中手动处理量角器承诺通常是一个问题过于复杂的迹象。 Protractor具有各种抽象和函数式编程工具,涵盖了大多数用例。

如果你使用转发器.column(),你可以在一行中解决它:

this.save = function() {
    cm.saveButton.click(); 
    return cm.org1.all(by.repeater('brand in vm.brands').column('brand.alias')).getText();
};
  

我会这样做,但如果列brand.alias与我拥有的某个常量匹配,我想最终能够获得元素的父级。如果我只有别名文本,我就无法得到父母,如果我错了,请纠正我。

filter()map()救援:

cm.org1.all(by.repeater('brand in vm.brands').column('brand.alias')).filter(alias) {
    return alias.getText().then(function (aliasText) {
        return aliasText === "foo";
    });
}).map(function (alias) {
    return alias.element(by.xpath("..")).getText();  // getting the parent
});

答案 1 :(得分:1)

尝试:

this.save = function() {
    cm.saveButton.click(); 
    var elements;
    var promises = [];
    var defer = protractor.promise.defer();
    return cm.org1.all(by.repeater('brand in vm.brands'))
    .then(function(response) {
        //elements is of length 4
        elements = response;
        for(var i=0; i<elements.length;i++) {
            promises.push(getNewElement(elements, i));
        }
        return protractor.promise.all(promises);
    });
};