我有一系列异步/等待函数,但是它们似乎按照表明await
语句未阻止执行的顺序执行。我正在使用Twilio和Sequelize,但我想可以在不知道这两个软件包之一的情况下诊断出异步问题。很抱歉发布了这么多代码,但我觉得我需要将所有内容都包括在内以解释问题。
我的主要代码是:
app.post('/sms',async function(req,res){
try{
worker=await worker.updateWorker('+18005559999',process.env.TWILIO_OFFLINE_SID);
responseValue="/sms: worker "+worker.friendlyName+" updated to: "+worker.activityName;
console.log(responseValue);
res.status(200).send();
}
catch(err){
console.log("/sms error: "+err);
}
}
worker.updateWorker()
在ES6类中的定义如下:
async updateWorker(contact_uri,activitySid){
console.log("updateWorker: getting workerSid from database");
workerSid=await database.getWorkerSid(contact_uri);
console.log("updateWorker: workerSid is "+workerSid);
worker=await this.updateWorkerFromSid(workerSid,activitySid);
console.log("updateWorker: worker's friendlyName is "+worker.friendlyName);
return worker;
}
database.getWorkerSid()
是:
getWorkerSid(contact_uri){
return new Promise(function(resolve,reject){
sequelize.query("select * from worker where contact_uri='"+contact_uri+"'",
{ type: sequelize.QueryTypes.SELECT})
.then(result=>{
if(result.length==0){
resolve(null);
}
else{
resolve(result[0].sid);
}
})
.catch(err=>reject(err));
});
}
this.updateWorkerFromSid()
是:
async updateWorkerFromSid(workerSid,activitySid){
var worker;
try{
worker=await this.workspace.workers(workerSid)
.update({
activitySid:activitySid
});
console.log("updateWorkerFromSid: worker has been updated to activity: "+worker.activityName);
return worker;
}
catch(err){
console.log("updateWorkerFromSid error: "+err);
}
finally{
return worker;
}
}
我最终进入控制台的是:
updateWorker: getting workerSid from database
Executing (default): select * from worker where contact_uri='+18005559999'
/sms error: ReferenceError: workerSid is not defined
因此,这使我认为我们可以到达sequelize.query()
中的database.getWorkerSid()
调用,但是执行继续进行而不必等待查询承诺解决,而且就行了:
console.log("updateWorker: workerSid is "+workerSid);
workerSid
是未定义的,因此会发生崩溃,并且错误会传播回到主代码中的try / catch块。
基本上,我想做的是:
workerSid
从数据库中获取contact_uri
workerSid
更新worker 我应该如何设置异步/等待以确保事件按此顺序发生?
答案 0 :(得分:0)
我重构了database.getWorkerSid()
,以摆脱Promise构造函数的反模式,如下所示:
async getWorkerSid(contact_uri){
var workerRow=await this.getRowFromWorkerTable(contact_uri);
if (workerRow.length==0){
return null;
}
else{
return workerRow[0].sid;
}
}
getRowFromWorkerTable(contact_uri){
return sequelize.query("select * from worker where contact_uri='"+contact_uri+"'",
{ type: sequelize.QueryTypes.SELECT});
}
然后我使用var
在类方法中声明了所有变量,例如
var workerSid=await database.getWorkerSid(contact_uri);
现在可以使用。