Running rn-nodeify breaks node_modules
you-fail-me opened this issue · 15 comments
@you-fail-me pretty strange, haven't experienced this myself. Care to investigate and submit a PR?
@mvayngrib I'm trying to investigate that but some help, suggestions, advice etc would be very helpful.
@you-fail-me absolutely. The gist is:
the --install part
crawls the project using the findit
module and potentially modifies all the package.json files in the node_modules tree (with fs.writeFile), as well as the project's own package.json. It then runs npm install --save list,of,core,shims
, e.g. npm install stream-browserify,react-native-crypto
to install missing shims for core modules.
the --hack part
goes through node_modules and patches modules that the react-native packager chokes on but webpack and browserify don't, for whatever reason, e.g.: nulls imports that are destined to fail in the react-native environment, adjusts paths for imports that the react-native packager's path resolution breaks on, etc. Basically a bunch of naughty special cases. A few of them may no longer be necessary as the packager has evolved some.
Feel free to ask me about what any particular part does.
For some reason it deletes stuff:
not reinstalling assert
not reinstalling browserify-zlib
not reinstalling inherits
not reinstalling console-browserify
not reinstalling constants-browserify
not reinstalling react-native-crypto
not reinstalling dns.js
not reinstalling domain-browser
not reinstalling events
not reinstalling https-browserify
not reinstalling os-browserify
not reinstalling path-browserify
not reinstalling process
not reinstalling punycode
not reinstalling querystring-es3
not reinstalling react-native-level-fs
not reinstalling react-native-udp
not reinstalling stream-browserify
not reinstalling string_decoder
not reinstalling timers-browserify
not reinstalling tty-browserify
not reinstalling url
not reinstalling util
not reinstalling vm-browserify
not reinstalling readable-stream
not reinstalling react-native-randombytes
installing from npm buffer
installing from github react-native-http
installing from npm react-native-tcp
installing: npm install --save buffer@^3.0.3 tradle/react-native-http#834492d react-native-tcp@^2.0.4
npm WARN gentlyRm not removing /Users/user/app/node_modules/.bin/semver as it wasn't installed by /Users/user/app/node_modules/semver
npm WARN gentlyRm not removing /Users/user/app/node_modules/.bin/json5 as it wasn't installed by /Users/user/app/node_modules/json5
+ react-native-tcp@2.0.4
+ buffer@3.6.0
+ react-native-http@1.0.0
added 1 package, removed 899 packages and updated 11 packages in 22.882s
@mvayngrib I thought it shouldn't remove anything, but it removes 899(!) packages... why would it?
oh, interesting! Those last lines are output from npm install
. I'm not sure why it's removing packages, maybe it's something particular to your setup? Can you go into node_modules/.bin/rn-nodeify, look for proc.execSync(installLine,
, comment out that block, re-install and re-run rn-nodeify and then see if there are any clues in the package.json's in the tree that would make npm install remove stuff?
another thought: maybe it's hitting the maximum number of open files on your system and ends up corrupting the package.json files in the tree. If that's the case, we'll need to batchify some of the operations
@you-fail-me i also see a bunch of issues on npm, like this one: infinitered/ignite#1101 Are you using npm version 5?
@mvayngrib thanks for pointing me to npm. I'm using yarn but have npm 5 installed, and turns out rn-nodeify was using it. downgrading to npm 4 seems to solve this, at least my packages no longer get removed. Thanks a lot and sorry for the issue, actually related to npm, but not to rn-nodeify
@you-fail-me no worries, it's good for me to be aware of the npm issue anyway :)
+1 have the same with npm 5
+1 npm 5.3.0
I see this behavior, as well, with npm 5.3.0
Specifically, after
"postinstall": "rn-nodeify --install crypto,fs,http --hack"
I get an empty node_modules/react-native folder.
"postinstall": "rn-nodeify --install crypto,fs --hack"
does not remove the contents of react-native.
closing as it seems to be an npm issue, will re-open if proved otherwise
@mvayngrib Now that npm is at version 6.13, telling users to choose npm 3 or yarn in order to use rn-nodeify
probably is out-of-date advice, right? Would it be worth removing that from the README
?