量角器promise调用如何执行函数调用

时间:2019-03-08 12:41:03

标签: javascript protractor

我对量角器是陌生的,因为我对Java脚本知之甚少,因此很难预测脚本的执行流程。关于量角器的行为和js文件之间的数据流,我有一个非常基本的问题。

我有一个commonTC.js,其中包含describe(),it()块。在此“ it”块中,我在运行时调用函数。意思是,我在另一个js文件中编写了open(),click(),enter()之类的函数,该函数在运行时会根据从Excel中读取的函数调用数据进行动态调用。

在量角器中,大多数浏览器交互都会返回promise,因此,当我在click()/ enter()中执行浏览器调用的逻辑时,我想在作为调用文件的commonTC.js中获取浏览器调用的详细信息。

所以我在commonTC.js中将函数作为promise()进行了调用

              dynamicActions[enter()].then(()=>{
                  console.log("Success Activity:")
              }).catch((err)=>{              
                  console.log("Error on Activity():")
                  throw err;
              });

在ActivityAction.js()中,函数定义如下

this.dynamicActions.enter = function () {
    var deferred = protractor.promise.defer();
    element(by.id("username")).sendKeys("abc").then(
            function success() {                        
                deferred.fulfill();
            },
            function error(reason) {
                deferred.reject(reason);
            });
    return deferred.promise;
    }

我的问题是- 1.由于这种体系结构,所有函数调用都必须作为promise返回。如果我不返回promise,我在commonTC.js中会知道浏览器promise结果吗? 2.同样,通过这种体系结构,所有函数调用都是同步的。因为所有功能都按承诺返回,所以那些承诺会串行执行吗?我的意思是说,在第一个承诺解决之后,是否可以保证第二个承诺将得到执行/或者也可以选择第五个? 3.如果它随机选择承诺执行,那么我如何实现承诺的串行执行? 4.如果需要删除commonTC.js中的Promise体系结构,那么如何确保每个函数open()/ enter()返回失败/成功?

1 个答案:

答案 0 :(得分:0)

量角器有一个内置的承诺管理器,名为Control Flow,可以将承诺保存在列表中,并保证列表中的承诺按脚本中显示的顺序依次执行。

it('promise execute order', ()=>{
   browser.get('...')               // promise 1
   element(by.xxx(...)).sendKeys(); // promise 2
   element(by.xxx(...)).sendKeys()
                       .then(()=>{ yyyy.then()....}) // nested `then()`
                       .then()
                       .catch()  // promise 3, no matter how many `then()` followed 
                                 // and nested. They are treated as single promise

   element(by.xxx(...)).click();    // promise 4
})

// There are 4 lines in above `it`, every protractor api return a promise
// thus there will be a list includes 4 promises:
// [promise 1, promise 2, promise 3, promise 4]
// Control Flow makes sure promise in list executed one by one.