Heroku和Node 0.10.29:在配置中替换环境变量失败

3
为了在Heroku部署的Node应用中使用私有包注册表,我一直在我的项目中包含以下.npmrc文件:
_auth = ${NPM_AUTH}
always-auth = true
registry = https://myprivateregistry.com/

NPM_AUTH是以npm期望的形式表示名称/密码哈希值。

这使我可以将凭据保留在版本控制之外。一切都正常工作,直到我开始推送到Heroku时出现以下错误:

♥ → git push heroku HEAD:master
Fetching repository, done.
Counting objects: 11, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (9/9), done.
Writing objects: 100% (11/11), 915 bytes | 0 bytes/s, done.
Total 11 (delta 8), reused 4 (delta 1)

-----> Node.js app detected
-----> Requested node range:  ~0.10.15
-----> Resolved node version: 0.10.29
-----> Downloading and installing node
-----> Restoring node_modules directory from cache
-----> Pruning cached dependencies not specified in package.json
       Error: Failed to replace env in config: ${NPM_AUTH}
           at /tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/node_modules/npmconf/npmconf.js:371:13
           at String.replace (native)
           at envReplace (/tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/node_modules/npmconf/npmconf.js:366:12)
           at parseField (/tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/node_modules/npmconf/npmconf.js:345:7)
           at /tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/node_modules/npmconf/npmconf.js:290:15
           at Array.forEach (native)
           at Conf.add (/tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/node_modules/npmconf/npmconf.js:289:21)
           at ConfigChain.addString (/tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/node_modules/npmconf/node_modules/config-chain/index.js:244:8)
           at Conf.<anonymous> (/tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/node_modules/npmconf/npmconf.js:278:10)
           at fs.js:271:14


       /tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/lib/npm.js:33
           throw new Error('npm.load() required')
                 ^
       Error: npm.load() required
           at Object.npm.config.get (/tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/lib/npm.js:33:11)
           at exit (/tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/lib/utils/error-handler.js:49:27)
           at process.errorHandler (/tmp/build_fb6a1362-16ae-4753-b169-3a1bed157306/vendor/node/lib/node_modules/npm/lib/utils/error-handler.js:316:3)
           at process.emit (events.js:95:17)
           at process._fatalException (node.js:272:26)

 !     Push rejected, failed to compile Node.js app

To git@heroku.com:myproject.git
 ! [remote rejected] HEAD -> master (pre-receive hook declined)
error: failed to push some refs to 'git@heroku.com:myproject.git'

环境变量已设置,并且我能够通过在我的package.json文件的engines字段中指定版本0.10.28来再次提交它。

我希望了解以下信息:

  1. 哪些部分发生了变化:node、npm、npmconf或Heroku?(提供相关提交和问题的链接非常好。)
  2. 更改是否是有意的,还是我需要提交一个bug报告?
1个回答

2

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接