I'm new to create-react-app. I just made a quick setup with redux and react-router-dom which builds nicely on my computer using yarn build, but when pushing to Scalingo or Heroku the build fails with the following error:
./src/index.jsx
Error: Failed to load plugin import: Cannot find module 'eslint-plugin-import'
Referenced from:
at Array.forEach (<anonymous>)
at Array.reduceRight (<anonymous>)
I did not do anything to customize deployment, just pushed to production.
Here is the full deployment log :
Enumerating objects: 74, done.
Counting objects: 100% (74/74), done.
Delta compression using up to 4 threads
Compressing objects: 100% (68/68), done.
Writing objects: 100% (74/74), 185.95 KiB | 4.77 MiB/s, done.
Total 74 (delta 20), reused 15 (delta 0)
<-- Start deployment of xxx-app-staging -->
Fetching source code
-----> Creating runtime environment
NPM_CONFIG_LOGLEVEL=error
NPM_CONFIG_PRODUCTION=true
NODE_VERBOSE=false
NODE_ENV=production
NODE_MODULES_CACHE=true
-----> Installing binaries
engines.node (package.json): unspecified
engines.npm (package.json): unspecified (use default)
engines.yarn (package.json): unspecified (use default)
Resolving node version 8.x...
Downloading and installing node 8.15.0...
Using default npm version: 6.4.1
Resolving yarn version 1.x...
Downloading and installing yarn (1.14.0)...
Installed yarn 1.14.0
-----> Restoring cache
Skipping cache restore (not-found)
-----> Building dependencies
Installing node modules (yarn.lock)
yarn install v1.14.0
[1/4] Resolving packages...
[2/4] Fetching packages...
info [email protected]: The platform "linux" is incompatible with this module.
info "[email protected]" is an optional dependency and failed compatibility check. Excluding it from installation.
info [email protected]: The platform "linux" is incompatible with this module.
info "[email protected]" is an optional dependency and failed compatibility check. Excluding it from installation.
[3/4] Linking dependencies...
warning " > [email protected]" has unmet peer dependency "eslint@^3.0.0 || ^4.0.0 || ^5.0.0".
warning "react-scripts > pnp-webpack-plugin > [email protected]" has unmet peer dependency "typescript@*".
warning " > [email protected]" has unmet peer dependency "eslint@^4.19.1 || ^5.3.0".
warning "eslint-config-airbnb > [email protected]" has unmet peer dependency "eslint@^4.19.1 || ^5.3.0".
warning " > [email protected]" has unmet peer dependency "[email protected] - 5.x".
warning " > [email protected]" has unmet peer dependency "eslint@^3 || ^4 || ^5".
[4/4] Building fresh packages...
Done in 12.22s.
Running build (yarn)
yarn run v1.14.0
$ react-scripts build
Creating an optimized production build...
Failed to compile.
./src/index.jsx
Error: Failed to load plugin import: Cannot find module 'eslint-plugin-import'
Referenced from:
at Array.forEach (<anonymous>)
at Array.reduceRight (<anonymous>)
error Command failed with exit code 1.
info Visit https://yarnpkg.com/en/docs/cli/run for documentation about this command.
-----> Build failed
We're sorry this build is failing!
Some possible problems:
- A module may be missing from 'dependencies' in package.json
http://doc.scalingo.com/languages/javascript/nodejs#ensure-youre-tracking-all-your-dependencies
- This module may be specified in 'devDependencies' instead of 'dependencies'
http://doc.scalingo.com/languages/javascript/nodejs#install-devdependencies
Keep coding,
Scalingo
! An error occured during buildpack compilation
! Error deploying the application
! → Invalid return code from buildpack
And here is my package.json:
{
"name": "xxxx",
"version": "0.1.0",
"private": true,
"dependencies": {
"@sentry/browser": "^4.5.4",
"prop-types": "^15.7.1",
"react": "^16.8.1",
"react-dom": "^16.8.1",
"react-redux": "^6.0.0",
"react-redux-i18n": "^1.9.3",
"react-router-dom": "^4.3.1",
"react-scripts": "2.1.5",
"redux": "^4.0.1",
"redux-logger": "^3.0.6",
"redux-promise": "^0.6.0",
"redux-thunk": "^2.3.0"
},
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test",
"eject": "react-scripts eject"
},
"eslintConfig": {
"extends": "react-app"
},
"browserslist": [
">0.2%",
"not dead",
"not ie <= 11",
"not op_mini all"
],
"devDependencies": {
"eslint-config-airbnb": "^17.1.0",
"eslint-plugin-import": "^2.16.0",
"eslint-plugin-jsx-a11y": "^6.2.1",
"eslint-plugin-react": "^7.12.4"
}
}
I can't understand why would I have any usage of eslint and its plugins in my production code, and how to fix this. Can you help?
node_modulesand runningnpm i/src/index.jsx, the error suggest that there is an import here that can't be found. Maybe the import shouldn't be there in the first place, but it looks to me like what you've done is correct.