繁体   English   中英

承诺解决不等待其中的承诺

[英]Promise resolve not waiting for promise inside it

我试图打个电话,更新列表,然后用更新后的列表解决诺言。

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()

该请求被发布,并且我能够在测试栏中创建测试,但是resolve(tests)没有newId分配。 这是我得到的输出。 不确定为什么resolve不等待其余调用完成。

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

compareTestRailAndProtractor返回Promise 您可以在.then()使用async/awaitfor循环中的Promise构造函数来等待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具有非阻塞性。 问题是在您的“ post”事件得到响应之前(即从中获取ID的事件),将执行“ resolve(test)”。

我建议您看一下https://caolan.github.io/async/异步是一个处理异步过程的出色库。

祝好运!

编辑:您也可以看看异步/等待 JS运算符

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM