Google DialogFlow V2履行中的神秘错误(Google Assistant模拟器为空,响应,请求,错误标签)

时间:2019-06-11 18:16:55

标签: firebase google-cloud-platform dialogflow actions-on-google dialogflow-fulfillment

我的应用程序中遇到一个神秘的错误。 (在Firebase上运行的NodeJS中编写的Google Assistant + Fulfillment)我的应用程序是购买汽油。 如果您想购买其他东西,例如苹果,它将询问您。 如果想第二次购买其他东西,例如7李子,它将把您重定向到默认意图。这就是它应该如何工作的。 但是,除此之外(请参见屏幕截图) flow

奇怪的是请求和响应以及错误选项卡为空:(对于其他用例,它们永远不会为空) Empty request tab Empty response tab Empty errors tab

在firebase函数内部,我没有看到错误日志,但在GCP日志下却看到一个错误:

{
 insertId:  "1fmi9ryg1rc8hud"  
 labels: {
  channel:  "preview"   
  querystream:  "GOOGLE_USER"   
  source:  "JSON_RESPONSE_VALIDATION"   
 }
 logName:  "projects/xxxxxx/logs/actions.googleapis.com%2Factions"  
 receiveTimestamp:  "2019-06-11T17:10:13.712416274Z"  
 resource: {
  labels: {
   action_id:  "actions.intent.TEXT"    
   project_id:  "xxxxxx"    
   version_id:  ""    
  }
  type:  "assistant_action"   
 }
 severity:  "ERROR"  
 textPayload:  "MalformedResponse: ErrorId: 113661de-882c-4238-a67a-f324359004a4. Failed to parse Dialogflow response into AppResponse because of invalid platform response. : Could not find a RichResponse or SystemIntent in the platform response for agentId: d7069fa0-5691-4104-848a-56f78e3007c4 and intentId: "  
 timestamp:  "2019-06-11T17:10:13.699816952Z"  
 trace:  "projects/xxxxxxx/traces/ABwppHEdFw2KY23BcC1eOVrIkgUCPC0ae2Sa39ixR7r1mUexFYRhdj2pH-BHNkXky1s9cgLGSw"  
}

Full error log

之所以如此神秘,是因为例如,如果我先说7李子接受,然后再说7苹果,它将进入默认意图。为什么?我不知道如果我输入随机文本(如3 sadjhb),它也会询问,第二次返回默认意图。我知道这不是对问题的正确描述,但我认为它并不能始终如一地工作。

我也可以复制此意图的实现代码,但现在我觉得这与它无关。 我希望你们当中的一个人曾经遇到过这种行为。 谢谢您的阅读!

编辑:

我有一个后备意图,每次找不到意图时都应运行 fallback intent definition 和意图实现

app.intent('service.addgasoline.getinput', (conv, params) => {
    if (params.value && params.unittype) {
      const outmessage = 'So buy gas for - ' + params.value + ' ' +  params.unittype;
      conv.ask(outmessage);
      conv.ask(new Suggestions(['Yes', 'No']));
    } else {
      conv.ask('How much gas you want to buy? For example, you can say 1 L or 1 gallon.');
    }

});

1 个答案:

答案 0 :(得分:1)

我刚刚在我的应用程序中修复了类似的问题。

在我的情况下,问题出在DialogFlow的意图训练短语上。实体的解析值不完全符合预期。

例如,整个短语“ 7 plum”可能被错误地解析为值,而不是其中的“ 7”。