8

我正在尝试部署 fireabase 示例,但是当我尝试部署它时,CLI 会启动一个错误:

[代码]

const functions = require('firebase-functions'); //to activate firebase functions

const admin = require('firebase-admin'); //to active firebase database permissions

admin.initializeApp(functions.config().firebase);

exports.addMessage = functions.https.onRequest((req, res) => {
// [END addMessageTrigger]
  // Grab the text parameter.
  const original = req.query.text;
  // [START adminSdkPush]
  // Push the new message into the Realtime Database using the Firebase Admin SDK.
  admin.database().ref('/messages').push({original: original}).then(snapshot => {
    // Redirect with 303 SEE OTHER to the URL of the pushed object in the Firebase console.
    res.redirect(303, snapshot.ref);
  });
  // [END adminSdkPush]
});

[错误]

  15:3   error  Expected catch() or return                  promise/catch-or-return
  15:69  error  Each then() should return a value or throw  promise/always-return

✖ 2 problems (2 errors, 0 warnings)


npm ERR! Darwin 17.4.0
npm ERR! argv "/usr/local/bin/node" "/usr/local/bin/npm" "--prefix" "/Users/user/test/functions" "run" "lint"
npm ERR! node v6.10.2
npm ERR! npm  v3.10.10
npm ERR! code ELIFECYCLE
npm ERR! functions@ lint: `eslint .`
npm ERR! Exit status 1
npm ERR! 
npm ERR! Failed at the functions@ lint script 'eslint .'.
npm ERR! Make sure you have the latest version of node.js and npm installed.
npm ERR! If you do, this is most likely a problem with the functions package,
npm ERR! not with npm itself.
npm ERR! Tell the author that this fails on your system:
npm ERR!     eslint .
npm ERR! You can get information on how to open an issue for this project with:
npm ERR!     npm bugs functions
npm ERR! Or if that isn't available, you can get their info via:
npm ERR!     npm owner ls functions
npm ERR! There is likely additional logging output above.

npm ERR! Please include the following file with any support request:
npm ERR!     /Users/eliassebastian/Developer/npm-debug.log

Error: functions predeploy error: Command terminated with non-zero exit code1

我看一下firebase here提供的原始最终版本

我是 Javascript 和这个世界的新手,所以我真的迷失了这种类型的消息。

我该如何解决这个问题?

4

2 回答 2

23

ESLint 警告是合法的。要获得每一个的更多详细信息,您可以使用它们的唯一 ID 搜索它们。例如:

15:3   error  Expected catch() or return                  promise/catch-or-return

这里警告的 id 是promise/catch-or-return. 谷歌搜索“eslint promise/catch-or-return”会找到一个 ESLint 插件,该插件将警告描述为:

强制对未返回的承诺使用 catch()

你得到这个是因为你有一个从 中返回的承诺then,但你从来没有returncatch可能出现错误。

第二个警告:

15:69  error  Each then() should return a value or throw  promise/always-return

来自同一个 ESLint 插件,描述如下:

在每个 then() 内部返回以创建可读和可重用的 Promise 链。

它要求您在由 调用的每个函数中返回一个值then,即使您没有任何特殊的东西要发送到下一个承诺链。

您可以像这样解决这两个问题:

admin.database().ref('/messages').push({original: original}).then(snapshot => {
    res.redirect(303, snapshot.ref);
    return null;
}).catch(error => {
    console.error(error);
    res.error(500);
});

请注意,该then块现在返回 null,并catch用于从返回的 Promisethen中捕获错误并向客户端发送错误响应。

于 2018-02-02T16:38:08.953 回答
0

Doug Stevenson的回答部分正确,因为其中存在一个缺陷。

它应该是 :

admin.database().ref('/messages').push({original: original}).then(snapshot => {
    res.redirect(303, snapshot.ref);
    return 1; // IT SHOULD RETURN NON-NULL VALUE
}).catch(error => {
    console.error(error);
    res.error(500);
});

云功能问题已解决

云函数在返回 null 时进入无限循环。结果,我们可以在上图中看到函数在 60,000 毫秒后超时。

未执行的功能

在这样的多个超时函数之后,您将得到可以执行的错误函数(如上图所示)。这是因为在 Spark 计划(免费套餐计划)中,对CPUMilliSecondsDailyNonbillable有限制。

GCD配额区 如果你在云功能部分点击Stackdriver 的配额政策,你可以看到 GCD(谷歌云平台)中的限制

于 2018-10-06T06:47:03.263 回答