Wednesday, 3 May 2017

Heroku trying to request development file while in production

I'm deploying a express and react project to heroku and all seems to be going well until I run a postinstall to build my project. I have set heroku config:set NODE_ENV=production but when I run git push heroku master it installs all my dependencies and then gets to the npm build where it fails because its trying to access a require file that is only for development env.

This is crazy seen as I set the dev environment = production. Below is my package.json script.

  "scripts": {
    "start": "node server/app.js",
    "dev": "nodemon server/app.js",
    "build": "cross-env NODE_ENV=production webpack --config ./webpack/webpack.prod.config.js --progress --colors",
    "heroku-postbuild": "npm run build"
  },

Here is the error I get.

remote: 
remote: -----> Node.js app detected
remote: 
remote: -----> Creating runtime environment
remote:        
remote:        NPM_CONFIG_LOGLEVEL=error
remote:        NPM_CONFIG_PRODUCTION=true
remote:        NODE_VERBOSE=false
remote:        NODE_ENV=production
remote:        NODE_MODULES_CACHE=true
remote: 
remote: -----> Installing binaries
remote:        engines.node (package.json):  v6.0.0
remote:        engines.npm (package.json):   3.3.4
remote:        
remote:        Resolving node version v6.0.0 via semver.io...
remote:        Downloading and installing node 6.0.0...
remote:        Downloading and installing npm 3.3.4 (replacing version 3.8.6)...
remote: 
remote: -----> Restoring cache
remote:        Loading 2 from cacheDirectories (default):
remote:        - node_modules
remote:        - bower_components (not cached - skipping)
remote: 
remote: -----> Building dependencies
remote:        Installing node modules (package.json)
remote:        (node:224) fs: re-evaluating native module sources is not supported. If you are using the graceful-fs module, please update it to a more recent version.
remote:        Running heroku-postbuild
remote:        
remote:        > Portfolio@1.1.0 heroku-postbuild /tmp/build_918738f52e06005c6e2c99818c8fcedf
remote:        > npm run build
remote:        
remote:        
remote:        > Portfolio@1.1.0 build /tmp/build_918738f52e06005c6e2c99818c8fcedf
remote:        > cross-env NODE_ENV=production webpack --config ./webpack/webpack.prod.config.js --progress --colors
remote:        
remote:        Hash: 75051662c9db78bafa19
remote:        Version: webpack 2.4.1
remote:        Time: 14721ms
remote:        Asset     Size  Chunks                    Chunk Names
remote:        homeslider-2.jpg  78.4 kB          [emitted]
remote:        separator.png   1.8 kB          [emitted]
remote:        bundle.js   479 kB       0  [emitted]  [big]  main
remote:        [3] ./~/react/react.js 56 bytes {0} [built]
remote:        [10] ./~/react-redux/lib/index.js 475 bytes {0} [built]
remote:        [39] ./~/react-router/es/PatternUtils.js 7.34 kB {0} [built]
remote:        [41] ./~/react/lib/React.js 3.32 kB {0} [built]
remote:        [50] ./~/react-router/es/index.js 1.46 kB {0} [built]
remote:        [52] ./app/js/actions/types.js 541 bytes {0} [built]
remote:        [64] ./~/react-dom/index.js 59 bytes {0} [built]
remote:        [209] ./app/js/index.js 1.29 kB {0} [built]
remote:        [244] ./app/js/routes.js 2.83 kB {0} [built]
remote:        [245] ./app/js/store.js 775 bytes {0} [built]
remote:        [472] ./~/react-router/es/Route.js 1.33 kB {0} [built]
remote:        [473] ./~/react-router/es/Router.js 5.28 kB {0} [built]
remote:        [475] ./~/react-router/es/applyRouterMiddleware.js 1.9 kB {0} [built]
remote:        [476] ./~/react-router/es/browserHistory.js 183 bytes {0} [built]
remote:        [563] multi ./app/js/index 28 bytes {0} [built]
remote:        + 549 hidden modules
remote:        
remote:        ERROR in ./server/config/config.js
remote:        Module not found: Error: Can't resolve './config.json' in '/tmp/build_918738f52e06005c6e2c99818c8fcedf/server/config'
remote:        @ ./server/config/config.js 6:15-39
remote:        @ ./app/js/actions/index.js
remote:        @ ./app/js/pages/login.js
remote:        @ ./app/js/routes.js
remote:        @ ./app/js/index.js
remote:        @ multi ./app/js/index
remote: 
remote: npm ERR! Linux 3.13.0-112-generic
remote: npm ERR! argv "/tmp/build_918738f52e06005c6e2c99818c8fcedf/.heroku/node/bin/node" "/tmp/build_918738f52e06005c6e2c99818c8fcedf/.heroku/node/bin/npm" "run" "build"
remote: npm ERR! node v6.0.0
remote: npm ERR! npm  v3.3.4
remote: npm ERR! code ELIFECYCLE
remote: npm ERR! Portfolio@1.1.0 build: `cross-env NODE_ENV=production webpack --config ./webpack/webpack.prod.config.js --progress --colors`
remote: npm ERR! Exit status 2
remote: npm ERR! 
remote: npm ERR! Failed at the Portfolio@1.1.0 build script 'cross-env NODE_ENV=production webpack --config ./webpack/webpack.prod.config.js --progress --colors'.
remote: npm ERR! This is most likely a problem with the Portfolio package,
remote: npm ERR! not with npm itself.

Error:

   remote:        ERROR in ./server/config/config.js
    remote:        Module not found: Error: Can't resolve './config.json' in '/tmp/build_918738f52e06005c6e2c99818c8fcedf/server/config'

here is the file where it would require ./config.json

config.js

var env = process.env.NODE_ENV || 'development';

console.log("env = ", env);

if(env === 'development' || env === 'test'){
  var config = require('./config.json');
  var envConfig = config[env];
  Object.keys(envConfig).forEach(function(key){
    process.env[key] = envConfig[key];
  })
}
module.exports = process.env;

So config.js requires config.json only when process.env.NODE_ENV=development.

How can this be possible that its accessing this if the environment is production?



via ericb

No comments:

Post a Comment