-
Notifications
You must be signed in to change notification settings - Fork 906
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
CLI has a big delay in starting Android apps in newer versions of React Native #2012
Comments
For context on the CLI folks, I believe this happens also on the Namely you can reproduce with:
You will see that it takes several seconds before the bundler actually starts |
Looks like some kind of regression with Metro server discovery or Android config resolution. @szymonrybczak is investigating this |
Hey @cortinico @thymikee @szymonrybczak unfortunately the update to React Native 0.72.4 has not fixed the issue. Still a delay of several minutes between "Starting JS server..." and "Installing the app...". Any chance this can be opened again and reviewed? Thanks in advance! |
@cortinico @thymikee @szymonrybczak this continues to be an issue, reported by other user as well here |
@rodrigo-nexudus would you mind sharing some repro that would help us pin down the root cause? |
Hey @thymikee apologies for the delay in getting back to you. I've seen this in every project I've worked on in version 0.72 of React Native. It seems the more complex the project is, dependencies wise, the longer the delay is. In the most complex app I work on, the delay is 2-3 minutes, and this particular application has a lot of dependencies, different flavours and native code, but unfortunately I cannot share that particular project. The issue did crop up after an upgrade to 0.72 though. I can create a repo with a lot of random dependencies if you like, but as far as I can tell this is affecting all projects. I mentioned this in the initial issue that was created on the React Native project here, and did some initial testing for @cortinico, who narrowed it down to the CLI and asked me to open this issue here. |
Hi @rodrigo-nexudus thanks for reporting cli/packages/cli-platform-android/src/commands/runAndroid/listAndroidTasks.ts Lines 31 to 41 in 2204d35
In an essence, we are running |
Hey @adamTrz thanks for your reply! I was under the impression this happened after the app begins the install process, and it actually outputs the tasks it needs to run on the console? The delay on our app is prior to the The As I mentioned before, the delay is between |
That would make sense actually, we gather information on all available build types with You've mentioned that |
As the output from |
Hey @rodrigo-nexudus together with @adamTrz we crafted solution, would you mind to test it on your own? 🙏 Here you have got instructions how to get this running locally. |
Hey @szymonrybczak , no luck unfortunately. I cloned the cli project, added your fix, linked the packages to our project, ran the app, but the delay is still there, in this case after Once the app moved on to installing, we could still also see all our flavours being run through, although again, that's a separate issue, just thought your fix might also affect that. But everything seems to be as it was before. And in case this comes up, yes we are running React Native 0.72.3, yes we tried 0.72.4, but it didn't fix our issue so we stayed on the version we were on. I'm attaching a couple of screenshots below of the changes I've made. The app also didn't build so it's possible I did something wrong, so I will run it all again to be sure, but I followed all the steps detailed on the instructions. I also ran |
Hey @szymonrybczak and @adamTrz I've re-run everything today with a bit more time and can confirm the above solution did not fix the delay. All as mentioned on my previous comment, about 4 minutes before |
Just a little side note:
@rodrigo-nexudus if Also @adamTrz, we should not be running |
Hey @cortinico as I've mentioned before, our app is pretty complex. We have a lot of native code and SDKs and over 100 flavours. When I run This didn't happen to us on previous versions of React Native, we went from 0.69 to 0.72 and that is when this delay started happening. |
Has that changed since previous versions? (I wonder whether this could be task cache invalidation caused by a shelling out to |
@robhogan from my side I can't tell if that has changed, as I never ran
I tried enabling One thing that has made a difference was commenting out all flavours from |
Are you able to go back via source control to before the upgrade and try it? That'd also help confirm that the upgrade is the cause. In the absence of a repo project any concrete difference (eg, tasks run now that didn't previously) that we might be able to reproduce would be super helpful. |
Hey CLI team, I followed the suggestion by @robhogan and reverted to a commit with React Native 0.71.11. No delay there, immediately goes from As for a repo project, I am happy to create a sample one, but I think all you would need to do is create a new react native app and add a lot of flavours to |
@rodrigo-nexudus were you able to try Otherwise, now that you can repro the difference at the end-to-end build level, it'd be great if you can narrow it down to a bit further. |
Here's the output of
This is related to a custom repository for a new SDK we have added, and should not be the cause of the issue. Other than the above, they take a similar amount of time and run tasks for every flavour within our application. @robhogan I'm not sure how you want me to narrow it down further, if tasks wasn't running before at that point and is now, and tasks is made much slower by having a lot of flavours. |
I still have the delay issue with the react-native version
However with this, you need to start the metro bundler yourself. |
Hey CLI team, any chance we can get an update on this? The initial fix provided did not resolve the issue, and the delay is very lengthy, meaning building takes close to 10 minutes. I would really appreciate a solution to this, as I'm sure others here and in the main React Native repo thread would. Thanks in advance! |
@rodrigo-nexudus we'd appreciate a reproducible example which we could inspect. Otherwise it's shooting in the dark |
Hey @thymikee, I think here's great example I believe: https://github.com/Expensify/App |
hi @hungvu193 thanks for the repro, checked it by myself and I can confirm it takes ~10mins to build the app. Gonna take a look on this next week 👍 |
Hi @hungvu193 @rodrigo-nexudus I opened a PR #2144 , already tested it with Expensify, but if you have any other complex app to test it with, feel free to follow the contributing guide and give it a try. Let me know if you run into any issues |
@TMisiukiewicz I'll test it and let you know! Thank you for your amazing work 🙇 |
@TMisiukiewicz I can confirm it worked 🚀 Screen.Recording.2023-10-31.at.16.41.49.movDummy question, how do you test this PR within an existing project? I tried "resolutions" in my package json to override current "resolutions": {
"@react-native-community/cli": "git+https://github.com/react-native-community/cli.git#e17764a20951d5b9c2ba948cd2d8417c70a2c9e4"
} |
Amazing, happy it works!
You can clone my fork, checkout branch from the PR, then follow the Contributing guide and link local packages in your project. Alternatively, if you don't want to link them, you can just point to the main script using node, eg. |
Awesome and I'll give it a try! 👍 |
There hasn't been any activity on this issue in the past 3 months, so it has been marked as stale and it will be closed automatically if no further activity occurs in the next 7 days. |
Environment
System:
OS: macOS 13.3.1
CPU: (8) arm64 Apple M1
Memory: 54.14 MB / 16.00 GB
Shell:
version: "5.9"
path: /bin/zsh
Binaries:
Node:
version: 16.19.1
path: /var/folders/79/d8l5t8f510j93_0rvtf6cdh40000gn/T/yarn--1689079820992-0.6055964608057027/node
Yarn:
version: 1.22.19
path: /var/folders/79/d8l5t8f510j93_0rvtf6cdh40000gn/T/yarn--1689079820992-0.6055964608057027/yarn
npm:
version: 8.19.3
path: ~/.nvm/versions/node/v16.19.1/bin/npm
Watchman:
version: 2022.12.05.00
path: /opt/homebrew/bin/watchman
Managers:
CocoaPods:
version: 1.12.1
path: /usr/local/bin/pod
SDKs:
iOS SDK:
Platforms:
- DriverKit 22.4
- iOS 16.4
- macOS 13.3
- tvOS 16.4
- watchOS 9.4
Android SDK: Not Found
IDEs:
Android Studio: 2022.2 AI-222.4459.24.2221.10121639
Xcode:
version: 14.3/14E222b
path: /usr/bin/xcodebuild
Languages:
Java:
version: 17.0.7
path: /usr/bin/javac
Ruby:
version: 2.6.10
path: /usr/bin/ruby
npmPackages:
"@react-native-community/cli": Not Found
react:
installed: 18.2.0
wanted: 18.2.0
react-native:
installed: 0.72.1
wanted: 0.72.1
react-native-macos: Not Found
npmGlobalPackages:
"react-native": Not Found
Android:
hermesEnabled: false
newArchEnabled: false
iOS:
hermesEnabled: false
newArchEnabled: false
Description
Follow up to issue opened here
Details and testing on link above. It seems CLI is adding a noticeable delay (can be upwards of several minutes in complex projects) when starting up an Android app. In our project this delay hangs the process several minutes before eventually starting the "installation". This was caused in our case by updating from react native 0.67.5 to 0.72.1. Likely a general issue with all apps, exacerbated by complexity.
Reproducible Demo
Any app running newer versions of React Native should suffer from this, but the delay seems to be worse on apps with more libraries/complexity. Please refer to link above for some of the testing already done to rule out a runtime issue.
The text was updated successfully, but these errors were encountered: