承诺决心不等待里面的承诺



我正在尝试进行休息调用并更新列表,然后使用更新的列表解决承诺。

function addTestCaseToTestRail(){
    return new Promise(function(resolve){
        compareTestRailAndProtractor().then(function(tests){
            var testsLength = tests.tests.length;
            var url = testRailURL+testRailData.addTestEndPoint;
            for(var i=0; i<testsLength; i++){
                if(tests.tests[i].id==undefined){
                    var newId=""
                    var options = {
                        url:url,
                        headers:headers,
                        body:{
                            "title":tests.tests[i].name,
                            "custom_jira_component" : 465
                        },
                        json: true
                    }
                    request.post(options, function(err, httpResponse, body){
                        if (err) {
                            console.error(err);
                            return;
                        }
                        newId = body.id;
                    });
                    tests.tests[i].id = newId;
                }
            }
            resolve(tests);
        });
    });
}
function test(){
    addTestCaseToTestRail().then(function(tests){
        console.log(tests);
    });
}
test()

请求正在发布,我能够在测试轨道中创建测试,但解析(测试)没有 newId 分配。这是我得到的输出。不知道为什么解析不等待其余调用完成。

{ tests: 
    [ { id: '', name: 'test1'},
      { id: '', name: 'test2'},
      { id: '', name: 'test3'},
      { id: '', name: 'test4'},
      { id: '', name: 'test6'},
      { id: '', name: 'test5'} ] }

compareTestRailAndProtractor 返回一个Promise 。您可以在 .then() 中使用 async/await 并在循环中使用Promise构造函数for等待request回调,这是在 Question 的代码中发出的,因为 for 循环不等待回调函数

function addTestCaseToTestRail() {
  return compareTestRailAndProtractor()
    .then(async function(tests) {
        var testsLength = tests.tests.length;
        var url = testRailURL + testRailData.addTestEndPoint;
        for (var i = 0; i < testsLength; i++) {
          await new Promise((resolve, reject) => {
              if (tests.tests[i].id == undefined) {
                var newId = ""
                var options = {
                  url: url,
                  headers: headers,
                  body: {
                    "title": tests.tests[i].name,
                    "custom_jira_component": 465
                  },
                  json: true
                }
                request.post(options, function(err, httpResponse, body) {
                  if (err) {
                    reject(err);
                  }
                  newId = body.id;
                  tests.tests[i].id = newId;
                  resolve();
                });
              } else {
                resolve()
              }    
          });
      }
      return tests
    })
}
function test() {
  addTestCaseToTestRail()
    .then(function(tests) {
      console.log(tests);
    })
    .catch(function(err) {
      console.error(err)
    })
}
test()

我认为这是因为Javascript的非阻塞性质。问题是"resolve(test)"在你的"post"事件有响应之前被执行(这是你从中获取ID的那个)。

我建议您看看 https://caolan.github.io/async/Async 是一个用于处理异步进程的惊人库。

祝你好运!

编辑:你也可以看看async/await JS运算符

最新更新