量角器端到端测试中的异步执行

asynchronous execution in protractor end to end tests

我写了一个函数,它返回一个值。在我的主要我调用函数是这样的:

var fn_return_val = lesson.select_lesson(lesson1_text);  
console.log("returned value is : " + fn_return_val);

我的函数实现就像(other file.js) :

module.exports = {
 select_lesson:
    function select_lesson(lesson_name) {

        console.log('\n ************************* Lessson name: ' + lesson_name);
        var desiredOption, status;
        var repeter = element.all(by.repeater('item in items'));

        repeter.then(function (items) {
            items.forEach(function (icon) {
                console.log('\n ************************* item');
                icon.getText().then(function (txt) {
                    if (txt == lesson_name) {
                        desiredOption = icon;
                    }
                })
            }).then(function clickOption() {
                if (desiredOption) {
                    var el = desiredOption.all(by.css('[ng-click="launchActivity()"]'));
                    var el_progress = desiredOption.all(by.css('.pna-progress'));
                    var abc = el.getAttribute('value').then(function (txt) {
                        status = txt;
                        return status
                    });
                    el_progress.getAttribute('style').then(function (progress) {
                        console.log('\n ************************* Lessson progress : ' + progress);
                    });
                    el.click();
                }
            });
        });
    }

};

问题是函数返回 "undefined" 值,打印语句 console.log("returned value is : " + fn_return_val); 在函数实现之前执行

谁能帮我解决这个问题?

这都是关于承诺和量角器的Control Flow

您需要解决 promise 并将结果记录在 then:

lesson.select_lesson(lesson1_text).then(function(fn_return_val) {
    console.log("returned value is : " + fn_return_val);
});

而且您还需要 return 从一个函数:

function select_lesson(lesson_name) {

    ...

    // return here
    return repeter.then(function (items) {
        ...
        }).then(function clickOption() {
            ...
        });
    });
}