fel*_*ima 15 npm firebase google-cloud-functions
我正在使用react-crud-shared作为使用Firebase Cloud Functions 的react-crud-backend 的依赖项。
在react-crud-backend我有以下内容:
{
"name": "react-crud-backend",
"description": "Cloud Functions for Firebase",
"scripts": {
...
},
"dependencies": {
...
"react-crud-shared": "file:../shared",
...
},
"engines": {
"node": "8"
},
"private": true,
"devDependencies": {
...
}
}
Run Code Online (Sandbox Code Playgroud)
在react-crud-shared我有以下内容:
{
"name": "react-crud-shared",
"version": "0.0.1",
"description": "",
"main": "src/index.js",
"private": true,
"dependencies": {
"lodash": "^4.17.11"
}
}
Run Code Online (Sandbox Code Playgroud)
它在开发中运行良好:“firebase serve --only functions”,但在部署时会引发错误:
Did you list all required modules in the package.json dependencies?
Detailed stack trace: Error: Cannot find module 'react-crud-shared'
Run Code Online (Sandbox Code Playgroud)
有没有办法让它工作而不必将私有存储库发布到 NPM?
谢谢
编辑:我找到了一个我更喜欢的解决方案。我在这里评论了这个 github 问题:https : //github.com/firebase/firebase-tools/issues/968#issuecomment-460323113。基本上,npm pack在我使用 firebase deploy 之前,我有一个预安装脚本运行来复制函数目录下的包。
FWIW 我有完全相同的问题。不完全确定我将如何解决它,但是来自文档的这些信息很有帮助(https://firebase.google.com/docs/functions/handle-dependencies):
要为您的函数指定依赖项,请将其添加到您的 package.json 文件中。如果您通过 gcloud 命令行工具进行部署,您还可以预安装依赖项并将它们与您的函数一起部署。默认情况下,node_modules 文件夹会添加到您的 .gcloudignore 文件中,并且不会作为部署的一部分上传。要部署预安装的依赖项,请在部署函数之前从 .gcloudignore 文件中删除 node_modules/。
注意:部署预安装的依赖项仅适用于 gcloud;Firebase CLI 会忽略本地 node_modules 文件夹。
因此,您似乎可以先在本地运行“npm install”,然后使用 gcloud 进行部署,因为它会复制您的 node_modules 目录,该目录将包含您的对等依赖项。
不过,我不得不从 firebase CLI 切换到 gcloud 进行部署,这真的很糟糕。啊。
| 归档时间: |
|
| 查看次数: |
2978 次 |
| 最近记录: |