Skip to content
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

Deadlock during start with new architecture on iOS #4506

Open
2 tasks done
TimotheeIsnard opened this issue Jun 10, 2024 · 10 comments
Open
2 tasks done

Deadlock during start with new architecture on iOS #4506

TimotheeIsnard opened this issue Jun 10, 2024 · 10 comments

Comments

@TimotheeIsnard
Copy link

What happened?

Hello,
I have a React Native app that I test on iOS, on both the old and new RN architecture, and when starting the app with the new architecture enabled Detox freezes while trying to first enable synchronization.
There is no freeze on the old RN architecture.

I tried --debug-synchronization, but it has nothing to say, since Detox seems to block internally before reaching the app code.
By adding logs and following in a debugger, I found that the freeze comes from the waitForReactNativeLoadWithCompletionHandler function in DetoxSync.

I opened a PR in DetoxSync that fixes the deadlock for me, but there may be other ways to solve the freeze, so I wanted to make a bug report here anyways (also, this repo seems more active)
DetoxSync PR: wix-incubator/DetoxSync#74

What was the expected behaviour?

Detox should start on iOS with the new architecture enabled.

Was it tested on latest Detox?

  • I have tested this issue on the latest Detox release and it still reproduces.

Did your test throw out a timeout?

Help us reproduce this issue!

The freeze reproduces 100% of the time, if I do either a regular await device.launchApp(), or a manual:

  const detoxArgs = {
    launchArgs: {
      detoxEnableSynchronization: 0,
      'DTXEnableVerboseSyncSystem': 'YES',
      'DTXEnableVerboseSyncResources': 'YES'
    },
  };
  await device.launchApp(detoxArgs);

  console.log('Device launched, enabling sync again soon...');
  await new Promise((r) => setTimeout(r, 5000));
  console.log('Device launched, enabling sync again');
  await device.enableSynchronization();

In what environment did this happen?

Detox version: 20.22.2
React Native version: 0.73
Has Fabric (React Native's new rendering system) enabled: Yes
Node version: 22.2.0
Device model: iPhone 15 simulator
iOS version: 17.5
macOS version: Sonoma 14.5
Xcode version: 15.4 (15F31d)
Test-runner (select one): jest

Detox logs

Detox logs (in attachment due to 65kB github comment limit): detox_loglevel_trace.txt

Device logs

No response

More data, please!

Output of xcrun simctl spawn booted log stream --level debug --style compact | tee detoxlog:
detox_xcrun_log.tar.gz (13 MB uncompressed)

@Sky
Copy link

Sky commented Oct 22, 2024

It looks like this is causing similar issue as here: #3949
@TimotheeIsnard could you share steps on how to apply your patch locally?

I tried to:

  1. unpack ./node_modules/detox/Detox-ios-src.tbz
  2. rename Detox-ios-src folder to ios
  3. apply your changes to DetoxSync sources
  4. run ./scripts/pack_ios.sh which created new frameworks and archived them
  5. run detox rebuild-framework-cache
  6. rebuild app with detox build (this is probably not needed since Detox framework is injected during app launch)

But this did not helped and it's still stuck waiting after app launched. RN 0.75.4 with New Arch enabled. Detox 20.27.4. Also having similar issue on Android.

@TimotheeIsnard
Copy link
Author

TimotheeIsnard commented Oct 23, 2024

Hey there. Sorry to hear there are more of us out there having Detox deadlocks :)
We're current using our own private fork of Detox in CI to workaround these upstream issues.

Here's how I build and run a custom Detox on my react native app/lib for iOS, in case it can help:


Git clone detox, then:

git submodule update --init --recursive
lerna bootstrap

# (ignore this for iOS, this is for Android only)
cd detox/android
# ./gradlew clean detox:publish -Dversion=20.20.0 # Replace by cur ver number 

In your react-native app's root folder, do a regular yarn install at the root (with the regular upstream detox in package.json), then:

rm example/node_modules/detox -r && ln -s /YOUR_LOCAL_FOLDER_HERE/Detox/detox example/node_modules/detox

For ios in your react native app's folder:

rm -r ~/Library/Detox/ && yarn detox build-framework-cache

Then I can do yarn detox build/yarn detox test as usual my RN app's repository, and now the app JS/content load can happen in any order, without deadlocking on startup.

@Sky
Copy link

Sky commented Oct 23, 2024

@TimotheeIsnard thanks for sharing those steps. Just to confirm do you have any other patches in your private forks or only those you added to wix-incubator/DetoxSync#74 ?
Also does Detox work for you on Android with New Architecture enabled?
And what are your current versions of RN and Detox?

@TimotheeIsnard
Copy link
Author

TimotheeIsnard commented Oct 24, 2024

That's the only patch we have at the moment. It does work for us on Android with new arch (including fabric). There is still some random flakyness on some configs (mostly Android, more on older API levels), but that's just Detox, and it's <1%. We can generally workaround the unreliable random failures without patching Detox itself.

Currently we're running RN 0.73.6, Detox 20.23 (haven't updated our fork since 7345e6c)
We test on both old and new architecture, with both old and new Android versions, plus iOS.

@asamaranayake
Copy link

Im still getting this issue
Any idea how to fix this

@Sky
Copy link

Sky commented Nov 12, 2024

@asafkorem do you have some roadmap on supporting newer versions of React Native and New Architecture? 0.73 that is currently highest version officially supported by Detox is out of support window by RN team and 0.76 was released with New Architecture enabled by default https://github.com/facebook/react-native/releases

@Sky
Copy link

Sky commented Nov 20, 2024

I investigated more on this and figured out that with Fabric and Bridgeless enabled on RN 0.76 there are many issues with Detox selectors related to completely different native views structure generated by RN and other functionality not working related to Detox dependencies on Bridge and other legacy components. I did an attempt to fix some of the issues on iOS but there are still tests that are failing. Probably will not have resources to fix this also I think there will be similar problems on Android as well

https://github.com/Sky/Detox/pull/1/files
https://github.com/Sky/DetoxSync/pull/1/files

@dominictobias-bullish
Copy link

Any tips? Detox opens the app on Expo 52 with new arch but then doesn't run any of the tests

@tmitchel2
Copy link

My tip is to delete the iOS build dir and rerun podinstall with newarch turned off, then turn it back on after testing. Obviously less than desirable. That's the only way I see that it can be navigated for now.

Copy link

stale bot commented Jan 22, 2025

This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs.
If you believe the issue is still relevant, please test on the latest Detox and report back.

Thank you for your contributions!

For more information on bots in this repository, read this discussion.

@stale stale bot added the 🏚 stale label Jan 22, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

5 participants